| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915491649174918491949204921492249234924492549264927492849294930493149324933493449354936493749384939494049414942494349444945494649474948494949504951495249534954495549564957495849594960496149624963496449654966496749684969497049714972497349744975497649774978497949804981498249834984498549864987498849894990499149924993499449954996499749984999500050015002500350045005500650075008500950105011501250135014501550165017501850195020502150225023502450255026502750285029503050315032503350345035503650375038503950405041504250435044504550465047504850495050505150525053505450555056505750585059506050615062506350645065506650675068506950705071507250735074507550765077507850795080508150825083508450855086508750885089509050915092509350945095509650975098509951005101510251035104510551065107510851095110511151125113511451155116511751185119512051215122512351245125512651275128512951305131513251335134513551365137513851395140514151425143514451455146514751485149515051515152515351545155515651575158515951605161516251635164516551665167516851695170517151725173517451755176517751785179518051815182518351845185518651875188518951905191519251935194519551965197519851995200520152025203520452055206520752085209521052115212521352145215521652175218521952205221522252235224522552265227522852295230523152325233523452355236523752385239524052415242524352445245524652475248524952505251525252535254525552565257525852595260526152625263526452655266526752685269527052715272527352745275527652775278527952805281528252835284528552865287528852895290529152925293529452955296529752985299530053015302530353045305530653075308530953105311531253135314531553165317531853195320532153225323532453255326532753285329533053315332533353345335533653375338533953405341534253435344534553465347534853495350535153525353535453555356535753585359536053615362536353645365536653675368536953705371537253735374537553765377537853795380538153825383538453855386538753885389539053915392539353945395539653975398539954005401540254035404540554065407540854095410541154125413541454155416541754185419542054215422542354245425542654275428542954305431543254335434543554365437543854395440544154425443544454455446544754485449545054515452545354545455545654575458545954605461546254635464546554665467546854695470547154725473547454755476547754785479548054815482548354845485548654875488548954905491549254935494549554965497549854995500550155025503550455055506550755085509551055115512551355145515551655175518551955205521552255235524552555265527552855295530553155325533553455355536553755385539554055415542554355445545554655475548554955505551555255535554555555565557555855595560556155625563556455655566556755685569557055715572557355745575557655775578557955805581558255835584558555865587558855895590559155925593559455955596559755985599560056015602560356045605560656075608560956105611561256135614561556165617561856195620562156225623562456255626562756285629563056315632563356345635563656375638563956405641564256435644564556465647564856495650565156525653565456555656565756585659566056615662566356645665566656675668566956705671567256735674567556765677567856795680568156825683568456855686568756885689569056915692569356945695569656975698569957005701570257035704570557065707570857095710571157125713571457155716571757185719572057215722572357245725572657275728572957305731573257335734573557365737573857395740574157425743574457455746574757485749575057515752575357545755575657575758575957605761576257635764576557665767576857695770577157725773577457755776577757785779578057815782578357845785578657875788578957905791579257935794579557965797579857995800580158025803580458055806580758085809581058115812581358145815581658175818581958205821582258235824582558265827582858295830583158325833583458355836583758385839584058415842584358445845584658475848584958505851585258535854585558565857585858595860586158625863586458655866586758685869587058715872587358745875587658775878587958805881588258835884588558865887588858895890589158925893589458955896589758985899590059015902590359045905590659075908590959105911591259135914591559165917591859195920592159225923592459255926592759285929593059315932593359345935593659375938593959405941594259435944594559465947594859495950595159525953595459555956595759585959596059615962596359645965596659675968596959705971597259735974597559765977597859795980598159825983598459855986598759885989599059915992599359945995599659975998599960006001600260036004600560066007600860096010601160126013601460156016601760186019602060216022602360246025602660276028602960306031603260336034603560366037603860396040604160426043604460456046604760486049605060516052605360546055605660576058605960606061606260636064606560666067606860696070607160726073607460756076607760786079608060816082608360846085608660876088608960906091609260936094609560966097609860996100610161026103610461056106610761086109611061116112611361146115611661176118611961206121612261236124612561266127612861296130613161326133613461356136613761386139614061416142614361446145614661476148614961506151615261536154615561566157615861596160616161626163616461656166616761686169617061716172617361746175617661776178617961806181618261836184618561866187618861896190619161926193619461956196619761986199620062016202620362046205620662076208620962106211621262136214621562166217621862196220622162226223622462256226622762286229623062316232623362346235623662376238623962406241624262436244624562466247624862496250625162526253625462556256625762586259626062616262626362646265626662676268626962706271627262736274627562766277627862796280628162826283628462856286628762886289629062916292629362946295629662976298629963006301630263036304630563066307630863096310631163126313631463156316631763186319632063216322632363246325632663276328632963306331633263336334633563366337633863396340634163426343634463456346634763486349635063516352635363546355635663576358635963606361636263636364636563666367636863696370637163726373637463756376637763786379638063816382638363846385638663876388638963906391639263936394639563966397639863996400640164026403640464056406640764086409641064116412641364146415641664176418641964206421642264236424642564266427642864296430643164326433643464356436643764386439644064416442644364446445644664476448644964506451645264536454645564566457645864596460646164626463646464656466646764686469647064716472647364746475647664776478647964806481648264836484648564866487648864896490649164926493649464956496649764986499650065016502650365046505650665076508650965106511651265136514651565166517651865196520652165226523652465256526652765286529653065316532653365346535653665376538653965406541654265436544654565466547654865496550655165526553655465556556655765586559656065616562656365646565656665676568656965706571657265736574657565766577657865796580658165826583658465856586658765886589659065916592659365946595659665976598659966006601660266036604660566066607660866096610661166126613661466156616661766186619662066216622662366246625662666276628662966306631663266336634663566366637663866396640664166426643664466456646664766486649665066516652665366546655665666576658665966606661666266636664666566666667666866696670667166726673667466756676667766786679668066816682668366846685668666876688668966906691669266936694669566966697669866996700670167026703670467056706670767086709671067116712671367146715671667176718671967206721672267236724672567266727672867296730673167326733673467356736673767386739674067416742674367446745674667476748674967506751675267536754675567566757675867596760676167626763676467656766676767686769677067716772677367746775677667776778677967806781678267836784678567866787678867896790679167926793679467956796679767986799680068016802680368046805680668076808680968106811681268136814681568166817681868196820682168226823682468256826682768286829683068316832683368346835683668376838683968406841684268436844684568466847684868496850685168526853685468556856685768586859686068616862686368646865686668676868686968706871687268736874687568766877687868796880688168826883688468856886688768886889689068916892689368946895689668976898689969006901690269036904690569066907690869096910691169126913691469156916691769186919692069216922692369246925692669276928692969306931693269336934693569366937693869396940694169426943694469456946694769486949695069516952695369546955695669576958695969606961696269636964696569666967696869696970697169726973697469756976697769786979698069816982698369846985698669876988698969906991699269936994699569966997699869997000700170027003700470057006700770087009701070117012701370147015701670177018701970207021702270237024702570267027702870297030703170327033703470357036703770387039704070417042704370447045704670477048704970507051705270537054705570567057705870597060706170627063706470657066706770687069707070717072707370747075707670777078707970807081708270837084708570867087708870897090709170927093709470957096709770987099710071017102710371047105710671077108710971107111711271137114711571167117711871197120712171227123712471257126712771287129713071317132713371347135713671377138713971407141714271437144714571467147714871497150715171527153715471557156715771587159716071617162716371647165716671677168716971707171717271737174717571767177717871797180718171827183718471857186718771887189719071917192719371947195719671977198719972007201720272037204720572067207720872097210721172127213721472157216721772187219722072217222722372247225722672277228722972307231723272337234723572367237723872397240724172427243724472457246724772487249725072517252725372547255725672577258725972607261726272637264726572667267726872697270727172727273727472757276727772787279728072817282728372847285728672877288728972907291729272937294729572967297729872997300730173027303730473057306730773087309731073117312731373147315731673177318731973207321732273237324732573267327732873297330733173327333733473357336733773387339734073417342734373447345734673477348734973507351735273537354735573567357735873597360736173627363736473657366736773687369737073717372737373747375737673777378737973807381738273837384738573867387738873897390739173927393739473957396739773987399740074017402740374047405740674077408740974107411741274137414741574167417741874197420742174227423742474257426742774287429743074317432743374347435743674377438743974407441744274437444744574467447744874497450745174527453745474557456745774587459746074617462746374647465746674677468746974707471747274737474747574767477747874797480748174827483748474857486748774887489749074917492749374947495749674977498749975007501750275037504750575067507750875097510751175127513751475157516751775187519752075217522752375247525752675277528752975307531753275337534753575367537753875397540754175427543754475457546754775487549755075517552755375547555755675577558755975607561756275637564756575667567756875697570757175727573757475757576757775787579758075817582758375847585758675877588758975907591759275937594759575967597759875997600760176027603760476057606760776087609761076117612761376147615761676177618761976207621762276237624762576267627762876297630763176327633763476357636763776387639764076417642764376447645764676477648764976507651765276537654765576567657765876597660766176627663766476657666766776687669767076717672767376747675767676777678767976807681768276837684768576867687768876897690769176927693769476957696769776987699770077017702770377047705770677077708770977107711771277137714771577167717771877197720772177227723772477257726772777287729773077317732773377347735773677377738773977407741774277437744774577467747774877497750775177527753775477557756775777587759776077617762776377647765776677677768776977707771777277737774777577767777777877797780778177827783778477857786778777887789779077917792779377947795779677977798779978007801780278037804780578067807780878097810781178127813781478157816781778187819782078217822782378247825782678277828782978307831783278337834783578367837783878397840784178427843784478457846784778487849785078517852785378547855785678577858785978607861786278637864786578667867786878697870787178727873787478757876787778787879788078817882788378847885788678877888788978907891789278937894789578967897789878997900790179027903790479057906790779087909791079117912791379147915791679177918791979207921792279237924792579267927792879297930793179327933793479357936793779387939794079417942794379447945794679477948794979507951795279537954795579567957795879597960796179627963796479657966796779687969797079717972797379747975797679777978797979807981798279837984798579867987798879897990799179927993799479957996799779987999800080018002800380048005800680078008800980108011801280138014801580168017801880198020802180228023802480258026802780288029803080318032803380348035803680378038803980408041804280438044804580468047804880498050805180528053805480558056805780588059806080618062806380648065806680678068806980708071807280738074807580768077807880798080808180828083808480858086808780888089809080918092809380948095809680978098809981008101810281038104810581068107810881098110811181128113811481158116811781188119812081218122812381248125812681278128812981308131813281338134813581368137813881398140814181428143814481458146814781488149815081518152815381548155815681578158815981608161816281638164816581668167816881698170817181728173817481758176817781788179818081818182818381848185818681878188818981908191819281938194819581968197819881998200820182028203820482058206820782088209821082118212821382148215821682178218821982208221822282238224822582268227822882298230823182328233823482358236823782388239824082418242824382448245824682478248824982508251825282538254825582568257825882598260826182628263826482658266826782688269827082718272827382748275827682778278827982808281828282838284828582868287828882898290829182928293829482958296829782988299830083018302830383048305830683078308830983108311831283138314831583168317831883198320832183228323832483258326832783288329833083318332833383348335833683378338833983408341834283438344834583468347834883498350835183528353835483558356835783588359836083618362836383648365836683678368836983708371837283738374837583768377837883798380838183828383838483858386838783888389839083918392839383948395839683978398839984008401840284038404840584068407840884098410841184128413841484158416841784188419842084218422842384248425842684278428842984308431843284338434843584368437843884398440844184428443844484458446844784488449845084518452845384548455845684578458845984608461846284638464846584668467846884698470847184728473847484758476847784788479848084818482848384848485848684878488848984908491849284938494849584968497849884998500850185028503850485058506850785088509851085118512851385148515851685178518851985208521852285238524852585268527852885298530853185328533853485358536853785388539854085418542854385448545854685478548854985508551855285538554855585568557855885598560856185628563856485658566856785688569857085718572857385748575857685778578857985808581858285838584858585868587858885898590859185928593859485958596859785988599860086018602860386048605860686078608860986108611861286138614861586168617861886198620862186228623862486258626862786288629863086318632863386348635863686378638863986408641864286438644864586468647864886498650865186528653865486558656865786588659866086618662866386648665866686678668866986708671867286738674867586768677867886798680868186828683868486858686868786888689869086918692869386948695869686978698869987008701870287038704870587068707870887098710871187128713871487158716871787188719872087218722872387248725872687278728872987308731873287338734873587368737873887398740874187428743874487458746874787488749875087518752875387548755875687578758875987608761876287638764876587668767876887698770877187728773877487758776877787788779878087818782878387848785878687878788878987908791879287938794879587968797879887998800880188028803880488058806880788088809881088118812881388148815881688178818881988208821882288238824882588268827882888298830883188328833883488358836883788388839884088418842884388448845884688478848884988508851885288538854885588568857885888598860886188628863886488658866886788688869887088718872887388748875887688778878887988808881888288838884888588868887888888898890889188928893889488958896889788988899890089018902890389048905890689078908890989108911891289138914891589168917891889198920892189228923892489258926892789288929893089318932893389348935893689378938893989408941894289438944894589468947894889498950895189528953895489558956895789588959896089618962896389648965896689678968896989708971897289738974897589768977897889798980898189828983898489858986898789888989899089918992899389948995899689978998899990009001900290039004900590069007900890099010901190129013901490159016901790189019902090219022902390249025902690279028902990309031903290339034903590369037903890399040904190429043904490459046904790489049905090519052905390549055905690579058905990609061906290639064906590669067906890699070907190729073907490759076907790789079908090819082908390849085908690879088908990909091909290939094909590969097909890999100910191029103910491059106910791089109911091119112911391149115911691179118911991209121912291239124912591269127912891299130913191329133913491359136913791389139914091419142914391449145914691479148914991509151915291539154915591569157915891599160916191629163916491659166916791689169917091719172917391749175917691779178917991809181918291839184918591869187918891899190919191929193919491959196919791989199920092019202920392049205920692079208920992109211921292139214921592169217921892199220922192229223922492259226922792289229923092319232923392349235923692379238923992409241924292439244924592469247924892499250925192529253925492559256925792589259926092619262926392649265926692679268926992709271927292739274927592769277927892799280928192829283928492859286928792889289929092919292929392949295929692979298929993009301930293039304930593069307930893099310931193129313931493159316931793189319932093219322932393249325932693279328932993309331933293339334933593369337933893399340934193429343934493459346934793489349935093519352935393549355935693579358935993609361936293639364936593669367936893699370937193729373937493759376937793789379938093819382938393849385938693879388938993909391939293939394939593969397939893999400940194029403940494059406940794089409941094119412941394149415941694179418941994209421942294239424942594269427942894299430943194329433943494359436943794389439944094419442944394449445944694479448944994509451945294539454945594569457945894599460946194629463946494659466946794689469947094719472947394749475947694779478947994809481948294839484948594869487948894899490949194929493949494959496949794989499950095019502950395049505950695079508950995109511951295139514951595169517951895199520952195229523952495259526952795289529953095319532953395349535953695379538953995409541954295439544954595469547954895499550955195529553955495559556955795589559956095619562956395649565956695679568956995709571957295739574957595769577957895799580958195829583958495859586958795889589959095919592959395949595959695979598959996009601960296039604960596069607960896099610961196129613961496159616961796189619962096219622962396249625962696279628962996309631963296339634963596369637963896399640964196429643964496459646964796489649965096519652965396549655965696579658965996609661966296639664966596669667966896699670967196729673967496759676967796789679968096819682968396849685968696879688968996909691969296939694969596969697969896999700970197029703970497059706970797089709971097119712971397149715971697179718971997209721972297239724972597269727972897299730973197329733973497359736973797389739974097419742974397449745974697479748974997509751975297539754975597569757975897599760976197629763976497659766976797689769977097719772977397749775977697779778977997809781978297839784978597869787978897899790979197929793979497959796979797989799980098019802980398049805980698079808980998109811981298139814981598169817981898199820982198229823 | // abc2svg - ABC to SVG translator// @source: https://chiselapp.com/user/moinejf/repository/abc2svg// Copyright (C) 2014-2023 Jean-Francois Moine - LGPL3+//abc2svg-abc2svg.jsif(typeof abc2svg=="undefined")var abc2svg={};abc2svg.C={BLEN:1536,BAR:0,CLEF:1,CUSTOS:2,SM:3,GRACE:4,KEY:5,METER:6,MREST:7,NOTE:8,PART:9,REST:10,SPACE:11,STAVES:12,STBRK:13,TEMPO:14,BLOCK:16,REMARK:17,FULL:0,EMPTY:1,OVAL:2,OVALBARS:3,SQUARE:4,SL_ABOVE:0x01,SL_BELOW:0x02,SL_AUTO:0x03,SL_HIDDEN:0x04,SL_DOTTED:0x08,SL_ALI_MSK:0x70,SL_ALIGN:0x10,SL_CENTER:0x20,SL_CLOSE:0x40};abc2svg.sym_name=['bar','clef','custos','smark','grace','key','meter','Zrest','note','part','rest','yspace','staves','Break','tempo','','block','remark']abc2svg.keys=[new Int8Array([-1,-1,-1,-1,-1,-1,-1]),new Int8Array([-1,-1,-1,0,-1,-1,-1]),new Int8Array([0,-1,-1,0,-1,-1,-1]),new Int8Array([0,-1,-1,0,0,-1,-1]),new Int8Array([0,0,-1,0,0,-1,-1]),new Int8Array([0,0,-1,0,0,0,-1]),new Int8Array([0,0,0,0,0,0,-1]),new Int8Array([0,0,0,0,0,0,0]),new Int8Array([0,0,0,1,0,0,0]),new Int8Array([1,0,0,1,0,0,0]),new Int8Array([1,0,0,1,1,0,0]),new Int8Array([1,1,0,1,1,0,0]),new Int8Array([1,1,0,1,1,1,0]),new Int8Array([1,1,1,1,1,1,0]),new Int8Array([1,1,1,1,1,1,1])]abc2svg.p_b40=new Int8Array([2,8,14,19,25,31,37])abc2svg.b40_p=new Int8Array([0,0,0,0,0,0,1,1,1,1,1,1,2,2,2,2,2,3,3,3,3,3,3,4,4,4,4,4,4,5,5,5,5,5,5,6,6,6,6,6])abc2svg.b40_a=new Int8Array([-2,-1,0,1,2,-3,-2,-1,0,1,2,-3,-2,-1,0,1,2,-2,-1,0,1,2,-3,-2,-1,0,1,2,-3,-2,-1,0,1,2,-3,-2,-1,0,1,2])abc2svg.b40_m=new Int8Array([-2,-1,0,1,2,0,0,1,2,3,4,0,2,3,4,5,6,3,4,5,6,7,0,5,6,7,8,9,0,7,8,9,10,11,0,9,10,11,12,13])abc2svg.b40k=new Int8Array([36,1,2,3,8,2,2,7,8,13,14,2,8,13,14,19,20,13,14,19,20,25,2,19,24,25,30,31,2,25,30,31,36,37,2,31,36,37,42,43])abc2svg.b40sf=new Int8Array([-2,-7,0,7,2,88,0,-5,2,-3,4,88,2,-3,4,-1,6,-3,4,-1,6,1,88,-1,-6,1,-4,3,88,1,-4,3,-2,5,88,3,-2,5,0,7])abc2svg.isb40=new Int8Array([0,1,6,11,12,17,18,23,28,29,34,35])abc2svg.pab40=function(p,a){p+=19var b40=((p/7)|0)*40+abc2svg.p_b40[p%7]if(a&&a!=3)b40+=areturn b40}abc2svg.b40p=function(b){return((b/40)|0)*7+abc2svg.b40_p[b%40]-19}abc2svg.b40a=function(b){return abc2svg.b40_a[b%40]}abc2svg.b40m=function(b){return((b/40)|0)*12+abc2svg.b40_m[b%40]}abc2svg.ch_alias={"maj":"","min":"m","-":"m","°":"dim","+":"aug","+5":"aug","maj7":"M7","Δ7":"M7","Δ":"M7","min7":"m7","-7":"m7","ø7":"m7b5","°7":"dim7","min+7":"m+7","aug7":"+7","7+5":"+7","7#5":"+7","sus":"sus4","7sus":"7sus4"}abc2svg.font_tb=[]abc2svg.font_st={}abc2svg.ft_w={thin:100,extralight:200,light:300,regular:400,medium:500,semi:600,demi:600,semibold:600,demibold:600,bold:700,extrabold:800,ultrabold:800,black:900,heavy:900}abc2svg.ft_re=new RegExp('\-?Thin|-?Extra Light|-?Light|-?Regular|-?Medium|\-?[DS]emi|-?[DS]emi[ -]?Bold|\-?Bold|-?Extra[ -]?Bold|-?Ultra[ -]?Bold|-?Black|-?Heavy/',"i")abc2svg.rat=function(n,d){var a,t,n0=0,d1=0,n1=1,d0=1while(1){if(d==0)breakt=da=(n/d)|0d=n%dn=tt=n0+a*n1n0=n1n1=tt=d0+a*d1d0=d1d1=t}return[n1,d1]}abc2svg.pitcmp=function(n1,n2){return n1.pit-n2.pit}abc2svg.Abc=function(user){"use strict";var C=abc2svg.C;var require=empty_function,system=empty_function,write=empty_function,XMLHttpRequest=empty_function;var OPEN_BRACE=0x01,CLOSE_BRACE=0x02,OPEN_BRACKET=0x04,CLOSE_BRACKET=0x08,OPEN_PARENTH=0x10,CLOSE_PARENTH=0x20,STOP_BAR=0x40,FL_VOICE=0x80,OPEN_BRACE2=0x0100,CLOSE_BRACE2=0x0200,OPEN_BRACKET2=0x0400,CLOSE_BRACKET2=0x0800,MASTER_VOICE=0x1000,IN=96,CM=37.8,YSTEPvar errs={bad_char:"Bad character '$1'",bad_grace:"Bad character in grace note sequence",bad_transp:"Bad transpose value",bad_val:"Bad value in $1",bar_grace:"Cannot have a bar in grace notes",ignored:"$1: inside tune - ignored",misplaced:"Misplaced '$1' in %%score",must_note:"!$1! must be on a note",must_note_rest:"!$1! must be on a note or a rest",nonote_vo:"No note in voice overlay",not_ascii:"Not an ASCII character",not_enough_n:'Not enough notes/rests for %%repeat',not_enough_m:'Not enough measures for %%repeat',not_enough_p:"Not enough parameters in %%map",not_in_tune:"Cannot have '$1' inside a tune",notransp:"Cannot transpose with a temperament"}var self=this,glovar={meter:{type:C.METER,wmeasure:1,a_meter:[]},},info={},parse={ctx:{},prefix:'%',state:0,ottava:[],line:new scanBuf},tunes=[],psvgfunction clone(obj,lvl){if(!obj)return objvar tmp=new obj.constructorfor(var k in obj)if(obj.hasOwnProperty(k)){if(lvl&&typeof obj[k]=="object")tmp[k]=clone(obj[k],lvl-1)elsetmp[k]=obj[k]}return tmp}function errbld(sev,txt,fn,idx){var i,j,l,c,hif(user.errbld){switch(sev){case 0:sev="warn";breakcase 1:sev="error";breakdefault:sev="fatal";break}user.errbld(sev,txt,fn,idx)return}if(idx!=undefined&&idx>=0){i=l=0while(1){j=parse.file.indexOf('\n',i)if(j<0||j>idx)breakl++;i=j+1}c=idx-i}h=""if(fn){h=fnif(l)h+=":"+(l+1)+":"+(c+1);h+=" "}switch(sev){case 0:h+="Warning: ";breakcase 1:h+="Error: ";breakdefault:h+="Internal bug: ";break}user.errmsg(h+txt,l,c)}function error(sev,s,msg,a1,a2,a3,a4){var i,j,regex,tmpif(!sev&&cfmt.quiet)returnif(s){if(s.err)returns.err=true}if(user.textrans){tmp=user.textrans[msg]if(tmp)msg=tmp}if(arguments.length>3)msg=msg.replace(/\$./g,function(a){switch(a){case'$1':return a1case'$2':return a2case'$3':return a3default:return a4}})if(s&&s.fname)errbld(sev,msg,s.fname,s.istart)elseerrbld(sev,msg)}function scanBuf(){this.index=0;scanBuf.prototype.char=function(){return this.buffer[this.index]}scanBuf.prototype.next_char=function(){return this.buffer[++this.index]}scanBuf.prototype.get_int=function(){var val=0,c=this.buffer[this.index]while(c>='0'&&c<='9'){val=val*10+Number(c);c=this.next_char()}return val}}function syntax(sev,msg,a1,a2,a3,a4){var s={fname:parse.fname,istart:parse.istart+parse.line.index}error(sev,s,msg,a1,a2,a3,a4)}function js_inject(js){if(!/eval *\(|Function|setTimeout|setInterval/.test(js))eval('"use strict";\n'+js)elsesyntax(1,"Unsecure code")}var dd_tb={},a_de,crossvar decos={dot:"0 stc 6 1.5 1",tenuto:"0 emb 6 4 3",slide:"1 sld 3 7 1",arpeggio:"2 arp 12 10 3",roll:"3 roll 5,4 5 6",lowermordent:"3 lmrd 6,5 4 6",uppermordent:"3 umrd 6,5 4 6",trill:"3 trl 14 5 8",upbow:"3 upb 10,2 3 7",downbow:"3 dnb 9 4 6",gmark:"3 grm 7 4 6",wedge:"0 wedge 8 1.5 1",longphrase:"5 lphr 0 1 16",mediumphrase:"5 mphr 0 1 16",shortphrase:"5 sphr 0 1 16",turnx:"3 turnx 7,2.5 5 6",invertedturn:"3 turn 7,2 5 6","0":"3 fng 5,5 3 3 0","1":"3 fng 5,5 3 3 1","2":"3 fng 5,5 3 3 2","3":"3 fng 5,5 3 3 3","4":"3 fng 5,5 3 3 4","5":"3 fng 5,5 3 3 5",plus:"3 dplus 8,2 2 4","+":"3 dplus 8,2 2 4",">":"5 accent 3.5,3.5 4 4",accent:"5 accent 3.5,3.5 4 4",emphasis:"5 accent 3.5,3.5 4 4",marcato:"3 marcato 9 5 5","^":"3 marcato 9 5 5",mordent:"3 lmrd 6,5 4 6",open:"3 opend 8 3 3",snap:"3 snap 10 3 3",thumb:"3 thumb 10 3 3",turn:"3 turn 7,2.5 5 6","trill(":"5 ltr 8 0 0","trill)":"5 ltr 8 0 0","8va(":"5 8va 12 6 6","8va)":"5 8va 12 6 6","8vb(":"4 8vb 10,5 6 6","8vb)":"4 8vb 10,5 6 6","15ma(":"5 15ma 12 9 9","15ma)":"5 15ma 12 9 9","15mb(":"4 15mb 12 9 9","15mb)":"4 15mb 12 9 9",breath:"5 brth 0 1 16",caesura:"5 caes 0 1 20",short:"5 short 0 1 16",tick:"5 tick 0 1 16",coda:"5 coda 22,5 10 10",dacapo:"5 dacs 16 20 20 Da Capo",dacoda:"5 dacs 16 20 20 Da Coda","D.C.":"5 dcap 16,3 12 12","D.S.":"5 dsgn 16,3 12 12","D.C.alcoda":"5 dacs 16 38 38 D.C. al Coda","D.S.alcoda":"5 dacs 16 38 38 D.S. al Coda","D.C.alfine":"5 dacs 16 38 38 D.C. al Fine","D.S.alfine":"5 dacs 16 38 38 D.S. al Fine",fermata:"5 hld 12 7.5 7.5",fine:"5 dacs 16 14 14 Fine",invertedfermata:"7 hld 12 8 8",segno:"5 sgno 22,2 5 5",f:"6 f 12,5 3 4",ff:"6 ff 12,5 8 5",fff:"6 fff 12,5 11 9",ffff:"6 ffff 12,5 15 12",mf:"6 mf 12,5 8 10",mp:"6 mp 12,5 9 10",p:"6 p 12,5 3 6",pp:"6 pp 12,5 8 9",ppp:"6 ppp 12,5 14 11",pppp:"6 pppp 12,5 14 17",pralltriller:"3 umrd 6,5 4 6",sfz:"6 sfz 12,5 9 9",ped:"7 ped 14 6 10","ped-up":"7 pedoff 12 4 4","ped(":"7 lped 14 1 1","ped)":"7 lped 14 1 1","crescendo(":"6 cresc 15,2 0 0","crescendo)":"6 cresc 15,2 0 0","<(":"6 cresc 15,2 0 0","<)":"6 cresc 15,2 0 0","diminuendo(":"6 dim 15,2 0 0","diminuendo)":"6 dim 15,2 0 0",">(":"6 dim 15,2 0 0",">)":"6 dim 15,2 0 0","-(":"8 gliss 0 0 0","-)":"8 gliss 0 0 0","~(":"8 glisq 0 0 0","~)":"8 glisq 0 0 0",invisible:"32 0 0 0 0",beamon:"33 0 0 0 0",trem1:"34 0 0 0 0",trem2:"34 0 0 0 0",trem3:"34 0 0 0 0",trem4:"34 0 0 0 0",xstem:"35 0 0 0 0",beambr1:"36 0 0 0 0",beambr2:"36 0 0 0 0",rbstop:"37 0 0 0 0","/":"38 0 0 6 6","//":"38 0 0 6 6","///":"38 0 0 6 6","beam-accel":"39 0 0 0 0","beam-rall":"39 0 0 0 0",stemless:"40 0 0 0 0",rbend:"41 0 0 0 0",editorial:"42 0 0 0 0","sacc-1":"3 sacc-1 6,4 4 4",sacc3:"3 sacc3 6,5 4 4",sacc1:"3 sacc1 6,4 4 4",courtesy:"43 0 0 0 0","cacc-1":"3 cacc-1 0 0 0",cacc3:"3 cacc3 0 0 0",cacc1:"3 cacc1 0 0 0","tie(":"44 0 0 0 0","tie)":"44 0 0 0 0"},f_near=[d_near,d_slide,d_arp],f_note=[null,null,null,d_upstaff,d_upstaff],f_staff=[null,null,null,null,null,d_upstaff,d_upstaff,d_upstaff]function y_get(st,up,x,w){var y,p_staff=staff_tb[st],i=(x/2)|0,j=((x+w)/2)|0if(i<0)i=0if(j>=YSTEP){j=YSTEP-1if(i>j)i=j}if(up){y=p_staff.top[i++]while(i<=j){if(y<p_staff.top[i])y=p_staff.top[i];i++}}else{y=p_staff.bot[i++]while(i<=j){if(y>p_staff.bot[i])y=p_staff.bot[i];i++}}return y}function y_set(st,up,x,w,y){var p_staff=staff_tb[st],i=(x/2)|0,j=((x+w)/2)|0if(i<0)i=0if(j>=YSTEP){j=YSTEP-1if(i>j)i=j}if(up){while(i<=j){if(p_staff.top[i]<y)p_staff.top[i]=y;i++}}else{while(i<=j){if(p_staff.bot[i]>y)p_staff.bot[i]=y;i++}}}function up3(s,pos){switch(pos&0x07){case C.SL_ABOVE:return 1case C.SL_BELOW:return 0}return!s.second}function up6(s,pos){switch(pos&0x07){case C.SL_ABOVE:return truecase C.SL_BELOW:return false}if(s.multi)return s.multi>0if(!s.p_v.have_ly)return falsereturn(s.pos.voc&0x07)!=C.SL_ABOVE}function d_arp(de){var m,h,dx,s=de.s,dd=de.dd,xc=dd.wrif(s.type==C.NOTE){for(m=0;m<=s.nhd;m++){if(s.notes[m].acc){dx=s.notes[m].shac}else{dx=1-s.notes[m].shhdswitch(s.head){case C.SQUARE:dx+=3.5breakcase C.OVALBARS:case C.OVAL:dx+=2break}}if(dx>xc)xc=dx}}h=3*(s.notes[s.nhd].pit-s.notes[0].pit)+4;m=dd.hif(h<m)h=m;de.has_val=true;de.val=h;de.x-=xc;de.y=3*((s.notes[0].pit+s.notes[s.nhd].pit)/2-18)-h/2-3}function d_near(de){var y,up=de.up,s=de.s,dd=de.ddif(dd.str){return}y=up?s.ymx:s.ymnif(y>0&&y<24){y=(((y+9)/6)|0)*6-6}if(up){y+=dd.hds.ymx=y+dd.h}else if(dd.name[0]=='w'){de.inv=truey-=dd.hs.ymn=y}else{y-=dd.hs.ymn=y-dd.hd}de.x-=dd.wlde.y=yif(s.type==C.NOTE)de.x+=s.notes[s.stem>=0?0:s.nhd].shhdif(dd.name[0]=='d'){if(!(s.beam_st&&s.beam_end)){if(up){if(s.stem>0)de.x+=3.5}else{if(s.stem<0)de.x-=3.5}}else{if(up&&s.stem>0){y=s.y+(y-s.y)*.6if(y>=27){de.y=ys.ymx=de.y+dd.h}}}}}function d_slide(de){var m,dx,s=de.s,yc=s.notes[0].pit,xc=5for(m=0;m<=s.nhd;m++){if(s.notes[m].acc){dx=4+s.notes[m].shac}else{dx=5-s.notes[m].shhdswitch(s.head){case C.SQUARE:dx+=3.5breakcase C.OVALBARS:case C.OVAL:dx+=2break}}if(s.notes[m].pit<=yc+3&&dx>xc)xc=dx}de.x-=xc;de.y=3*(yc-18)}function d_trill(de){if(de.ldst)returnvar y,w,tmp,dd=de.dd,de2=de.prev,up=de.start.up,s2=de.s,st=s2.st,s=de.start.s,x=s.xfunction sh_st(){var de3,de2=de.start,s=de2.s,i=de2.ixwhile(--i>=0){de3=a_de[i]if(!de3||de3.s!=s)break}while(1){i++de3=a_de[i]if(!de3||de3.s!=s)breakif(de3==de2)continueif(!(up^de3.up)&&(de3.dd.name=="trill"||de3.dd.func==6)){x+=de3.dd.wr+2break}}}function sh_en(){var de3,i=de.ixwhile(--i>0){de3=a_de[i]if(!de3||de3.s!=s2)break}while(1){i++de3=a_de[i]if(!de3||de3.s!=s2)breakif(de3==de)continueif(!(up^de3.up)&&de3.dd.func==6){w-=de3.dd.wlbreak}}}if(de2){x=de2.s.x+de.dd.wl+2de2.val-=de2.dd.wrif(de2.val<8)de2.val=8}de.st=stde.up=upsh_st()if(de.defl.noen){w=de.x-xif(w<20){x=de.x-20-3;w=20}}else{w=s2.x-x-4sh_en(de)if(w<20)w=20}y=y_get(st,up,x-dd.wl,w)if(up){tmp=staff_tb[s.st].topbar+2if(y<tmp)y=tmp}else{tmp=staff_tb[s.st].botbar-2if(y>tmp)y=tmpy-=dd.h}if(de2){if(up){if(y<de2.y)y=de2.y}else{if(y>=de2.y){y=de2.y}else{do{de2.y=yde2=de2.prev}while(de2)}}}de.lden=false;de.has_val=true;de.val=w;de.x=x;de.y=yif(up)y+=dd.h;elsey-=dd.hdy_set(st,up,x,w,y)if(up)s.ymx=s2.ymx=yelses.ymn=s2.ymn=y}function d_upstaff(de){if(de.ldst)returnif(de.start){d_trill(de)return}var y,inv,up=de.up,s=de.s,dd=de.dd,x=de.x,w=dd.wl+dd.wrswitch(dd.glyph){case"brth":case"caes":case"lphr":case"mphr":case"sphr":case"short":case"tick":y=staff_tb[s.st].topbar+2+dd.hdif(s.type==C.BAR){s.invis=1}else{if(dd.glyph=="brth"&&y<s.ymx)y=s.ymxfor(s=s.ts_next;s;s=s.ts_next)if(s.seqst)breakx+=((s?s.x:realwidth)-x)*.45}de.x=xde.y=yreturn}if(s.nhd)x+=s.notes[s.stem>=0?0:s.nhd].shhd;switch(dd.ty){case'@':case'<':case'>':y=de.ybreak}if(y==undefined){if(up){y=y_get(s.st,true,x-dd.wl,w)+dd.hdif(de.y>y)y=de.ys.ymx=y+dd.h}else{y=y_get(s.st,false,x-dd.wl,w)-dd.hif(de.y<y)y=de.yif(dd.name=="fermata"||dd.glyph=="accent"||dd.glyph=="roll")de.inv=1s.ymn=y-dd.hd}}if(dd.wr>10&&x>realwidth-dd.wr)de.x=x=realwidth-dd.wr-dd.wlif(up)y_set(s.st,1,x-dd.wl,w,y+dd.h)elsey_set(s.st,0,x-dd.wl,w,y-dd.hd)de.y=y}function deco_add(param){var dv=param.match(/(\S*)\s+(.*)/);decos[dv[1]]=dv[2]}function deco_def(nm,nmd){if(!nmd)nmd=nmvar a,dd,dd2,nm2,c,i,elts,str,hd,text=decos[nmd]if(!text&&/\d[()]$/.test(nmd))text=decos[nmd.replace(/\d/,'')]if(!text){if(cfmt.decoerr)error(1,null,"Unknown decoration '$1'",nm)return}a=text.match(/(\d+)\s+(.+?)\s+([0-9.,]+)\s+([0-9.]+)\s+([0-9.]+)/)if(!a){error(1,null,"Invalid decoration '$1'",nm)return}var c_func=Number(a[1]),h=a[3],wl=parseFloat(a[4]),wr=parseFloat(a[5])if(isNaN(c_func)){error(1,null,"%%deco: bad C function value '$1'",a[1])return}if(c_func>10&&(c_func<32||c_func>44)){error(1,null,"%%deco: bad C function index '$1'",c_func)return}if(h.indexOf(',')>0){h=h.split(',')hd=h[1]h=h[0]}else{hd=0}if(h>50||wl>80||wr>80){error(1,null,"%%deco: abnormal h/wl/wr value '$1'",text)return}dd=dd_tb[nm]if(!dd){dd={name:nm}dd_tb[nm]=dd}dd.func=nm.indexOf("head-")==0?9:c_func;dd.glyph=a[2];dd.h=Number(h)dd.hd=Number(hd)dd.wl=wl;dd.wr=wr;str=text.replace(a[0],'').trim()if(str){if(str[0]=='"')str=str.slice(1,-1);if(str[0]=='@'&&!str.match(/^@([0-9.-]+),([0-9.-]+);?/)){error(1,null,"%%deco: bad position '$1'",str)return}dd.str=str}if(dd.func==6&&dd.str==undefined)dd.str=nmc=nm.slice(-1)if(c=='('||(c==')'&&nm.indexOf('(')<0)){dd.str=null;nm2=nm.slice(0,-1)+(c=='('?')':'(');dd2=dd_tb[nm2]if(dd2){if(c=='('){dd.dd_en=dd2;dd2.dd_st=dd}else{dd.dd_st=dd2;dd2.dd_en=dd}}}return dd}function do_ctie(nm,s,nt1){var nt2=cross[nm],nm2=nm.slice(0,-1)+(nm.slice(-1)=='('?')':'(')if(nt2){error(1,s,"Conflict on !$1!",nm)return}nt1.s=snt2=cross[nm2]if(!nt2){cross[nm]=nt1return}if(nm.slice(-1)==')'){nt2=nt1nt1=cross[nm2]}cross[nm2]=nullif(nt1.midi!=nt2.midi||nt1.s.time+nt1.s.dur!=nt2.s.time){error(1,s,"Bad tie")}else{nt1.tie_ty=C.SL_AUTOnt1.tie_e=nt2nt2.tie_s=nt1nt1.s.ti1=nt2.s.ti2=true}}function get_dd(nm){var ty,p,dd=dd_tb[nm]if(dd)return ddif("<>^_@".indexOf(nm[0])>=0&&!/^([>^]|[<>]\d?[()])$/.test(nm)){ty=nm[0]if(ty=='@'){p=nm.match(/@([-\d]+),([-\d]+)/)if(p)ty=p[0]elsety=''}dd=deco_def(nm,nm.replace(ty,''))}else{dd=deco_def(nm)}if(!dd)returnif(ty){if(ty[0]=='@'){dd.x=Number(p[1])dd.y=Number(p[2])ty='@'}dd.ty=ty}return dd}function deco_cnv(s,prev){var i,j,dd,nm,note,s1,courtwhile(1){nm=a_dcn.shift()if(!nm)breakdd=get_dd(nm)if(!dd)continueswitch(dd.func){case 0:if(s.type==C.BAR&&nm=="dot"){s.bar_dotted=truecontinue}case 1:case 2:if(!s.notes){error(1,s,errs.must_note_rest,nm)continue}breakcase 4:case 5:i=nm.match(/1?[85]([vm])([ab])([()])/)if(i){j=i[1]=='v'?1:2if(i[2]=='b')j=-jif(!s.ottava)s.ottava=[]s.ottava[i[3]=='('?0:1]=jglovar.ottava=1}breakcase 8:if(s.type!=C.NOTE){error(1,s,errs.must_note,nm)continue}note=s.notes[s.nhd]if(!note.a_dd)note.a_dd=[]note.a_dd.push(dd)continuecase 9:if(!s.notes){error(1,s,errs.must_note_rest,nm)continue}for(j=0;j<=s.nhd;j++){note=s.notes[j]note.invis=trueif(!note.a_dd)note.a_dd=[]note.a_dd.push(dd)}continuecase 10:if(s.notes){for(j=0;j<=s.nhd;j++)s.notes[j].color=nm}else{s.color=nm}breakcase 32:s.invis=truebreakcase 33:if(s.type!=C.BAR){error(1,s,"!beamon! must be on a bar")continue}s.beam_on=truebreakcase 34:if(s.type!=C.NOTE||!prev||prev.type!=C.NOTE||s.dur!=prev.dur){error(1,s,"!$1! must be on the last of a couple of notes",nm)continue}s.trem2=true;s.beam_end=true;s.beam_st=false;prev.beam_st=true;prev.beam_end=false;s.ntrem=prev.ntrem=Number(nm[4]);for(j=0;j<=s.nhd;j++)s.notes[j].dur*=2;for(j=0;j<=prev.nhd;j++)prev.notes[j].dur*=2breakcase 35:if(s.type!=C.NOTE){error(1,s,errs.must_note,nm)continue}s.xstem=true;breakcase 36:if(s.type!=C.NOTE){error(1,s,errs.must_note,nm)continue}if(nm[6]=='1')s.beam_br1=trueelses.beam_br2=truebreakcase 37:s.rbstop=1breakcase 38:if(s.type!=C.NOTE){error(1,s,errs.must_note,nm)continue}s.trem1=true;s.ntrem=nm.lengthbreakcase 39:if(s.type!=C.NOTE){error(1,s,errs.must_note,nm)continue}s.feathered_beam=nm[5]=='a'?1:-1;breakcase 40:s.stemless=truebreakcase 41:s.rbstop=2breakcase 42:if(!s.notes[0].acc)continuenm="sacc"+s.notes[0].acc.toString()dd=dd_tb[nm]if(!dd){dd=deco_def(nm)if(!dd){error(1,s,errs.bad_val,"!editorial!")continue}}delete s.notes[0].acccurvoice.acc[s.notes[0].pit+19]=0breakcase 43:j=curvoice.acc[s.notes[0].pit+19]if(s.notes[0].acc||!j)continuecourt=1breakcase 44:do_ctie(nm,s,s.notes[0])continue}if(!s.a_dd)s.a_dd=[]s.a_dd.push(dd)}if(court){a_dcn.push("cacc"+j)dh_cnv(s,s.notes[0])}}function dh_cnv(s,nt){var k,nm,ddwhile(1){nm=a_dcn.shift()if(!nm)breakdd=get_dd(nm)if(!dd)continueswitch(dd.func){case 0:case 1:case 3:case 4:case 8:breakdefault:error(1,s,"Cannot have !$1! on a head",nm)continuecase 9:nt.invis=truebreakcase 32:nt.invis=truecontinuecase 10:nt.color=nmcontinuecase 40:s.stemless=truecontinuecase 44:do_ctie(nm,s,nt)continue}if(!nt.a_dd)nt.a_dd=[]nt.a_dd.push(dd)}}function deco_update(s,dx){var i,de,nd=a_de.lengthfor(i=0;i<nd;i++){de=a_de[i]if(de.s==s)de.x+=dx}}function deco_width(s,wlnt){var dd,i,w,wl=wlnt,wr=s.wr,a_dd=s.a_dd,nd=a_dd.lengthfor(i=0;i<nd;i++){dd=a_dd[i]switch(dd.func){case 1:case 2:if(wl<12)wl=12breakcase 3:switch(dd.glyph){case"brth":case"lphr":case"mphr":case"sphr":if(s.wr<20)s.wr=20breakdefault:w=dd.wl+2if(wl<w)wl=wbreak}default:switch(dd.ty){case'<':w=wlnt+dd.wl+dd.wr+6if(wl<w)wl=wbreakcase'>':w=wr+dd.wl+dd.wr+6if(s.wr<w)s.wr=wbreak}break}}return wl}function deco_wch(nt){var i,w,dd,wl=0,n=nt.a_dd.lengthfor(i=0;i<n;i++){dd=nt.a_dd[i]if(dd.ty=='<'){w=dd.wl+dd.wr+4if(w>wl)wl=w}}return wl}Abc.prototype.draw_all_deco=function(){if(!a_de.length)returnvar de,dd,s,note,f,st,x,y,y2,ym,uf,i,str,a,new_de=[],ymid=[]st=nstaff;y=staff_tb[st].ywhile(--st>=0){y2=staff_tb[st].y;ymid[st]=(y+24+y2)*.5;y=y2}while(1){de=a_de.shift()if(!de)breakdd=de.ddif(!dd)continueif(dd.dd_en)continues=de.sf=dd.glyph;i=f.indexOf('/')if(i>0){if(s.stem>=0)f=f.slice(0,i)elsef=f.slice(i+1)}if(f_staff[dd.func])set_sscale(s.st)elseset_scale(s);st=de.st;if(!staff_tb[st].topbar)continuex=de.x;y=de.y+staff_tb[st].yif(de.m!=undefined){note=s.notes[de.m];if(note.shhd)x+=note.shhd*stv_g.scale}else if(dd.func==6&&((de.pos&C.SL_ALI_MSK)==C.SL_CENTER||((de.pos&C.SL_ALI_MSK)==0&&!s.fmt.dynalign))&&((de.up&&st>0)||(!de.up&&st<nstaff))){if(de.up)ym=ymid[--st]elseym=ymid[st++];ym-=dd.h*.5if((de.up&&y<ym)||(!de.up&&y>ym)){y2=y_get(st,!de.up,de.x,de.val)+staff_tb[st].yif(de.up)y2-=dd.hif((de.up&&y2>ym)||(!de.up&&y2<ym)){y=ym;if(stv_g.scale!=1)y+=stv_g.dy/2}}}uf=user[f]if(uf&&typeof(uf)=="function"){uf(x,y,de)continue}if(self.psdeco(f,x,y,de))continueanno_start(s,'deco')if(de.inv){y=y+dd.h-dd.hdg_open(x,y,0,1,-1);x=y=0}if(de.has_val){if(dd.func!=2||stv_g.st<0)out_deco_val(x,y,f,de.val/stv_g.scale,de.defl)elseout_deco_val(x,y,f,de.val,de.defl)if(de.cont)new_de.push(de.start)}else if(dd.str!=undefined){str=dd.strif(str[0]=='@'){a=str.match(/^@([0-9.-]+),([0-9.-]+);?/);x+=Number(a[1]);y+=Number(a[2]);str=str.replace(a[0],"")}out_deco_str(x,y,f,str)}else if(de.lden){out_deco_long(x,y,de)}else{xygl(x,y,f)}if(stv_g.g)g_close();anno_stop(s,'deco')}a_de=new_de}function draw_deco_near(){var s,gfunction ldeco_update(s){var i,de,x=s.x-s.wl,nd=a_de.lengthfor(i=0;i<nd;i++){de=a_de[i];de.ix=i;de.s.x=de.x=x;de.defl.nost=true}}function create_deco(s){var dd,k,pos,de,x,y,up,nd=s.a_dd.lengthif(s.y==undefined)s.y=0for(k=0;k<nd;k++){dd=s.a_dd[k]x=s.xy=s.yswitch(dd.func){default:if(dd.func>=10)continuepos=0breakcase 3:case 4:case 5:pos=s.pos.ornbreakcase 6:pos=s.pos.dynbreak}switch(dd.ty){case'^':pos=(pos&~0x07)|C.SL_ABOVEbreakcase'_':pos=(pos&~0x07)|C.SL_BELOWbreakcase'<':case'>':pos=(pos&0x07)|C.SL_CLOSEif(dd.ty=='<'){x-=dd.wr+8if(s.notes[0].acc)x-=8}else{x+=dd.wl+8}y=3*(s.notes[0].pit-18)-(dd.h-dd.hd)/2breakcase'@':x+=dd.xy+=dd.ybreak}if((pos&0x07)==C.SL_HIDDEN)continuede={s:s,dd:dd,st:s.st,ix:a_de.length,defl:{},x:x,y:y}if(pos)de.pos=posup=0if(dd.ty=='^'){up=1}else if(dd.ty=='_'){}else{switch(dd.func){case 0:if(s.multi)up=s.multi>0elseup=s.stem<0breakcase 3:case 5:up=up3(s,pos)breakcase 6:case 7:up=up6(s,pos)break}}de.up=upif(dd.name.indexOf("inverted")>=0)de.inv=1if(s.type==C.BAR&&!dd.ty)de.x-=s.wl/2-2a_de.push(de)if(dd.dd_en){de.ldst=true}else if(dd.dd_st){de.lden=true;de.defl.nost=true}if(f_near[dd.func])f_near[dd.func](de)}}function create_dh(s,m){var de,k,dd,note=s.notes[m],nd=note.a_dd.length,x=s.xfor(k=0;k<nd;k++){dd=note.a_dd[k]de={s:s,dd:dd,st:s.st,m:m,ix:0,defl:{},x:x,y:3*(note.pit-18)-(dd.h-dd.hd)/2}if(dd.ty){if(dd.ty=='@'){de.x+=dd.xde.y+=dd.y}else{de.y-=(dd.h-dd.hd)/2if(dd.ty=='<'){de.x-=dd.wr+8if(s.notes[m].acc)x-=8}else if(dd.ty=='>'){de.x+=dd.wl+8}}}a_de.push(de)if(dd.dd_en){de.ldst=true}else if(dd.dd_st){de.lden=true;de.defl.nost=true}}}function create_all(s){if(s.invis&&s.play)returnif(s.a_dd)create_deco(s)if(s.notes){for(var m=0;m<s.notes.length;m++){if(s.notes[m].a_dd)create_dh(s,m)}}}function ll_deco(){var i,j,de,de2,de3,dd,dd2,v,s,st,n_de=a_de.lengthfor(i=0;i<n_de;i++){de=a_de[i]if(!de.ldst)continuedd=de.dd;dd2=dd.dd_en;s=de.s;v=s.vfor(j=i+1;j<n_de;j++){de2=a_de[j]if(!de2.start&&de2.dd==dd2&&de2.s.v==v)break}if(j==n_de){st=s.st;for(j=i+1;j<n_de;j++){de2=a_de[j]if(!de2.start&&de2.dd==dd2&&de2.s.st==st)break}}if(j==n_de){de2={s:s,st:de.st,dd:dd2,ix:a_de.length-1,x:realwidth-6,y:s.y,cont:true,lden:true,defl:{noen:true}}if(de2.x<s.x+10)de2.x=s.x+10if(de.m!=undefined)de2.m=de.m;a_de.push(de2)}de2.start=de;de2.defl.nost=de.defl.nostj=iwhile(--j>=0){de3=a_de[j]if(!de3.start)continueif(de3.s.time<s.time)breakif(de3.dd.name==de2.dd.name){de2.prev=de3break}}}for(i=0;i<n_de;i++){de2=a_de[i]if(!de2.lden||de2.start)continues=de2.s;de={s:prev_scut(s),st:de2.st,dd:de2.dd.dd_st,ix:a_de.length-1,y:s.y,ldst:true}de.x=de.s.x+de.s.wrif(de2.m!=undefined)de.m=de2.m;a_de.push(de);de2.start=de}}for(s=tsfirst;s;s=s.ts_next){switch(s.type){case C.CLEF:case C.KEY:case C.METER:continue}break}if(a_de.length)ldeco_update(s)for(;s;s=s.ts_next){switch(s.type){case C.BAR:case C.MREST:case C.NOTE:case C.REST:case C.SPACE:breakcase C.GRACE:for(g=s.extra;g;g=g.next)create_all(g)breakdefault:continue}create_all(s)}ll_deco()}function draw_deco_note(){var i,de,dd,f,nd=a_de.lengthfor(i=0;i<nd;i++){de=a_de[i];dd=de.dd;f=dd.funcif(f_note[f]&&de.m==undefined)f_note[f](de)}}function draw_deco_staff(){var s,p_voice,y,i,v,de,dd,w,minmax=new Array(nstaff+1),nd=a_de.lengthfunction draw_repbra(p_voice){var s,s1,x,y,y2,i,p,w,wh,first_repeat;y=staff_tb[p_voice.st].topbar+15for(s=p_voice.sym;s;s=s.next){if(s.type!=C.BAR)continueif(!s.rbstart||s.norepbra)continueif(!s.next)breakif(!first_repeat){first_repeat=s;set_font("repeat")}s1=sfor(;;){if(!s.next)breaks=s.nextif(s.rbstop)break}x=s1.xif(s1.xsh)x+=s1.xshy2=y_get(p_voice.st,true,x,s.x-x)+2if(y<y2)y=y2if(s1.rbstart==2){y2=y_get(p_voice.st,true,x,3)+10if(y<y2)y=y2}if(s.rbstop==2){y2=y_get(p_voice.st,true,s.x-3,3)+10if(y<y2)y=y2}if(s1.text){wh=strwh(s1.text);y2=y_get(p_voice.st,true,x+4,wh[0])+wh[1]if(y<y2)y=y2}if(s.rbstart)s=s.prev}s=first_repeatif(!s)returnset_dscale(p_voice.st,true);y2=y*staff_tb[p_voice.st].staffscalefor(;s;s=s.next){if(!s.rbstart||s.norepbra)continues1=swhile(1){if(!s.next)breaks=s.nextif(s.rbstop)break}if(s1==s)breakx=s1.xif(s1.xsh)x+=s1.xshif(cfmt.measurenb>0&s.bar_num&&s.bar_num%cfmt.measurenb)x+=6if(s.type!=C.BAR){w=s.rbstop?0:s.x-realwidth+4}else if((s.bar_type.length>1&&s.bar_type!="[]")||s.bar_type=="]"){if(s1.st>0&&!(cur_sy.staves[s1.st-1].flags&STOP_BAR))w=s.wlelse if(s.bar_type.slice(-1)==':')w=12else if(s.bar_type[0]!=':')w=0elsew=8}else{w=(s.rbstop&&!s.rbstart)?0:8}w=(s.x-x-w)if(!s.next&&!s.rbstop&&!p_voice.bar_start){p_voice.bar_start=_bar(s)p_voice.bar_start.bar_type=""p_voice.bar_start.rbstart=1}if(s1.text)xy_str(x+4,y2-gene.curfont.size,s1.text);xypath(x,y2);if(s1.rbstart==2)output+='m0 10v-10';output+='h'+w.toFixed(1)if(s.rbstop==2)output+='v10';output+='"/>\n';y_set(s1.st,true,x,w,y+2)if(s.rbstart)s=s.prev}}for(i=0;i<=nstaff;i++)minmax[i]={ymin:0,ymax:0}for(i=0;i<nd;i++){de=a_de[i];dd=de.ddif(!dd)continueif(!f_staff[dd.func]||de.m!=undefined||dd.ty=='<'||dd.ty=='>'||dd.ty=='@')continuef_staff[dd.func](de)if(dd.func!=6||dd.dd_en)continueif((de.pos&C.SL_ALI_MSK)==C.SL_ALIGN||((de.pos&C.SL_ALI_MSK)==0&&de.s.fmt.dynalign>0)){if(de.up){if(de.y>minmax[de.st].ymax)minmax[de.st].ymax=de.y}else{if(de.y<minmax[de.st].ymin)minmax[de.st].ymin=de.y}}}for(i=0;i<nd;i++){de=a_de[i];dd=de.ddif(!dd)continueif(dd.ty=='@'){var y2y=de.yif(y>0){y2=y+dd.h+2if(y2>staff_tb[de.st].ann_top)staff_tb[de.st].ann_top=y2}else{y2=y-dd.hd-2if(y2<staff_tb[de.st].ann_bot)staff_tb[de.st].ann_bot=y2}continue}if(dd.func!=6||dd.ty=='<'||dd.ty=='>'||dd.dd_en)continuew=de.val||(dd.wl+dd.wr)if((de.pos&C.SL_ALI_MSK)==C.SL_ALIGN||((de.pos&C.SL_ALI_MSK)==0&&de.s.fmt.dynalign>0)){if(de.up)y=minmax[de.st].ymaxelsey=minmax[de.st].ymin;de.y=y}else{y=de.y}if(de.up)y+=dd.h;elsey-=dd.hdy_set(de.st,de.up,de.x,w,y)}for(i=0;i<nd;i++){de=a_de[i]dd=de.ddif(!dd)continueif(dd.dd_en||dd.name.slice(0,3)!="ped")continuew=de.val||10de.y=y_get(de.st,0,de.x,w)-(dd.dd_st&&cfmt.pedline?10:dd.h)y_set(de.st,0,de.x,w,de.y)}draw_all_chsy()for(v=0;v<voice_tb.length;v++){p_voice=voice_tb[v]if(p_voice.second||!p_voice.sym||p_voice.ignore)continuedraw_repbra(p_voice)}}function draw_measnb(){var s,st,bar_num,x,y,w,any_nb,font_size,w0,sy=cur_syfor(st=0;st<=nstaff;st++){if(sy.st_print[st])break}if(st>nstaff)returnset_dscale(st)if(staff_tb[st].staffscale!=1){font_size=get_font("measure").size;param_set_font("measurefont","* "+(font_size/staff_tb[st].staffscale).toString())}set_font("measure");w0=cwidf('0');s=tsfirst;bar_num=gene.nbarif(bar_num>1){if(cfmt.measurenb==0){any_nb=true;y=y_get(st,true,0,20)if(y<staff_tb[st].topbar+14)y=staff_tb[st].topbar+14;xy_str(0,y-gene.curfont.size*.2,bar_num.toString())y_set(st,true,0,20,y+gene.curfont.size+2)}else if(bar_num%cfmt.measurenb==0){for(;;s=s.ts_next){switch(s.type){case C.CLEF:case C.KEY:case C.METER:case C.STBRK:continue}break}if(s.type!=C.BAR||!s.bar_num){any_nb=true;w=w0if(bar_num>=10)w*=bar_num>=100?3:2if(gene.curfont.pad)w+=gene.curfont.pad*2x=(s.prev?s.prev.x+s.prev.wr/2:s.x-s.wl)-wy=y_get(st,true,x,w)+5if(y<staff_tb[st].topbar+6)y=staff_tb[st].topbar+6;y+=gene.curfont.padxy_str(x,y-gene.curfont.size*.2,bar_num.toString())y+=gene.curfont.size+gene.curfont.pady_set(st,true,x,w,y)}}}for(;s;s=s.ts_next){switch(s.type){case C.STAVES:sy=s.syfor(st=0;st<nstaff;st++){if(sy.st_print[st])break}set_dscale(st)continuedefault:continuecase C.BAR:if(!s.bar_num||s.bar_num<=1)continuebreak}bar_num=s.bar_numif(cfmt.measurenb==0||(bar_num%cfmt.measurenb)!=0||!s.next||s.bar_mrep)continueif(!any_nb)any_nb=true;w=w0if(bar_num>=10)w*=bar_num>=100?3:2if(gene.curfont.pad)w+=gene.curfont.pad*2x=s.xy=y_get(st,true,x,w)if(y<staff_tb[st].topbar+6)y=staff_tb[st].topbar+6if(s.next.type==C.NOTE){if(s.next.stem>0){if(y<s.next.ys-gene.curfont.size)y=s.next.ys-gene.curfont.size}else{if(y<s.next.y)y=s.next.y}}y+=2+gene.curfont.padxy_str(x,y-gene.curfont.size*.2,bar_num.toString())y+=gene.curfont.size+gene.curfont.pady_set(st,true,x,w,y)}gene.nbar=bar_numif(font_size)param_set_font("measurefont","* "+font_size.toString())}function draw_partempo(){var s,s2,some_part,some_tempo,h,w,y,st,sy=cur_syfor(st=0;st<=nstaff;st++){if(sy.st_print[st])break}if(st>nstaff)returnset_dscale(st,1)var ymin=staff_tb[st].topbar+2,dosh=0,shift=1,x=-100,yn=0for(s=tsfirst;s;s=s.ts_next){s2=s.partif(!s2||s2.invis)continueif(!some_part){some_part=s;set_font("parts");h=gene.curfont.size+2+gene.curfont.pad*2}if(s2.x==undefined)s2.x=s.x-10w=strwh(s2.text)[0]y=y_get(st,true,s2.x,w+3)if(ymin<y)ymin=y}if(some_part){set_sscale(-1)ymin*=staff_tb[st].staffscalefor(s=some_part;s;s=s.ts_next){s2=s.partif(!s2||s2.invis)continuew=strwh(s2.text)[0]if(user.anno_start||user.anno_stop){s2.wl=0s2.wr=ws2.ymn=ymins2.ymx=s2.ymn+hanno_start(s2)}xy_str(s2.x,ymin+2+gene.curfont.pad+gene.curfont.size*.22,s2.text)y_set(st,1,s2.x,w+3,ymin+2+h)if(s2.x<0)yn=ymin+2+hanno_stop(s2)}}ymin=staff_tb[st].topbar+6for(s=tsfirst;s;s=s.ts_next){if(s.type!=C.TEMPO||s.invis)continueif(!some_tempo)some_tempo=sw=s.tempo_wh[0]y=y_get(st,true,s.x-16,w)if(s.x-16<0)y=ynif(y>ymin)ymin=yif(x>=s.x-16&&!(dosh&(shift>>1)))dosh|=shiftshift<<=1x=s.x-16+w}if(some_tempo){set_sscale(-1)set_font("tempo")h=gene.curfont.sizeymin+=2ymin*=staff_tb[st].staffscalefor(s=some_tempo;s;s=s.ts_next){if(s.type!=C.TEMPO||s.invis)continuew=s.tempo_wh[0]y=yminif(dosh&1)y+=hif(user.anno_start||user.anno_stop){s.wl=16s.wr=w-16s.ymn=ys.ymx=s.ymn+14anno_start(s)}writempo(s,s.x-16,y)anno_stop(s)y_set(st,1,s.x-16,w,y+h+2)dosh>>=1}}}var STEM_MIN=16,STEM_MIN2=14,STEM_MIN3=12,STEM_MIN4=10,STEM_CH_MIN=14,STEM_CH_MIN2=10,STEM_CH_MIN3=9,STEM_CH_MIN4=9,BEAM_DEPTH=3.2,BEAM_OFFSET=.25,BEAM_SHIFT=5,BEAM_STUB=7,SLUR_SLOPE=.5,GSTEM=15,GSTEM_XOFF=2.3var cache,anno_a=[]function b_pos(grace,stem,nflags,b){var top,bot,d1,d2,shift=!grace?BEAM_SHIFT:3.5,depth=!grace?BEAM_DEPTH:1.8function rnd6(y){var iy=Math.round((y+12)/6)*6-12return iy-y}if(stem>0){bot=b-(nflags-1)*shift-depthif(bot>26)return 0top=b}else{top=b+(nflags-1)*shift+depthif(top<-2)return 0bot=b}d1=rnd6(top-BEAM_OFFSET);d2=rnd6(bot+BEAM_OFFSET)return d1*d1>d2*d2?d2:d1}function sym_dup(s){var m,notes=clone(s)s.invis=truedelete s.extra;delete s.textdelete s.a_gchdelete s.a_lydelete s.a_dd;delete s.tps.notes=clone(s.notes)for(m=0;m<=s.nhd;m++){note=s.notes[m]=clone(s.notes[m])delete note.a_dd}return s}var min_tb=[[STEM_MIN,STEM_MIN,STEM_MIN2,STEM_MIN3,STEM_MIN4,STEM_MIN4],[STEM_CH_MIN,STEM_CH_MIN,STEM_CH_MIN2,STEM_CH_MIN3,STEM_CH_MIN4,STEM_CH_MIN4]]Abc.prototype.calculate_beam=function(bm,s1){var s,s2,g,notes,nflags,st,v,two_staves,two_dir,x,y,ys,a,b,stem_err,max_stem_err,p_min,p_max,s_closest,stem_xoff,scale,visible,dyif(!s1.beam_st){s=sym_dup(s1);lkvsym(s,s1);lktsym(s,s1);s.x-=12if(s.x>s1.prev.x+12)s.x=s1.prev.x+12;s.beam_st=truedelete s.beam_end;s.tmp=truedelete s.sls;s1=s}notes=nflags=0;two_staves=two_dir=false;st=s1.st;v=s1.v;stem_xoff=s1.grace?GSTEM_XOFF:3.5for(s2=s1;;s2=s2.next){if(s2.type==C.NOTE){if(s2.nflags>nflags)nflags=s2.nflags;notes++if(s2.st!=st)two_staves=trueif(s2.stem!=s1.stem)two_dir=trueif(!visible&&!s2.invis&&(!s2.stemless||s2.trem2))visible=trueif(s2.beam_end)break}if(!s2.next){for(;;s2=s2.prev){if(s2.type==C.NOTE)break}s=sym_dup(s2);s.next=s2.nextif(s.next)s.next.prev=s;s2.next=s;s.prev=s2;s.ts_next=s2.ts_nextif(s.ts_next)s.ts_next.ts_prev=s;s2.ts_next=s;s.ts_prev=s2delete s.beam_st;s.beam_end=true;s.tmp=truedelete s.sls;s.x+=12if(s.x<realwidth-12)s.x=realwidth-12;s2=s;notes++break}}if(!visible)return false;bm.s2=s2if(staff_tb[st].y==0){if(two_staves)return false}else{if(!two_staves){bm.s1=s1;bm.a=(s1.ys-s2.ys)/(s1.xs-s2.xs);bm.b=s1.ys-s1.xs*bm.a+staff_tb[st].y;bm.nflags=nflagsreturn true}}s_closest=s1;p_min=100;p_max=0for(s=s1;;s=s.next){if(s.type!=C.NOTE)continueif((scale=s.p_v.scale)==1)scale=staff_tb[s.st].staffscaleif(s.stem>=0){x=stem_xoff+s.notes[0].shhdif(s.notes[s.nhd].pit>p_max){p_max=s.notes[s.nhd].pit;s_closest=s}}else{x=-stem_xoff+s.notes[s.nhd].shhdif(s.notes[0].pit<p_min){p_min=s.notes[0].pit;s_closest=s}}s.xs=s.x+x*scale;if(s==s2)break}if(s.grace&&s1.fmt.flatbeams)a=0else if(!two_dir&¬es>=3&&s_closest!=s1&&s_closest!=s2)a=0y=s1.ys+staff_tb[st].yif(a==undefined)a=(s2.ys+staff_tb[s2.st].y-y)/(s2.xs-s1.xs)if(a!=0){a=s1.fmt.beamslope*a/(s1.fmt.beamslope+Math.abs(a))if(a>-.04&&a<.04)a=0}b=(y+s2.ys+staff_tb[s2.st].y)/2-a*(s2.xs+s1.xs)/2max_stem_err=0;s=s1if(two_dir){ys=((s1.grace?3.5:BEAM_SHIFT)*(nflags-1)+BEAM_DEPTH)*.5if(s1.nflags==s2.nflags);else if(s1.stem!=s2.stem&&s1.nflags<s2.nflags)b+=ys*s2.stemelseb+=ys*s1.stem}else if(!s1.grace){var beam_h=BEAM_DEPTH+BEAM_SHIFT*(nflags-1)while(s.ts_prev&&s.ts_prev.type==C.NOTE&&s.ts_prev.time==s.time&&s.ts_prev.x>s1.xs)s=s.ts_prevfor(;s&&s.time<=s2.time;s=s.ts_next){if(s.type!=C.NOTE||s.invis||(s.st!=st&&s.v!=v)){continue}x=s.v==v?s.xs:s.x;ys=a*x+b-staff_tb[s.st].yif(s.v==v){stem_err=min_tb[s.nhd==0?0:1][s.nflags]if(s.stem>0){if(s.notes[s.nhd].pit>26){stem_err-=2if(s.notes[s.nhd].pit>28)stem_err-=2}stem_err-=ys-3*(s.notes[s.nhd].pit-18)}else{if(s.notes[0].pit<18){stem_err-=2if(s.notes[0].pit<16)stem_err-=2}stem_err-=3*(s.notes[0].pit-18)-ys}stem_err+=BEAM_DEPTH+BEAM_SHIFT*(s.nflags-1)}else{if(s1.stem>0){if(s.stem>0){if(s.ymn>ys+4||s.ymx<ys-beam_h-2)continueif(s.v>v)stem_err=s.ymx-yselsestem_err=s.ymn+8-ys}else{stem_err=s.ymx-ys}}else{if(s.stem<0){if(s.ymx<ys-4||s.ymn>ys-beam_h-2)continueif(s.v<v)stem_err=ys-s.ymnelsestem_err=ys-s.ymx+8}else{stem_err=ys-s.ymn}}stem_err+=2+beam_h}if(stem_err>max_stem_err)max_stem_err=stem_err}}else{for(;;s=s.next){ys=a*s.xs+b-staff_tb[s.st].y;stem_err=GSTEM-2if(s.stem>0)stem_err-=ys-(3*(s.notes[s.nhd].pit-18))elsestem_err+=ys-(3*(s.notes[0].pit-18));stem_err+=3*(s.nflags-1)if(stem_err>max_stem_err)max_stem_err=stem_errif(s==s2)break}}if(max_stem_err>0)b+=s1.stem*max_stem_errif(!two_staves&&!two_dir)for(s=s1.next;;s=s.next){switch(s.type){case C.REST:if(!s.multi)breakg=s.ts_nextif(!g||g.st!=st||(g.type!=C.NOTE&&g.type!=C.REST))breakcase C.BAR:if(s.invis)breakcase C.CLEF:y=a*s.x+bif(s1.stem>0){y=s.ymx-y+BEAM_DEPTH+BEAM_SHIFT*(nflags-1)+2if(y>0)b+=y}else{y=s.ymn-y-BEAM_DEPTH-BEAM_SHIFT*(nflags-1)-2if(y<0)b+=y}breakcase C.GRACE:for(g=s.extra;g;g=g.next){y=a*g.x+bif(s1.stem>0){y=g.ymx-y+BEAM_DEPTH+BEAM_SHIFT*(nflags-1)+2if(y>0)b+=y}else{y=g.ymn-y-BEAM_DEPTH-BEAM_SHIFT*(nflags-1)-2if(y<0)b+=y}}break}if(s==s2)break}if(a==0)b+=b_pos(s1.grace,s1.stem,nflags,b-staff_tb[st].y)for(s=s1;;s=s.next){switch(s.type){case C.NOTE:s.ys=a*s.xs+b-staff_tb[s.st].yif(s.stem>0){s.ymx=s.ys+2.5if(s.ts_prev&&s.ts_prev.stem>0&&s.ts_prev.st==s.st&&s.ts_prev.ymn<s.ymx&&s.ts_prev.x==s.x&&s.notes[0].shhd==0){s.ts_prev.x-=3;s.ts_prev.xs-=3}}else{s.ymn=s.ys-2.5}breakcase C.REST:y=a*s.x+b-staff_tb[s.st].ydy=BEAM_DEPTH+BEAM_SHIFT*(nflags-1)+(s.head!=C.FULL?4:9)if(s1.stem>0){y-=dyif(s1.multi==0&&y>12)y=12if(s.y<=y)break}else{y+=dyif(s1.multi==0&&y<12)y=12if(s.y>=y)break}if(s.head!=C.FULL)y=(((y+3+12)/6)|0)*6-12;s.y=ybreak}if(s==s2)break}if(staff_tb[st].y==0)return falsebm.s1=s1;bm.a=a;bm.b=b;bm.nflags=nflagsreturn true}function draw_beams(bm){var s,i,beam_dir,shift,bshift,bstub,bh,da,bd,k,k1,k2,x1,s1=bm.s1,s2=bm.s2function draw_beam(x1,x2,dy,h,bm,n){var y1,dy2,s=bm.s1,nflags=s.nflagsif(s.ntrem)nflags-=s.ntremif(s.trem2&&n>nflags){if(s.dur>=C.BLEN/2){x1=s.x+6;x2=bm.s2.x-6}else if(s.dur<C.BLEN/4){var dx=x2-x1if(dx<16){x1+=dx/4x2-=dx/4}else{x1+=5x2-=6}}}y1=bm.a*x1+bm.b-dy;x2-=x1;x2/=stv_g.scale;dy2=bm.a*x2*stv_g.scalexypath(x1,y1,true);output+='l'+x2.toFixed(1)+' '+(-dy2).toFixed(1)+'v'+h.toFixed(1)+'l'+(-x2).toFixed(1)+' '+dy2.toFixed(1)+'z"/>\n'}anno_start(s1,'beam')if(!s1.grace){bshift=BEAM_SHIFT;bstub=BEAM_STUB;shift=.34;bh=BEAM_DEPTH}else{bshift=3.5;bstub=3.2;shift=.29;bh=1.8}bh/=stv_g.scalebeam_dir=s1.stemif(s1.stem!=s2.stem&&s1.nflags<s2.nflags)beam_dir=s2.stemif(beam_dir<0)bh=-bh;draw_beam(s1.xs-shift,s2.xs+shift,0,bh,bm,1);da=0for(s=s1;;s=s.next){if(s.type==C.NOTE&&s.stem!=beam_dir)s.ys=bm.a*s.xs+bm.b-staff_tb[s.st].y+bshift*(s.nflags-1)*s.stem-bhif(s==s2)break}if(s1.feathered_beam){da=bshift/(s2.xs-s1.xs)if(s1.feathered_beam>0){da=-da;bshift=da*s1.xs}else{bshift=da*s2.xs}da=da*beam_dir}shift=0for(i=2;i<=bm.nflags;i++){shift+=bshiftif(da!=0)bm.a+=dafor(s=s1;;s=s.next){if(s.type!=C.NOTE||s.nflags<i){if(s==s2)breakcontinue}if(s.trem1&&i>s.nflags-s.ntrem){x1=(s.dur>=C.BLEN/2)?s.x:s.xs;draw_beam(x1-5,x1+5,(shift+2.5)*beam_dir,bh,bm,i)if(s==s2)breakcontinue}k1=swhile(1){if(s==s2)breakk=s.nextif(k.type==C.NOTE||k.type==C.REST){if(k.trem1){if(k.nflags-k.ntrem<i)break}else if(k.nflags<i){break}}if(k.beam_br1||(k.beam_br2&&i>2))breaks=k}k2=swhile(k2.type!=C.NOTE)k2=k2.prev;x1=k1.xsbd=beam_dirif(k1==k2){if(k1==s1){x1+=bstub}else if(k1==s2){x1-=bstub}else if(k1.beam_br1||(k1.beam_br2&&i>2)){x1+=bstub}else{k=k1.nextwhile(k.type!=C.NOTE)k=k.nextif(k.beam_br1||(k.beam_br2&&i>2)){x1-=bstub}else{k1=k1.prevwhile(k1.type!=C.NOTE)k1=k1.previf(k1.nflags<k.nflags||(k1.nflags==k.nflags&&k1.dots<k.dots))x1+=bstubelsex1-=bstub}}if(k1.stem!=beam_dir){bd=k1.stemk1.ys=bm.a*k1.xs+bm.b-staff_tb[k1.st].y-bh}}draw_beam(x1,k2.xs,shift*bd,bh,bm,i)if(s==s2)break}}if(s1.tmp)unlksym(s1)else if(s2.tmp)unlksym(s2)anno_stop(s1,'beam')}function draw_lstaff(x){var i,j,yb,h,fl,nst=cur_sy.nstaff,l=0function draw_sysbra(x,st,flag){var i,st_end,yt,ybwhile(!cur_sy.st_print[st]){if(cur_sy.staves[st].flags&flag)returnst++}i=st_end=stwhile(1){if(cur_sy.st_print[i])st_end=iif(cur_sy.staves[i].flags&flag)breaki++}yt=staff_tb[st].y+staff_tb[st].topbar*staff_tb[st].staffscale;yb=staff_tb[st_end].y+staff_tb[st_end].botbar*staff_tb[st_end].staffscaleif(flag&(CLOSE_BRACE|CLOSE_BRACE2))out_brace(x,yb,yt-yb)elseout_bracket(x,yt,yt-yb)}for(i=0;;i++){fl=cur_sy.staves[i].flagsif(fl&(OPEN_BRACE|OPEN_BRACKET))l++if(cur_sy.st_print[i])breakif(fl&(CLOSE_BRACE|CLOSE_BRACKET))l--if(i==nst)break}for(j=nst;j>i;j--){if(cur_sy.st_print[j])break}if(i==j&&l==0)returnyb=staff_tb[j].y+staff_tb[j].botbar*staff_tb[j].staffscale;h=staff_tb[i].y+staff_tb[i].topbar*staff_tb[i].staffscale-yb;xypath(x,yb);output+="v"+(-h).toFixed(1)+'"/>\n'for(i=0;i<=nst;i++){fl=cur_sy.staves[i].flagsif(fl&OPEN_BRACE)draw_sysbra(x,i,CLOSE_BRACE)if(fl&OPEN_BRACKET)draw_sysbra(x,i,CLOSE_BRACKET)if(fl&OPEN_BRACE2)draw_sysbra(x-6,i,CLOSE_BRACE2)if(fl&OPEN_BRACKET2)draw_sysbra(x-6,i,CLOSE_BRACKET2)}}function draw_meter(s){if(!s.a_meter)returnvar dx,i,j,meter,x,st=s.st,p_staff=staff_tb[st],y=p_staff.y;if(p_staff.stafflines!='|||||')y+=(p_staff.topbar+p_staff.botbar)/2-12for(i=0;i<s.a_meter.length;i++){meter=s.a_meter[i];x=s.x+s.x_meter[i]if(meter.bot){out_XYAB('\<g transform="translate(X,Y)" text-anchor="middle">\n\ <text y="-12">A</text>\n\ <text>B</text>\n\</g>\n',x,y+6,m_gl(meter.top),m_gl(meter.bot))}else{out_XYAB('\<text x="X" y="Y" text-anchor="middle">A</text>\n',x,y+12,m_gl(meter.top))}}}var acc_nd={}function draw_acc(x,y,a){if(typeof a=="object"){var c,n=a[0],d=a[1]c=n+'_'+da=acc_nd[c]if(!a){a=abc2svg.rat(Math.abs(n),d)d=a[1]a=(n<0?-a[0]:a[0]).toString()if(d!=1)a+='_'+dacc_nd[c]=a}}xygl(x,y,"acc"+a)}function set_hl(p_st,n,x,dx1,dx2){var i,hlif(n>=0){hl=p_st.hlu[n]if(!hl)hl=p_st.hlu[n]=[]}else{hl=p_st.hld[-n]if(!hl)hl=p_st.hld[-n]=[]}for(i=0;i<hl.length;i++){if(x>=hl[i][0])break}if(i==hl.length){hl.push([x,dx1,dx2])}else if(x>hl[i][0]){hl.splice(++i,0,[x,dx1,dx2])}else{if(dx1<hl[i][1])hl[i][1]=dx1if(dx2>hl[i][2])hl[i][2]=dx2}}Abc.prototype.draw_hl=function(s){var i,j,n,note,hla=[],st=s.st,p_staff=staff_tb[st]if(!p_staff.hll||s.invis)returnfor(i=0;i<=s.nhd;i++){note=s.notes[i]if(!p_staff.hlmap[note.pit-p_staff.hll])hla.push([note.pit-18,note.shhd*stv_g.scale])}n=hla.lengthif(!n)returnvar dx1,dx2,hl,shhd,hlp,stafflines=p_staff.stafflines,top=stafflines.length-1,yu=top,bot=p_staff.botline/6,yl=bot,dx=s.grace?4:hw_tb[s.head]*1.3note=s.notes[s.stem<0?s.nhd:0]shhd=note.shhdfor(i=0;i<hla.length;i++){hlp=hla[i][0]dx1=(hla[i][1]<shhd?hla[i][1]:shhd)-dxdx2=(hla[i][1]>shhd?hla[i][1]:shhd)+dxif(hlp<bot*2){if(hlp<yl*2)yl=++hlp>>1n--}else if(hlp>top*2){yu=hlp>>1n--}set_hl(p_staff,hlp>>1,s.x,dx1,dx2)}dx1=shhd-dxdx2=shhd+dxwhile(++yl<bot)set_hl(p_staff,yl,s.x,dx1,dx2)while(--yu>top)set_hl(p_staff,yu,s.x,dx1,dx2)if(!n)returni=yl;j=yuwhile(i>bot&&stafflines[i]=='-')i--while(j<top&&stafflines[j]=='-')j++for(;i<j;i++){if(stafflines[i]=='-')set_hl(p_staff,i,s.x,dx1,dx2)}}var sharp_cl=new Int8Array([24,9,15,21,6,12,18]),flat_cl=new Int8Array([12,18,24,9,15,21,6]),sharp1=new Int8Array([-9,12,-9,-9,12,-9]),sharp2=new Int8Array([12,-9,12,-9,12,-9]),flat1=new Int8Array([9,-12,9,-12,9,-12]),flat2=new Int8Array([-12,9,-12,9,-12,9])Abc.prototype.draw_keysig=function(x,s){var old_sf=s.k_old_sf,st=s.st,staffb=staff_tb[st].y,i,shift,p_seq,clef_ix=s.k_y_clef,a_acc=s.k_a_accfunction set_k_acc(a_acc,sf){var i,j,n,nacc,p_acc,accs=[],pits=[]if(sf>0){for(nacc=0;nacc<sf;nacc++){accs[nacc]=1pits[nacc]=[26,23,27,24,21,25,22][nacc]}}else{for(nacc=0;nacc<-sf;nacc++){accs[nacc]=-1pits[nacc]=[22,25,21,24,20,23,26][nacc]}}n=a_acc.lengthfor(i=0;i<n;i++){p_acc=a_acc[i]for(j=0;j<nacc;j++){if(pits[j]==p_acc.pit){accs[j]=p_acc.accbreak}}if(j==nacc){accs[j]=p_acc.accpits[j]=p_acc.pitnacc++}}for(i=0;i<nacc;i++){p_acc=a_acc[i]if(!p_acc)p_acc=a_acc[i]={}p_acc.acc=accs[i]p_acc.pit=pits[i]}}if(clef_ix&1)clef_ix+=7;clef_ix/=2while(clef_ix<0)clef_ix+=7;clef_ix%=7if(a_acc&&!s.exp)set_k_acc(a_acc,s.k_sf)if(!a_acc){if(s.fmt.cancelkey||s.k_sf==0){if(s.k_sf==0||old_sf*s.k_sf<0){shift=sharp_cl[clef_ix];p_seq=shift>9?sharp1:sharp2for(i=0;i<old_sf;i++){xygl(x,staffb+shift,"acc3");shift+=p_seq[i];x+=5.5}shift=flat_cl[clef_ix];p_seq=shift<18?flat1:flat2for(i=0;i>old_sf;i--){xygl(x,staffb+shift,"acc3");shift+=p_seq[-i];x+=5.5}if(s.k_sf!=0)x+=3}}if(s.k_sf>0){shift=sharp_cl[clef_ix];p_seq=shift>9?sharp1:sharp2for(i=0;i<s.k_sf;i++){xygl(x,staffb+shift,"acc1");shift+=p_seq[i];x+=5.5}if(s.fmt.cancelkey&&i<old_sf){x+=2for(;i<old_sf;i++){xygl(x,staffb+shift,"acc3");shift+=p_seq[i];x+=5.5}}if(s.k_bagpipe=='p'){xygl(x,staffb+27,"acc3")x+=5.5}}if(s.k_sf<0){shift=flat_cl[clef_ix];p_seq=shift<18?flat1:flat2for(i=0;i>s.k_sf;i--){xygl(x,staffb+shift,"acc-1");shift+=p_seq[-i];x+=5.5}if(s.fmt.cancelkey&&i>old_sf){x+=2for(;i>old_sf;i--){xygl(x,staffb+shift,"acc3");shift+=p_seq[-i];x+=5.5}}}}else if(a_acc.length){var acc,last_acc=a_acc[0].acc,last_shift=100,s2={st:st,nhd:0,notes:[{}]}for(i=0;i<a_acc.length;i++){acc=a_acc[i];shift=(s.k_y_clef+acc.pit-18)*3while(shift<-3)shift+=21while(shift>27)shift-=21if(i!=0&&(shift>last_shift+18||shift<last_shift-18))x-=5.5else if(acc.acc!=last_acc)x+=3;last_acc=acc.acc;s2.x=xs2.notes[0].pit=shift/3+18;last_shift=shift;draw_acc(x,staffb+shift,acc.acc)x+=5.5}}}function nrep_out(x,y,n){y-=3if(n<10){xygl(x-4,y,"mtr"+n)}else{xygl(x-10,y,"mtr"+((n/10)|0))xygl(x-2,y,"mtr"+(n%10))}}function center_rest(s){var s2,xif(s.dur<C.BLEN*2)s.nflags=-2else if(s.dur<C.BLEN*4)s.nflags=-3elses.nflags=-4s.dots=0s2=s.ts_nextwhile(s2.time!=s.time+s.dur&&s2.ts_next)s2=s2.ts_nextx=s2.x-s2.wls2=swhile(!s2.seqst)s2=s2.ts_prevs2=s2.ts_prevx=(x+s2.x+s2.wr)/2if(s.a_dd)deco_update(s,x-s.x)s.x=x}var rest_tb=["r128","r64","r32","r16","r8","r4","r2","r1","r0","r00"]function draw_rest(s){var s2,i,j,y,bx,p_staff=staff_tb[s.st],yb=p_staff.y,x=s.xif(s.notes[0].shhd)x+=s.notes[0].shhd*stv_g.scaleif(s.rep_nb){set_sscale(s.st);anno_start(s);if(p_staff.stafflines=='|||||')yb+=12elseyb+=(p_staff.topbar+p_staff.botbar)/2if(s.rep_nb<0){xygl(x,yb,"srep")}else{xygl(x,yb,"mrep")if(s.rep_nb>2&&s.v==cur_sy.top_voice&&s.fmt.measrepnb>0&&!(s.rep_nb%s.fmt.measrepnb))nrep_out(x,yb+p_staff.topbar,s.rep_nb)}anno_a.push(s)return}set_scale(s);anno_start(s);if(s.notes[0].color)set_color(s.notes[0].color);y=s.y;i=5-s.nflagsif(i==7&&y==12&&p_staff.stafflines.length<=2)y-=6if(!s.notes[0].invis)xygl(x,y+yb,rest_tb[i])if(s.dots){x+=8;y+=yb+3j=s.dotsi=(s.dur_orig/12)>>((5-s.nflags)-j)while(j-->0){xygl(x,y,(i&(1<<j))?"dot":"dot+")x+=3.5}}set_color();anno_a.push(s)}function draw_mrest(s){var x1,x2,prev,p_st=staff_tb[s.st],y=p_st.y+(p_st.topbar+p_st.botbar)/2,p=s.nmes.toString()if(!s.next){error(1,s,"Lack of bar after multi-measure rest")return}set_scale(s)prev=swhile(!prev.seqst)prev=prev.ts_prevprev=prev.ts_prevwhile(!prev.seqst)prev=prev.ts_prevx1=prev.x+20x2=s.next.x-20s.x=(x1+x2)/2anno_start(s)out_XYAB('<path d="mX Y',x1+.6,y-2.7)output+='v2.7h-1.4v-10.8h1.4v2.7h'+((x2-x1-2.8)/stv_g.scale).toFixed(1)+'v-2.7h1.4v10.8h-1.4v-2.7z"/>\n'if(s.tacet)out_XYAB('<text x ="X" y="Y" style="font-size:12px;font-weight:700"\ text-anchor="middle">A</text>\n',s.x,y+18,s.tacet)elseout_XYAB('<text x ="X" y="Y" text-anchor="middle">A</text>\n',s.x,y+22,m_gl(p))anno_a.push(s)}function grace_slur(s){var yy,x0,y0,x3,y3,bet1,bet2,dy1,dy2,last,below,so=s,g=s.extrawhile(1){if(!g.next)breakg=g.next}last=gbelow=((g.stem>=0||s.multi<0)&&g.notes[0].pit<=28)||g.notes[0].pit<16if(below){yy=127for(g=s.extra;g;g=g.next){if(g.y<yy){yy=g.y;last=g}}x0=last.x;y0=last.y-5if(s.extra!=last){x0-=4;y0+=1}s=s.next;x3=s.x-1if(s.stem<0&&s.nflags>-2)x3-=4;y3=3*(s.notes[0].pit-18)-5;dy1=(x3-x0)*.4if(dy1>3)dy1=3;dy2=dy1;bet1=.2;bet2=.8if(y0>y3+7){x0=last.x-1;y0+=.5;y3+=6.5;x3=s.x-5.5;dy1=(y0-y3)*.8;dy2=(y0-y3)*.2;bet1=0}else if(y3>y0+4){y3=y0+4;x0=last.x+2;y0=last.y-4}}else{yy=-127for(g=s.extra;g;g=g.next){if(g.y>yy){yy=g.y;last=g}}x0=last.x;y0=last.y+5if(s.extra!=last){x0-=4;y0-=1}s=s.next;x3=s.x-1if(s.stem>=0&&s.nflags>-2)x3-=2;y3=3*(s.notes[s.nhd].pit-18)+5;dy1=(x0-x3)*.4if(dy1<-3)dy1=-3;dy2=dy1;bet1=.2;bet2=.8if(y0<y3-7){x0=last.x-1;y0-=.5;y3-=6.5;x3=s.x-5.5;dy1=(y0-y3)*.8;dy2=(y0-y3)*.2;bet1=0}else if(y3<y0-4){y3=y0-4;x0=last.x+2;y0=last.y+4}}so.slur={x0:x0,y0:y0,x1:bet1*x3+(1-bet1)*x0-x0,y1:y0-bet1*y3-(1-bet1)*y0+dy1,x2:bet2*x3+(1-bet2)*x0-x0,y2:y0-bet2*y3-(1-bet2)*y0+dy2,x3:x3-x0,y3:y0-y3}y0-=so.slur.y1g=so.extraif(below){if(y0<g.ymn)g.ymn=y0}else{if(y0>g.ymx)g.ymx=y0}}function draw_gracenotes(s){var x1,y1,last,note,bm={},g=s.extrawhile(1){if(g.beam_st&&!g.beam_end){if(self.calculate_beam(bm,g))draw_beams(bm)}anno_start(g)draw_note(g,!bm.s2)if(g==bm.s2)bm.s2=nullanno_a.push(s)if(!g.next)breakg=g.next}last=gif(s.sappo){g=s.extraif(!g.next){x1=9y1=g.stem>0?5:-5}else{x1=(g.next.x-g.x)*.5+4y1=(g.ys+g.next.ys)*.5-g.yif(g.stem>0)y1-=1elsey1+=1}note=g.notes[g.stem<0?0:g.nhd]out_acciac(x_head(g,note),y_head(g,note),x1,y1,g.stem>0)}g=s.slurif(g){anno_start(s,'slur')xypath(g.x0,g.y0+staff_tb[s.st].y)output+='c'+g.x1.toFixed(1)+' '+g.y1.toFixed(1)+' '+g.x2.toFixed(1)+' '+g.y2.toFixed(1)+' '+g.x3.toFixed(1)+' '+g.y3.toFixed(1)+'"/>\n'anno_stop(s,'slur')}}function setdoty(s,y_tb){var m,m1,yfor(m=0;m<=s.nhd;m++){y=3*(s.notes[m].pit-18)if((y%6)==0){if(s.dot_low)y-=3elsey+=3}y_tb[m]=y}for(m=0;m<s.nhd;m++){if(y_tb[m+1]>y_tb[m])continuem1=mwhile(m1>0){if(y_tb[m1]>y_tb[m1-1]+6)breakm1--}if(3*(s.notes[m1].pit-18)-y_tb[m1]<y_tb[m+1]-3*(s.notes[m+1].pit-18)){while(m1<=m)y_tb[m1++]-=6}else{y_tb[m+1]=y_tb[m]+6}}}function x_head(s,note){return s.x+note.shhd*stv_g.scale}function y_head(s,note){return staff_tb[s.st].y+3*(note.pit-18)}function draw_basic_note(s,m,y_tb){var i,p,yy,dotx,doty,inv,old_color=false,note=s.notes[m],staffb=staff_tb[s.st].y,x=s.x,y=3*(note.pit-18),shhd=note.shhd*stv_g.scale,x_note=x+shhd,y_note=y+staffbvar elts=identify_note(s,note.dur),head=elts[0],dots=elts[1],nflags=elts[2]if(note.invis){}else if(s.grace){p="ghd";x_note-=4.5*stv_g.scale}else if(note.map&¬e.map[0]){i=s.head;p=note.map[0][i]if(!p)p=note.map[0][note.map[0].length-1]i=p.indexOf('/')if(i>=0){if(s.stem>=0)p=p.slice(0,i)elsep=p.slice(i+1)}}else if(s.type==C.CUSTOS){p="custos"}else{switch(head){case C.OVAL:p="HD"breakcase C.OVALBARS:if(s.head!=C.SQUARE){p="HDD"break}case C.SQUARE:if(nflags>-4){p="breve"}else{p="longa"inv=s.stem>0}if(!tsnext&&s.next&&s.next.type==C.BAR&&!s.next.next)dots=0x_note+=1breakcase C.EMPTY:p="Hd"breakdefault:p="hd"break}}if(note.color!=undefined)old_color=set_color(note.color)if(p){if(inv){g_open(x_note,y_note,0,1,-1);x_note=y_note=0}if(!self.psxygl(x_note,y_note,p))xygl(x_note,y_note,p)if(inv)g_close()}if(dots){dotx=x+(7.7+s.xmx)*stv_g.scaleif(y_tb[m]==undefined){y_tb[m]=3*(s.notes[m].pit-18)if((s.notes[m].pit&1)==0)y_tb[m]+=3}doty=y_tb[m]+staffbi=(note.dur/12)>>((5-nflags)-dots)while(dots-->0){xygl(dotx,doty,(i&(1<<dots))?"dot":"dot+")dotx+=3.5}}if(note.acc){x-=note.shac*stv_g.scaleif(!s.grace){draw_acc(x,y+staffb,note.acc)}else{g_open(x,y+staffb,0,.75);draw_acc(0,0,note.acc)g_close()}}if(old_color!=false)set_color(old_color)}function draw_note(s,fl){var s2,i,m,y,slen,c,nflags,y_tb=new Array(s.nhd+1),note=s.notes[s.stem<0?s.nhd:0],x=x_head(s,note),y=y_head(s,note),staffb=staff_tb[s.st].yif(s.dots)setdoty(s,y_tb)if(!s.stemless){slen=s.ys-s.y;nflags=s.nflagsif(s.ntrem)nflags-=s.ntremif(!fl||nflags<=0){if(s.nflags>0){if(s.stem>=0)slen-=1elseslen+=1}out_stem(x,y,slen,s.grace)}else{out_stem(x,y,slen,s.grace,nflags,s.fmt.straightflags)}}else if(s.xstem){s2=s.ts_prev;slen=(s2.stem>0?s2.y:s2.ys)-s.y;slen+=staff_tb[s2.st].y-staffb;out_stem(x,y,slen)}if(fl&&s.trem1){var ntrem=s.ntrem||0,x1=x;slen=3*(s.notes[s.stem>0?s.nhd:0].pit-18)if(s.head==C.FULL||s.head==C.EMPTY){x1+=(s.grace?GSTEM_XOFF:3.5)*s.stemif(s.stem>0)slen+=6+5.4*ntremelseslen-=6+5.4}else{if(s.stem>0)slen+=5+5.4*ntremelseslen-=5+5.4}slen/=s.p_v.scale;out_trem(x1,staffb+slen,ntrem)}for(m=0;m<=s.nhd;m++)draw_basic_note(s,m,y_tb)}function prev_scut(s){while(s.prev){s=s.previf(s.rbstart)return s}s=s.p_v.symwhile(s.type!=C.CLEF)s=s.ts_previf(s.next&&s.next.type==C.KEY)s=s.nextif(s.next&&s.next.type==C.METER)return s.nextreturn s}function slur_direction(k1,k2){var s,some_upstem,low,dirfunction slur_multi(s1,s2){if(s1.multi)return s1.multiif(s2.multi)return s2.multireturn 0}if(k1.grace&&k1.stem>0)return-1dir=slur_multi(k1,k2)if(dir)return dirfor(s=k1;;s=s.next){if(s.type==C.NOTE){if(!s.stemless){if(s.stem<0)return 1some_upstem=true}if(s.notes[0].pit<22)low=true}if(s.time==k2.time)break}if(!some_upstem&&!low)return 1return-1}function slur_out(x1,y1,x2,y2,dir,height,dotted){var dx,dy,dz,alfa=.3,beta=.45;dy=y2-y1if(dy<0)dy=-dy;dx=x2-x1if(dx>40.&&dy/dx<.7){alfa=.3+.002*(dx-40.)if(alfa>.7)alfa=.7}var mx=.5*(x1+x2),my=.5*(y1+y2),xx1=mx+alfa*(x1-mx),yy1=my+alfa*(y1-my)+height;xx1=x1+beta*(xx1-x1);yy1=y1+beta*(yy1-y1)var xx2=mx+alfa*(x2-mx),yy2=my+alfa*(y2-my)+height;xx2=x2+beta*(xx2-x2);yy2=y2+beta*(yy2-y2);dy=2*dir;dz=.2+.001*dxif(dz>.6)dz=.6;dz*=dirdx*=.03var scale_y=1if(!dotted)output+='<path d="M'elseoutput+='<path class="stroke" stroke-dasharray="5,5" d="M';out_sxsy(x1,' ',y1);output+='c'+((xx1-x1)/stv_g.scale).toFixed(1)+' '+((y1-yy1)/scale_y).toFixed(1)+' '+((xx2-x1)/stv_g.scale).toFixed(1)+' '+((y1-yy2)/scale_y).toFixed(1)+' '+((x2-x1)/stv_g.scale).toFixed(1)+' '+((y1-y2)/scale_y).toFixed(1)if(!dotted)output+='\n\tv'+(-dz).toFixed(1)+'c'+((xx2-dx-x2)/stv_g.scale).toFixed(1)+' '+((y2+dz-yy2-dy)/scale_y).toFixed(1)+' '+((xx1+dx-x2)/stv_g.scale).toFixed(1)+' '+((y2+dz-yy1-dy)/scale_y).toFixed(1)+' '+((x1-x2)/stv_g.scale).toFixed(1)+' '+((y2-y1)/scale_y).toFixed(1)output+='"/>\n'}function draw_slur(path,sl,recurr){var i,k,g,x1,y1,x2,y2,height,addy,s_st2,a,y,z,h,dx,dy,ty=sl.ty,dir=(ty&0x07)==C.SL_ABOVE?1:-1,n=path.length,i1=0,i2=n-1,not1=sl.nts,k1=path[0],k2=path[i2],nn=1set_dscale(k1.st)for(i=1;i<n;i++){k=path[i]if(k.type==C.NOTE||k.type==C.REST){nn++if(k.st!=k1.st&&!s_st2)s_st2=k}}if(s_st2&&!recurr){if(!gene.a_sl)gene.a_sl=[]h=24+k1.fmt.sysstaffsepif(s_st2.st>k1.st)h=-hfor(i=0;i<n;i++){k=path[i]if(k.st==k1.st){if(k.dur)a=kcontinue}k=clone(k)if(path[i]==s_st2)s_st2=kpath[i]=kif(k.dur){k.notes=clone(k.notes)k.notes[0]=clone(k.notes[0])if(sl.ty&C.SL_CENTER){if(k.st!=a.st){sl.ty=(sl.ty&~0x07)|(a.st<k.st?C.SL_BELOW:C.SL_ABOVE)z=k1.ymnh=k2.ymxif(k.st<a.st){for(i1=1;i1<i;i1++){a=path[i1]if(a.ymn<z)z=a.ymn}for(i1=i;i1<i2;i1++){a=path[i1]if(a.ymx>h)h=a.ymx}}else{for(i1=1;i1<i;i1++){a=path[i1]if(a.ymx>h)h=a.ymx}for(i1=i;i1<i2;i1++){a=path[i1]if(a.ymn<z)z=a.ymn}}h+=za=k}k.y=h-k.yk.notes[0].pit=(k.y/3|0)+18k.ys=h-k.ysy=k.ymxk.ymx=h-k.ymnk.ymn=h-yk.stem=-k.stem}else{k.notes[0].pit+=h/3|0k.ys+=hk.y+=hk.ymx+=hk.ymn+=h}}}ty=k1.st>s_st2.st?'/':'\\'if(sl.ty&C.SL_CENTER)ty=ty+tyelse if(k1.st==k2.st)ty=ty=='/'?'/\\':'\\/'elsety+=dir>0?'+':'-'var savout=outputoutput=""draw_slur(path,sl,1)gene.a_sl.push([k1,s_st2,ty,output])output=savoutreturn}x1=k1.xif(k1.notes&&k1.notes[0].shhd)x1+=k1.notes[0].shhd;x2=k2.xif(k2.notes)x2+=k2.notes[0].shhdif(not1){y1=3*(not1.pit-18)+2*dirx1+=3}else{y1=dir>0?k1.ymx+2:k1.ymn-2if(k1.type==C.NOTE){if(dir>0){if(k1.stem>0){x1+=5if(k1.beam_end&&k1.nflags>=-1&&!k1.in_tuplet){if(k1.nflags>0){x1+=2;y1=k1.ys-3}else{y1=k1.ys-6}}else{y1=k1.ys+3}}else{y1=k1.y+8}}else{if(k1.stem<0){x1-=1if(k2.grace){y1=k1.y-8}else if(k1.beam_end&&k1.nflags>=-1&&(!k1.in_tuplet||k1.ys<y1+3)){if(k1.nflags>0){x1+=2;y1=k1.ys+3}else{y1=k1.ys+6}}else{y1=k1.ys-3}}else{y1=k1.y-8}}}}if(sl.nte){y2=3*(sl.nte.pit-18)+2*dirx2-=3}else{y2=dir>0?k2.ymx+2:k2.ymn-2if(k2.type==C.NOTE){if(dir>0){if(k2.stem>0){x2+=1if(k2.beam_st&&k2.nflags>=-1&&!k2.in_tuplet)y2=k2.ys-6elsey2=k2.ys+3}else{y2=k2.y+8}}else{if(k2.stem<0){x2-=5if(k2.beam_st&&k2.nflags>=-1&&!k2.in_tuplet)y2=k2.ys+6elsey2=k2.ys-3}else{y2=k2.y-8}}}}if(k1.type!=C.NOTE){y1=y2+1.2*dir;x1=k1.x+k1.wr*.5if(x1>x2-12)x1=x2-12}if(k2.type!=C.NOTE){if(k1.type==C.NOTE)y2=y1+1.2*direlsey2=y1if(k1!=k2)x2=k2.x-k2.wl*.3}if(nn>=3){k=path[1]if(k.type!=C.BAR&&k.x<x1+48){if(dir>0){y=k.ymx-2if(y1<y)y1=y}else{y=k.ymn+2if(y1>y)y1=y}}k=path[i2-1]if(k.type!=C.BAR&&k.x>x2-48){if(dir>0){y=k.ymx-2if(y2<y)y2=y}else{y=k.ymn+2if(y2>y)y2=y}}}a=(y2-y1)/(x2-x1)if(a>SLUR_SLOPE||a<-SLUR_SLOPE){a=a>SLUR_SLOPE?SLUR_SLOPE:-SLUR_SLOPEif(a*dir>0)y1=y2-a*(x2-x1)elsey2=y1+a*(x2-x1)}y=y2-y1if(y>8)y=8else if(y<-8)y=-8z=yif(z<0)z=-z;dx=.5*z;dy=.3*yif(y*dir>0){x2-=dx;y2-=dy}else{x1+=dx;y1+=dy}if(k1.grace)x1=k1.x-GSTEM_XOFF*.5if(k2.grace)x2=k2.x+GSTEM_XOFF*1.5;h=0;a=(y2-y1)/(x2-x1)if(k1!=k2&&k1.v==k2.v){addy=y1-a*x1for(i=1;i<i2;i++){k=path[i]switch(k.type){case C.NOTE:case C.REST:if(dir>0){y=3*(k.notes[k.nhd].pit-18)+6if(y<k.ymx)y=k.ymx;y-=a*k.x+addyif(y>h)h=y}else{y=3*(k.notes[0].pit-18)-6if(y>k.ymn)y=k.ymn;y-=a*k.x+addyif(y<h)h=y}breakcase C.GRACE:for(g=k.extra;g;g=g.next){if(dir>0){y=3*(g.notes[g.nhd].pit-18)+6if(y<g.ymx)y=g.ymx;y-=a*g.x+addyif(y>h)h=y}else{y=3*(g.notes[0].pit-18)-6if(y>g.ymn)y=g.ymn;y-=a*g.x+addyif(y<h)h=y}}break}}y1+=.45*h;y2+=.45*h;h*=.65}if(nn>3)height=(.08*(x2-x1)+12)*direlseheight=(.03*(x2-x1)+8)*dirif(dir>0){if(height<3*h)height=3*hif(height>40)height=40}else{if(height>3*h)height=3*hif(height<-40)height=-40}y=y2-y1if(y<0)y=-yif(dir>0){if(height<.8*y)height=.8*y}else{if(height>-.8*y)height=-.8*y}height*=k1.fmt.slurheight;slur_out(x1,y1,x2,y2,dir,height,ty&C.SL_DOTTED);dx=x2-x1;a=(y2-y1)/dx;addy=y1-a*x1if(height>0)addy+=4*Math.sqrt(height)-2elseaddy-=4*Math.sqrt(-height)-2for(i=0;i<i2;i++){k=path[i]if(k.st!=k1.st||k.type==C.BAR)continuey=a*k.x+addyif(k.ymx<y)k.ymx=yelse if(k.ymn>y)k.ymn=yif(recurr)continueif(i==i2-1){dx=x2if(sl.nte)dx-=5}else{dx=k.x+k.wr}if(i!=0)x1=k.xif(!i||i==i2)y-=height/3dx-=x1-k.wly_set(k1.st,dir>0,x1-k.wl,dx,y)}}function draw_slurs(s,last){var gr1,i,m,note,sls,nslsfunction draw_sls(s,sl){var k,v,i,dir,s3,path=[],s2=sl.seif(last&&s2.time>last.time)returnswitch(sl.loc){case'i':s=prev_scut(s)breakcase'o':for(s3=s;s3.ts_next;s3=s3.ts_next);s2=s3for(;s3;s3=s3.ts_prev){if(s3.v==s.v){s2=s3break}if(s3.st==s.st)s2=s3if(s3.ts_prev.time!=s2.time)break}break}if(s.p_v.s_next&&s2.time>=tsnext.time){if(s2.time==tsnext.time){if(s2.grace){for(s3=tsnext;s3&&s3.time==s2.time;s3=s3.ts_next){if(s3.type==C.GRACE){s3=nullbreak}}}else{for(s3=tsnext;s3.time==s2.time;s3=s3.ts_next){if(s3==s2){s3=nullbreak}}}}else{s3=null}if(!s3){s.p_v.sls.push(sl);s2=s.p_v.s_next.prevwhile(s2.next)s2=s2.next;sl=Object.create(sl)}}switch(sl.ty&0x07){case C.SL_ABOVE:dir=1;breakcase C.SL_BELOW:dir=-1;breakdefault:dir=s.v!=s2.v?1:slur_direction(s,s2)sl.ty&=~0x07sl.ty|=dir>0?C.SL_ABOVE:C.SL_BELOWbreak}if(s.v==s2.v){v=s.v}if(!cur_sy.voices[s.v]||!cur_sy.voices[s2.v]){v=s.v>s2.v?s.v:s2.v}else if(dir*(cur_sy.voices[s.v].range<=cur_sy.voices[s2.v].range?1:-1)>0)v=s.velsev=s2.vif(gr1&&!(s2.grace&&s.v==s2.v&&s.time==s2.time)){do{path.push(s);s=s.next}while(s);s=gr1.next}else{path.push(s);if(s.grace)s=s.nextelses=s.ts_next}if(!s2.grace){while(s){if(s.v==v)path.push(s)if(s==s2)breaks=s.ts_next}}else if(s.grace){while(1){path.push(s)if(s==s2)breaks=s.next}}else{k=s2while(k.prev)k=k.prevwhile(1){if(s.v==v)path.push(s)if(s.extra==k)breaks=s.ts_next}s=kwhile(1){path.push(s)if(s==s2)breaks=s.next}}for(i=1;i<path.length-1;i++){s=path[i]if(s.sls)draw_slurs(s,last)if(s.tp)draw_tuplet(s)}draw_slur(path,sl)return 1}while(1){if(!s||s==last){if(!gr1||!(s=gr1.next)||s==last)breakgr1=null}if(s.type==C.GRACE){gr1=s;s=s.extracontinue}if(s.sls){sls=s.slss.sls=nullnsls=[]for(i=0;i<sls.length;i++){if(!draw_sls(s,sls[i]))nsls.push(sls[i])}if(nsls.length)s.sls=nsls}s=s.next}}function draw_tuplet(s1){var s2,s3,g,upstaff,nb_only,x1,x2,y1,y2,xm,ym,a,s0,yy,yx,dy,a,dir,r,tp=s1.tp.shift()if(!s1.tp.length)delete s1.tpupstaff=s1.stset_dscale(s1.st)for(s2=s1;s2;s2=s2.next){switch(s2.type){case C.GRACE:if(!s2.sl1)continuefor(g=s2.extra;g;g=g.next){if(g.sls)draw_slurs(g)}default:continuecase C.NOTE:case C.REST:break}if(s2.sls)draw_slurs(s2)if(s2.st<upstaff)upstaff=s2.stif(s2.tp)draw_tuplet(s2)if(s2.tpe)break}if(s2)s2.tpe--if(tp.f[0]==1)returnif(!s2){error(1,s1,"No end of tuplet in this music line")return}dir=tp.f[3]if(!dir){s3=s1while(s3&&!s3.stem)s3=s3.nextdir=(s3&&s3.stem<0)?C.SL_BELOW:C.SL_ABOVE}if(s1==s2||tp.f[1]==2){nb_only=true}else if(tp.f[1]==1){nb_only=true;draw_slur([s1,s2],{ty:dir})}else{if(tp.f[0]!=2&&s1.type==C.NOTE&&s2.type==C.NOTE){nb_only=truefor(s3=s1;;s3=s3.next){if(s3.type!=C.NOTE&&s3.type!=C.REST){if(s3.type==C.GRACE||s3.type==C.SPACE)continuenb_only=falsebreak}if(s3==s2)breakif(s3.beam_end){nb_only=falsebreak}}if(nb_only&&!s1.beam_st&&!s1.beam_br1&&!s1.beam_br2){for(s3=s1.prev;s3;s3=s3.prev){if(s3.type==C.NOTE||s3.type==C.REST){if(s3.nflags>=s1.nflags)nb_only=falsebreak}}}if(nb_only&&!s2.beam_end){for(s3=s2.next;s3;s3=s3.next){if(s3.type==C.NOTE||s3.type==C.REST){if(!s3.beam_br1&&!s3.beam_br2&&s3.nflags>=s2.nflags)nb_only=falsebreak}}}}}if(nb_only){if(tp.f[2]==1)returnset_font("tuplet")xm=(s2.x+s1.x)/2if(dir==C.SL_ABOVE)ym=y_get(upstaff,1,xm-4,8)elseym=y_get(upstaff,0,xm-4,8)-gene.curfont.sizeif(s1.stem*s2.stem>0){if(s1.stem>0)xm+=1.5elsexm-=1.5}if(tp.f[2]==0)xy_str(xm,ym,tp.p.toString(),'c')elsexy_str(xm,ym,tp.p+':'+tp.q,'c')for(s3=s1;;s3=s3.next){if(s3.x>=xm)break}if(dir==C.SL_ABOVE){ym+=gene.curfont.sizeif(s3.ymx<ym)s3.ymx=ym;y_set(upstaff,true,xm-3,6,ym)}else{if(s3.ymn>ym)s3.ymn=ym;y_set(upstaff,false,xm-3,6,ym)}return}x1=s1.x-4if(s2.dur>s2.prev.dur){s3=s2.nextif(!s3||s3.time!=s2.time+s2.dur){for(s3=s2.ts_next;s3;s3=s3.ts_next){if(s3.seqst&&s3.time>=s2.time+s2.dur)break}}x2=s3?s3.x-s3.wl-5:realwidth-6}else{x2=s2.x+4r=s2.stem>=0?0:s2.nhdif(s2.notes[r].shhd>0)x2+=s2.notes[r].shhdif(s2.st==upstaff&&s2.stem>0)x2+=3.5}if(dir==C.SL_ABOVE){if(s1.st==s2.st){y1=y2=staff_tb[upstaff].topbar+2}else{y1=s1.ymx;y2=s2.ymx}if(s1.st==upstaff){for(s3=s1;!s3.dur;s3=s3.next);ym=y_get(upstaff,1,s3.x-4,8)if(ym>y1)y1=ymif(s1.stem>0)x1+=3}if(s2.st==upstaff){for(s3=s2;!s3.dur;s3=s3.prev);ym=y_get(upstaff,1,s3.x-4,8)if(ym>y2)y2=ym}xm=.5*(x1+x2);ym=.5*(y1+y2);a=(y2-y1)/(x2-x1);s0=3*(s2.notes[s2.nhd].pit-s1.notes[s1.nhd].pit)/(x2-x1)if(s0>0){if(a<0)a=0else if(a>s0)a=s0}else{if(a>0)a=0else if(a<s0)a=s0}a=s1.fmt.beamslope*a/(s1.fmt.beamslope+Math.abs(a))if(a*a<.1*.1)a=0dy=0for(s3=s1;;s3=s3.next){if(!s3.dur||s3.st!=upstaff){if(s3==s2)breakcontinue}yy=ym+(s3.x-xm)*a;yx=y_get(upstaff,1,s3.x-4,8)+2if(yx-yy>dy)dy=yx-yyif(s3==s2)break}ym+=dy;y1=ym+a*(x1-xm);y2=ym+a*(x2-xm);ym+=6for(s3=s1;;s3=s3.next){if(s3.st==upstaff){yy=ym+(s3.x-xm)*aif(s3.ymx<yy)s3.ymx=yyy_set(upstaff,true,s3.x-3,6,yy)}if(s3==s2)break}}else{if(s1.stem<0)x1-=2if(s1.st==upstaff){for(s3=s1;!s3.dur;s3=s3.next);y1=y_get(upstaff,0,s3.x-4,8)}else{y1=0}if(s2.st==upstaff){for(s3=s2;!s3.dur;s3=s3.prev);y2=y_get(upstaff,0,s3.x-4,8)}else{y2=0}xm=.5*(x1+x2);ym=.5*(y1+y2);a=(y2-y1)/(x2-x1);s0=3*(s2.notes[0].pit-s1.notes[0].pit)/(x2-x1)if(s0>0){if(a<0)a=0else if(a>s0)a=s0if(a>.35)a=.35}else{if(a>0)a=0else if(a<s0)a=s0if(a<-.35)a=-.35}if(a*a<.1*.1)a=0dy=0for(s3=s1;;s3=s3.next){if(!s3.dur||s3.st!=upstaff){if(s3==s2)breakcontinue}yy=ym+(s3.x-xm)*a;yx=y_get(upstaff,0,s3.x-4,8)if(yx-yy<dy)dy=yx-yyif(s3==s2)break}ym+=dy-8y1=ym+a*(x1-xm);y2=ym+a*(x2-xm);ym-=2for(s3=s1;;s3=s3.next){if(s3.st==upstaff){yy=ym+(s3.x-xm)*aif(s3.ymn>yy)s3.ymn=yy;y_set(upstaff,false,s3.x-3,6,yy)}if(s3==s2)break}}if(tp.f[2]==1){out_tubr(x1,y1+4,x2-x1,y2-y1,dir==C.SL_ABOVE);return}out_tubrn(x1,y1,x2-x1,y2-y1,dir==C.SL_ABOVE,tp.f[2]==0?tp.p.toString():tp.p+':'+tp.q);if(dir==C.SL_ABOVE)y_set(upstaff,true,xm-3,6,yy+2)elsey_set(upstaff,false,xm-3,6,yy)}function draw_tie(not1,not2,job){var m,x1,s,y,h,time,p=job==2?not1.pit:not2.pit,dir=(not1.tie_ty&0x07)==C.SL_ABOVE?1:-1,s1=not1.s,st=s1.st,s2=not2.s,x2=s2.x,sh=not1.shhdfor(m=0;m<s1.nhd;m++)if(s1.notes[m]==not1)breakif(dir>0){if(m<s1.nhd&&p+1==s1.notes[m+1].pit)if(s1.notes[m+1].shhd>sh)sh=s1.notes[m+1].shhd}else{if(m>0&&p==s1.notes[m-1].pit+1)if(s1.notes[m-1].shhd>sh)sh=s1.notes[m-1].shhd}x1=s1.x+shif(job!=2){for(m=0;m<s2.nhd;m++)if(s2.notes[m]==not2)breaksh=s2.notes[m].shhdif(dir>0){if(m<s2.nhd&&p+1==s2.notes[m+1].pit)if(s2.notes[m+1].shhd<sh)sh=s2.notes[m+1].shhd}else{if(m>0&&p==s2.notes[m-1].pit+1)if(s2.notes[m-1].shhd<sh)sh=s2.notes[m-1].shhd}x2+=sh}switch(job){default:if(p<not2.pit||dir<0)p=not1.pitbreakcase 3:dir=-dircase 1:x1=s2.prev?(s2.prev.x+s2.wr):s1.xif(s1.st!=s2.st)st=s2.stx1+=(x2-x1)*.4if(x1>x2-20)x1=x2-20breakcase 2:x2=s1.next?s1.next.x:realwidthif(x2!=realwidth)x2-=(x2-x1)*.4if(x2<x1+16)x2=x1+16break}if(x2-x1>20){x1+=3.5x2-=3.5}else{x1+=1.5x2-=1.5}if(s1.dots&&!(not1.pit&1)&&((dir>0&&!s1.dot_low)||(dir<0&&s1.dot_low)))x1+=5y=staff_tb[st].y+3*(p-18)+dirh=(.03*(x2-x1)+16)*dir*s1.fmt.tieheightslur_out(x1,y,x2,y,dir,h,not1.tie_ty&C.SL_DOTTED)}function draw_all_ties(p_voice){var s,s1,s2,clef_chg,x,dx,m,not1,not2,tim2=0s1=p_voice.symset_color(s1.color)for(;s1;s1=s1.next){if(s1.ti2&&s1.time!=tim2){for(m=0;m<=s1.nhd;m++){not2=s1.notes[m]not1=not2.tie_sif(!not1||not1.s.v!=s1.v)continuedraw_tie(not1,not2,1)}}if(!s1.ti1)continueif(s1.type==C.GRACE){for(s=s1.extra;s;s=s.next){for(m=0;m<=s1.nhd;m++){not1=s.notes[m]not2=not1.tie_eif(!not2)continuedraw_tie(not1,not2)tim2=not2.s.time}}continue}for(m=0;m<=s1.nhd;m++){not1=s1.notes[m]not2=not1.tie_eif(!not2){if(not1.tie_ty)draw_tie(not1,not1,2)continue}s2=not2.sif(tsnext&&s2.time>=tsnext.time){draw_tie(not1,not2,2)continue}tim2=s2.timefor(s=s1.ts_next;s!=s2;s=s.ts_next){if(s.st!=s1.st)continueif(s.type==C.CLEF){clef_chg=truebreak}}if(clef_chg||s1.st!=s2.st){draw_tie(not1,not2,2)draw_tie(not1,not2,3)clef_chg=false}else{draw_tie(not1,not2)}}}}function draw_sym_near(){var p_voice,p_st,s,v,st,y,g,w,i,st,dx,top,bot,ymn,output_sav=output;function set_yab(s1,s2){var y,k=realwidth/YSTEP,i=(s1.x/k)|0,j=(s2.x/k)|0,a=(s1.ys-s2.ys)/(s1.xs-s2.xs),b=s1.ys-s1.xs*a,p_st=staff_tb[s1.st]k*=aif(s1.stem>0){while(i<=j){y=k*i+bif(p_st.top[i]<y)p_st.top[i]=yi++}}else{while(i<=j){y=k*i+bif(p_st.bot[i]>y)p_st.bot[i]=yi++}}}output=""YSTEP=Math.ceil(realwidth/2)for(st=0;st<=nstaff;st++){p_st=staff_tb[st]p_st.top=new Float32Array(YSTEP)p_st.bot=new Float32Array(YSTEP)for(i=0;i<YSTEP;i++){p_st.top[i]=0p_st.bot[i]=24}}for(v=0;v<voice_tb.length;v++){var bm={},first_note=true;p_voice=voice_tb[v]for(s=p_voice.sym;s;s=s.next){switch(s.type){case C.GRACE:for(g=s.extra;g;g=g.next){if(g.beam_st&&!g.beam_end){self.calculate_beam(bm,g)if(bm.s2)set_yab(g,bm.s2)}}if(!s.p_v.ckey.k_bagpipe&&s.fmt.graceslurs&&!s.gr_shift&&!s.sl1&&!s.ti1&&s.next&&s.next.type==C.NOTE)grace_slur(s)break}}for(s=p_voice.sym;s;s=s.next){switch(s.type){case C.NOTE:if((s.beam_st&&!s.beam_end)||(first_note&&!s.beam_st)){first_note=false;self.calculate_beam(bm,s)if(bm.s2)set_yab(s,bm.s2)}break}}}set_tie_room();draw_deco_near()for(s=tsfirst;s;s=s.ts_next){if(s.invis)continueswitch(s.type){case C.GRACE:for(g=s.extra;g;g=g.next){y_set(s.st,true,g.x-2,4,g.ymx+1);y_set(s.st,false,g.x-2,4,g.ymn-5)}continuecase C.MREST:y_set(s.st,true,s.x+16,32,s.ymx+2)continuedefault:y_set(s.st,true,s.x-s.wl,s.wl+s.wr,s.ymx+2);y_set(s.st,false,s.x-s.wl,s.wl+s.wr,s.ymn-2)continuecase C.NOTE:break}if(s.stem>0){if(s.stemless){dx=-5;w=10}else if(s.beam_st){dx=3;w=s.beam_end?4:10}else{dx=-8;w=s.beam_end?11:16}y_set(s.st,true,s.x+dx,w,s.ymx);ymn=s.ymnif(s.notes[0].acc&&ymn>3*(s.notes[0].pit-18)-9)ymn=3*(s.notes[0].pit-18)-9y_set(s.st,false,s.x-s.wl,s.wl+s.wr,ymn)}else{y_set(s.st,true,s.x-s.wl,s.wl+s.wr,s.ymx);if(s.stemless){dx=-5;w=10}else if(s.beam_st){dx=-6;w=s.beam_end?4:10}else{dx=-8;w=s.beam_end?5:16}dx+=s.notes[0].shhd;y_set(s.st,false,s.x+dx,w,s.ymn)}if(s.notes[s.nhd].acc){y=3*(s.notes[s.nhd].pit-18)+(s.notes[s.nhd].acc==-1?11:10)y_set(s.st,true,s.x-10,10,y)}if(s.notes[0].acc){y=3*(s.notes[0].pit-18)-(s.notes[0].acc==-1?5:10)y_set(s.st,false,s.x-10,10,y)}}draw_deco_note()for(v=0;v<voice_tb.length;v++){p_voice=voice_tb[v];s=p_voice.symif(!s)continueset_color(s.color);st=p_voice.st;for(;s;s=s.next){if(s.play)continueif(s.tp)draw_tuplet(s)if(s.sls||s.sl1)draw_slurs(s)}}set_color()for(st=0;st<=nstaff;st++){p_st=staff_tb[st];top=p_st.topbar+2;bot=p_st.botbar-2for(i=0;i<YSTEP;i++){if(top>p_st.top[i])p_st.top[i]=topif(bot<p_st.bot[i])p_st.bot[i]=bot}}if(cfmt.measurenb>=0)draw_measnb();set_dscale(-1)for(v=0;v<voice_tb.length;v++){p_voice=voice_tb[v]if(p_voice.have_ly){draw_all_lyrics()break}}draw_deco_staff()draw_partempo()set_dscale(-1);output=output_sav}function draw_vname(indent,stl){var p_voice,n,st,v,a_p,p,y,h,h2,staff_d=[]for(st=stl.length;st>=0;st--){if(stl[st])break}if(st<0)returnfor(v=0;v<voice_tb.length;v++){p_voice=voice_tb[v]if(!cur_sy.voices[v])continuest=cur_sy.voices[v].stif(!stl[st])continueif(!gene.vnt)continuep=gene.vnt==2?p_voice.nm:p_voice.snmif(!p)continuedelete p_voice.new_nameif(!staff_d[st])staff_d[st]=pelsestaff_d[st]+="\n"+p}if(!staff_d.length)returnset_font("voice");h=gene.curfont.sizeh2=h/2indent=-indent*.5for(st=0;st<staff_d.length;st++){if(!staff_d[st])continuea_p=staff_d[st].split("\n");y=staff_tb[st].y+staff_tb[st].topbar*.5*staff_tb[st].staffscale+h2*(a_p.length-2)if((cur_sy.staves[st].flags&OPEN_BRACE)&&st+1<staff_tb.length&&(cur_sy.staves[st+1].flags&CLOSE_BRACE)&&!staff_d[st+1])y-=(staff_tb[st].y-staff_tb[st+1].y)*.5for(n=0;n<a_p.length;n++){p=a_p[n];xy_str(indent,y,p,"c");y-=h}}}function set_staff(){var i,st,prev_staff,v,y,staffsep,dy,maxsep,mbot,val,p_voice,p_staff,fmt=tsfirst.fmt,sy=cur_syfor(v=0;v<voice_tb.length;v++){p_voice=voice_tb[v]if(p_voice.scale!=1)p_voice.scale_str='transform="scale('+p_voice.scale.toFixed(2)+')"'}for(st=0;st<=nstaff;st++){if(gene.st_print[st])break}y=0if(st>nstaff){st--;p_staff=staff_tb[st]}p_staff=staff_tb[st]for(i=0;i<YSTEP;i++){val=p_staff.top[i]if(y<val)y=val}y*=p_staff.staffscale;staffsep=fmt.staffsep*.5+p_staff.topbar*p_staff.staffscaleif(y<staffsep)y=staffsepif(y<p_staff.ann_top)y=p_staff.ann_top;p_staff.y=-y;for(prev_staff=0;prev_staff<st;prev_staff++)staff_tb[prev_staff].y=-yif(!gene.st_print[st])return yvar sy_staff_prev=sy.staves[prev_staff]for(st++;st<=nstaff;st++){if(!gene.st_print[st])continuep_staff=staff_tb[st]staffsep=sy_staff_prev.sep||cfmt.sysstaffsep;maxsep=sy_staff_prev.maxsep||cfmt.maxsysstaffsep;dy=0if(p_staff.staffscale==staff_tb[prev_staff].staffscale){for(i=0;i<YSTEP;i++){val=p_staff.top[i]-staff_tb[prev_staff].bot[i]if(dy<val)dy=val}dy*=p_staff.staffscale}else{for(i=0;i<YSTEP;i++){val=p_staff.top[i]*p_staff.staffscale-staff_tb[prev_staff].bot[i]*staff_tb[prev_staff].staffscaleif(dy<val)dy=val}}staffsep+=p_staff.topbar*p_staff.staffscaleif(dy<staffsep)dy=staffsep;maxsep+=p_staff.topbar*p_staff.staffscaleif(dy>maxsep)dy=maxsep;y+=dy;p_staff.y=-y;while(!gene.st_print[++prev_staff])staff_tb[prev_staff].y=-ywhile(1){sy_staff_prev=sy.staves[prev_staff]if(sy_staff_prev)breaksy=sy.next}}mbot=0for(i=0;i<YSTEP;i++){val=staff_tb[prev_staff].bot[i]if(mbot>val)mbot=val}if(mbot>p_staff.ann_bot)mbot=p_staff.ann_bot;mbot*=staff_tb[prev_staff].staffscalefor(st=0;st<=nstaff;st++){p_staff=staff_tb[st];dy=p_staff.yif(p_staff.staffscale!=1){p_staff.scale_str='transform="translate(0,'+(posy-dy).toFixed(1)+') '+'scale('+p_staff.staffscale.toFixed(2)+')"'}}if(mbot==0){for(st=nstaff;st>=0;st--){if(gene.st_print[st])break}if(st<0)return y}dy=-mbot;staffsep=fmt.staffsep*.5if(dy<staffsep)dy=staffsep;maxsep=fmt.maxstaffsep*.5if(dy>maxsep)dy=maxsep;return y+dy}function draw_systems(indent){var s,s2,st,x,x2,res,sy,xstaff=[],stl=[],bar_bot=[],bar_height=[],ba=[],sb="",thb=""function bar_set(){var st,staffscale,top,bot,dy=0for(st=0;st<=cur_sy.nstaff;st++){if(xstaff[st]<0){bar_bot[st]=bar_height[st]=0continue}staffscale=staff_tb[st].staffscale;top=staff_tb[st].topbar*staffscale;bot=staff_tb[st].botbar*staffscaleif(dy==0)dy=staff_tb[st].y+top;bar_bot[st]=staff_tb[st].y+bot;bar_height[st]=dy-bar_bot[st];dy=(cur_sy.staves[st].flags&STOP_BAR)?0:bar_bot[st]}}function draw_staff(st,x1,x2){var w,i,dy,ty,y=0,ln="",stafflines=staff_tb[st].stafflines,l=stafflines.length,il=6*staff_tb[st].staffscaleif(!/[\[|]/.test(stafflines))returnw=x2-x1;set_sscale(-1)if(cache&&cache.st_l==stafflines&&staff_tb[st].staffscale==1&&cache.st_w==(w|0)){xygl(x1,staff_tb[st].y,'stdef'+cfmt.fullsvg)return}for(i=0;i<l;i++,y-=il){if(stafflines[i]=='.')continuedy=0for(;i<l;i++,y-=il,dy-=il){switch(stafflines[i]){case'.':case'-':continuecase ty:ln+='m-'+w.toFixed(1)+' '+dy+'h'+w.toFixed(1);dy=0continue}if(ty!=undefined)ln+='"/>\n';ty=stafflines[i]ln+='<path class="'+(ty=='['?'slthW':'slW')+'" d="m0 '+y+'h'+w.toFixed(1);dy=0}ln+='"/>'}y=staff_tb[st].yif(!cache&&w>get_lwidth()-10&&staff_tb[st].staffscale==1){cache={st_l:stafflines,st_w:w|0}i='stdef'+cfmt.fullsvg;if(ln.indexOf('<path',1)<0)glyphs[i]=ln.replace('path','path id="'+i+'"')elseglyphs[i]='<g id="'+i+'">\n'+ln+'\n</g>';xygl(x1,y,i)return}out_XYAB('<g transform="translate(X, Y)">\n'+ln+'\n</g>\n',x1,y)}function draw_bar(s,bot,h){var i,s2,yb,w,bar_type=s.bar_type,st=s.st,p_staff=staff_tb[st],x=s.xif(st!=0&&s.ts_prev&&s.ts_prev.type!=C.BAR)h=p_staff.topbar*p_staff.staffscale;s.ymx=s.ymn+h;set_sscale(-1)anno_start(s)if(s.color)set_color(s.color);yb=p_staff.y+12;if(p_staff.stafflines!='|||||')yb+=(p_staff.topbar+p_staff.botbar)/2-12if(s.bar_mrep){set_sscale(st)if(s.bar_mrep==1){for(s2=s.prev;s2.type!=C.REST;s2=s2.prev);xygl(s2.x,yb,"mrep")}else{xygl(x,yb,"mrep2")if(s.v==cur_sy.top_voice)nrep_out(x,yb+p_staff.topbar,s.bar_mrep)}set_sscale(-1)}if(bar_type=='||:')bar_type='[|:'for(i=bar_type.length;--i>=0;){switch(bar_type[i]){case"|":if(s.bar_dotted){w=(5*p_staff.staffscale).toFixed(1);out_XYAB('<path class="bW" stroke-dasharray="A,A" d="MX Yv-G"/>\n',x,bot,w,h)}else if(s.color){out_XYAB('<path class="bW" d="MX Yv-F"/>\n',x,bot,h)}else{sb+='M'+sx(x).toFixed(1)+' '+self.sy(bot).toFixed(1)+'v-'+h.toFixed(1)}breakdefault:x-=3;if(s.color)out_XYAB('<path class="bthW" d="MX Yv-F"/>\n',x+1.5,bot,h)elsethb+='M'+sx(x+1.5).toFixed(1)+' '+self.sy(bot).toFixed(1)+'v-'+h.toFixed(1)breakcase":":x-=2;set_sscale(st);xygl(x+1,yb-12,"rdots")set_sscale(-1)break}x-=3}set_color();anno_stop(s)}function out_bars(){var i,b,bx,l=ba.lengthset_font("annotation");bx=gene.curfont.boxif(bx)gene.curfont.box=0for(i=0;i<l;i++){b=ba[i];draw_bar(b[0],b[1],b[2])}if(bx)gene.curfont.box=bxset_sscale(-1)if(sb)output+='<path class="bW" d="'+sb+'"/>\n'if(thb)output+='<path class="bthW" d="'+thb+'"/>\n'}function hl_rest(s){var j,p_st=staff_tb[s.st],i=5-s.nflags,x=s.x,y=s.yif(i<6)returnif(i==7&&y==12&&p_st.stafflines.length<=2)y-=6j=y/6switch(i){default:switch(p_st.stafflines[j+1]){case'|':case'[':breakdefault:set_hl(p_st,j+1,x,-7,7)break}if(i==9){y-=6j--}breakcase 7:y+=6j++case 6:break}switch(p_st.stafflines[j]){case'|':case'[':breakdefault:set_hl(p_st,j,x,-7,7)break}}function st1(st,s){var tim=s.timedo{s=s.ts_next}while(s.st!=st)while(s.prev&&s.prev.time>=tim)s=s.previf(s.bar_type)return s.xreturn s.x-s.wl}for(st=0;st<=nstaff;st++){stl[st]=cur_sy.st_print[st]xstaff[st]=!stl[st]?-1:0}bar_set();draw_lstaff(0)for(s=tsfirst;s;s=s.ts_next){switch(s.type){case C.STAVES:sy=s.syfor(st=0;st<=nstaff;st++){x=xstaff[st]if(x<0){if(sy.st_print[st]){xstaff[st]=st1(st,s)stl[st]=true}continue}if(sy.st_print[st]&&cur_sy.staves[st]&&sy.staves[st].stafflines==cur_sy.staves[st].stafflines)continueif(s.ts_prev.bar_type){x2=s.ts_prev.x}else{x2=(s.ts_prev.x+s.x)/2xstaff[st]=-1}draw_staff(st,x,x2)xstaff[st]=sy.st_print[st]?x2:-1}cur_sy=sy;bar_set()continuecase C.BAR:if(s.invis||!s.bar_type||!cur_sy.st_print[s.st])breakif(s.second&&(!s.ts_prev||(s.ts_prev.type==C.BAR&&s.ts_prev.st==s.st)))breakba.push([s,bar_bot[s.st],bar_height[s.st]])breakcase C.STBRK:if(cur_sy.voices[s.v]&&cur_sy.voices[s.v].range==0){if(s.xmx>14){var nv=0for(var i=0;i<voice_tb.length;i++){if(cur_sy.voices[i]&&cur_sy.voices[i].range>0)nv++}for(s2=s.ts_next;s2;s2=s2.ts_next){if(s2.type!=C.STBRK)breaknv--}if(nv==0)draw_lstaff(s.x)}}st=s.st;x=xstaff[st]if(x>=0){s2=s.previf(!s2)breakx2=s2.type==C.BAR?s2.x:s.x-s.xmxif(x>=x2)breakdraw_staff(st,x,x2)xstaff[st]=s.x}breakcase C.GRACE:for(s2=s.extra;s2;s2=s2.next)self.draw_hl(s2)breakcase C.NOTE:if(!s.invis)self.draw_hl(s)breakcase C.REST:if(s.fmr||(s.rep_nb&&s.rep_nb>=0))center_rest(s)if(!s.invis)hl_rest(s)break}}for(st=0;st<=nstaff;st++){x=xstaff[st]if(x<0||x>=realwidth)continuedraw_staff(st,x,realwidth)}draw_all_hl()out_bars()draw_vname(indent,stl)}Abc.prototype.draw_symbols=function(p_voice){var bm={},s,x,y,st;for(s=p_voice.sym;s;s=s.next){if(s.invis){switch(s.type){case C.CLEF:if(s.time>=staff_tb[s.st].clef.time)staff_tb[s.st].clef=scontinuecase C.KEY:p_voice.ckey=sdefault:continuecase C.NOTE:break}}st=s.stx=s.x;set_color(s.color)switch(s.type){case C.NOTE:set_scale(s)if(s.beam_st&&!s.beam_end){if(self.calculate_beam(bm,s))draw_beams(bm)}if(!s.invis){anno_start(s);draw_note(s,!bm.s2);anno_a.push(s)}if(s==bm.s2)bm.s2=nullbreakcase C.REST:if(!gene.st_print[st])breakdraw_rest(s);breakcase C.BAR:breakcase C.CLEF:if(s.time>=staff_tb[st].clef.time)staff_tb[st].clef=sif(s.second||!staff_tb[st].topbar||!gene.st_print[st])breakset_color();set_sscale(st);anno_start(s);y=staff_tb[st].yif(s.clef_name)xygl(x,y+s.y,s.clef_name)else if(!s.clef_small)xygl(x,y+s.y,s.clef_type+"clef")elsexygl(x,y+s.y,"s"+s.clef_type+"clef")if(s.clef_octave){if(s.clef_octave>0){y+=s.ymx-10if(s.clef_small)y-=1}else{y+=s.ymn+6if(s.clef_small)y+=1}xygl(x-2,y,(s.clef_octave==7||s.clef_octave==-7)?"oct":"oct2")}anno_a.push(s)breakcase C.METER:p_voice.meter=sif(s.second||!staff_tb[s.st].topbar)breakset_color();set_sscale(s.st);anno_start(s);draw_meter(s);anno_a.push(s)breakcase C.KEY:p_voice.ckey=sif(s.second||!staff_tb[s.st].topbar)breakset_color();set_sscale(s.st);anno_start(s);self.draw_keysig(x,s);anno_a.push(s)breakcase C.MREST:draw_mrest(s)breakcase C.GRACE:set_scale(s);draw_gracenotes(s)breakcase C.SPACE:case C.STBRK:breakcase C.CUSTOS:set_scale(s);draw_note(s,0)breakcase C.BLOCK:case C.REMARK:case C.STAVES:case C.TEMPO:breakdefault:error(2,s,"draw_symbols - Cannot draw symbol "+s.type)break}}set_scale(p_voice.sym)}function draw_all_sym(){var p_voice,v,n=voice_tb.lengthfunction draw_sl2(){var i,a,d,dy,dy2,dy2o,dz,n,slwhile(1){sl=gene.a_sl.shift()if(!sl)breaki=sl[3].indexOf('d="M')+4output+=sl[3].slice(0,i)a=new Float32Array(sl[3].slice(i).match(/[\d.-]+/g))a[1]-=staff_tb[sl[0].st].ydy2o=sl[0].fmt.sysstaffsep+24dy2=staff_tb[sl[1].st].y-staff_tb[sl[0].st].yswitch(sl[2]){case"//":case"\\\\":d=-(sl[1].prev.prev.y+staff_tb[sl[0].st].y+sl[1].prev.next.y+staff_tb[sl[1].st].y)-2*(a[1]-posy)a[5]=d-a[5]a[7]=d-a[7]if(a.length>8){d=sl[2][0]=='/'?3:-3a[8]=-a[8]a[10]=-a[3]+da[12]=-a[5]+da[14]=-a[7]}breakcase"/\\":case"\\/":d=sl[2][0]=='/'?dy2-dy2o-10:dy2+dy2o+10a[3]+=da[5]+=dif(a.length>8){a[10]+=da[12]+=d}breakdefault:d=sl[2][0]=='/'?dy2-dy2o:-dy2-dy2oa[5]+=da[7]+=dif(a.length>8){a[12]-=da[14]-=d}break}output+=a[0].toFixed(1)+' '+a[1].toFixed(1)+'c'+a[2].toFixed(1)+' '+a[3].toFixed(1)+' '+a[4].toFixed(1)+' '+a[5].toFixed(1)+' '+a[6].toFixed(1)+' '+a[7].toFixed(1)if(a.length>8)output+='v'+a[8].toFixed(1)+'c'+a[9].toFixed(1)+' '+a[10].toFixed(1)+' '+a[11].toFixed(1)+' '+a[12].toFixed(1)+' '+a[13].toFixed(1)+' '+a[14].toFixed(1)output+='"/>\n'}}for(v=0;v<n;v++){p_voice=voice_tb[v]if(p_voice.sym&&p_voice.sym.x!=undefined){self.draw_symbols(p_voice)draw_all_ties(p_voice);set_color()}}self.draw_all_deco()glout()anno_put()set_sscale(-1)if(gene.a_sl)draw_sl2()}function set_tie_dir(s){var i,ntie,dir,sec,pit,ty,s2for(;s;s=s.next){if(!s.ti1)continuesec=ntie=0;pit=128for(i=0;i<=s.nhd;i++){if(s.notes[i].tie_ty){ntie++if(pit<128&&s.notes[i].pit<=pit+1)sec++;pit=s.notes[i].pits2=s.notes[i].tie_e}}if(s2&&s.stem*s2.stem<0)dir=pit>=22?C.SL_ABOVE:C.SL_BELOWelse if(s.multi)dir=s.multi>0?C.SL_ABOVE:C.SL_BELOWelsedir=s.stem<0?C.SL_ABOVE:C.SL_BELOWif(s.multi){for(i=0;i<=s.nhd;i++){ty=s.notes[i].tie_tyif(!((ty&0x07)==C.SL_AUTO))continues.notes[i].tie_ty=(ty&C.SL_DOTTED)|dir}continue}if(ntie<=1){for(i=0;i<=s.nhd;i++){ty=s.notes[i].tie_tyif(ty){if((ty&0x07)==C.SL_AUTO)s.notes[i].tie_ty=(ty&C.SL_DOTTED)|dirbreak}}continue}if(!sec){if(ntie&1){ntie=(ntie-1)/2;dir=C.SL_BELOWfor(i=0;i<=s.nhd;i++){ty=s.notes[i].tie_tyif(!ty)continueif(ntie==0){if(s.notes[i].pit>=22)dir=C.SL_ABOVE}if((ty&0x07)==C.SL_AUTO)s.notes[i].tie_ty=(ty&C.SL_DOTTED)|dirif(ntie--==0)dir=C.SL_ABOVE}continue}ntie/=2;dir=C.SL_BELOWfor(i=0;i<=s.nhd;i++){ty=s.notes[i].tie_tyif(!ty)continueif((ty&0x07)==C.SL_AUTO)s.notes[i].tie_ty=(ty&C.SL_DOTTED)|dirif(--ntie==0)dir=C.SL_ABOVE}continue}pit=128for(i=0;i<=s.nhd;i++){if(s.notes[i].tie_ty){if(pit<128&&s.notes[i].pit<=pit+1){ntie=ibreak}pit=s.notes[i].pit}}dir=C.SL_BELOWfor(i=0;i<=s.nhd;i++){ty=s.notes[i].tie_tyif(!ty)continueif(ntie==i)dir=C.SL_ABOVEif((ty&0x07)==C.SL_AUTO)s.notes[i].tie_ty=(ty&C.SL_DOTTED)|dir}}}function set_tie_room(){var p_voice,s,s2,v,dx,y,dyfor(v=0;v<voice_tb.length;v++){p_voice=voice_tb[v];s=p_voice.symif(!s)continues=s.nextif(!s)continueset_tie_dir(s)for(;s;s=s.next){if(!s.ti1)continueif(s.notes[0].pit<20&&s.notes[0].tie_ty&&(s.notes[0].tie_ty&0x07)==C.SL_BELOW);else if(s.notes[s.nhd].pit>24&&s.notes[s.nhd].tie_ty&&(s.notes[s.nhd].tie_ty&0x07)==C.SL_ABOVE);elsecontinues2=s.nextwhile(s2&&s2.type!=C.NOTE)s2=s2.nextif(s2){if(s2.st!=s.st)continuedx=s2.x-s.x-10}else{dx=realwidth-s.x-10}if(dx<100)dy=9else if(dx<300)dy=12elsedy=16if(s.notes[s.nhd].pit>24){y=3*(s.notes[s.nhd].pit-18)+dyif(s.ymx<y)s.ymx=yif(s2&&s2.ymx<y)s2.ymx=y;y_set(s.st,true,s.x+5,dx,y)}if(s.notes[0].pit<20){y=3*(s.notes[0].pit-18)-dyif(s.ymn>y)s.ymn=yif(s2&&s2.ymn>y)s2.ymn=y;y_set(s.st,false,s.x+5,dx,y)}}}}var musicfont='url("data:application/octet-stream;base64,\AAEAAAAOAIAAAwBgRkZUTZHVOuoAAFgMAAAAHEdERUYAFQAUAABX8AAAABxPUy8yWMFdCgAAAWgA\AABWY21hcHlUuFMAAAQIAAAD5mN2dCAAIgKIAAAH8AAAAARnYXNw//8AAwAAV+gAAAAIZ2x5ZqUq\QgUAAAkcAABF/GhlYWQVmDJzAAAA7AAAADZoaGVhCWn/GwAAASQAAAAkaG10eNm9+0EAAAHAAAAC\SGxvY2HHqraAAAAH9AAAASZtYXhwANkBEgAAAUgAAAAgbmFtZeq7sB0AAE8YAAADFXBvc3SIfxKM\AABSMAAABbUAAQAAAAEAANGbj/xfDzz1AAsEAAAAAADRlyIXAAAAAOBezej/OPzvBUsEiAAAAAgA\AgAAAAAAAAABAAAEiPzvAFwEJf84/XQFSwABAAAAAAAAAAAAAAAAAAAAkgABAAAAkgDhAAUAAAAA\AAIAAAABAAEAAABAAC4AAAAAAAEBgAGQAAUACAKZAswAAACPApkCzAAAAesAMwEJAAACAAUDAAAA\AAAAAAAAARAAAAAAAAAAAAAAAFBmRWQAQAAA7LcDOP84AFwEiAMRAAAAAQAAAAAAAAF2ACIAAAAA\AVUAAAGQAAACWAAAAFcAAAAjAAAAJQAAACT//wBkAAAEIwAABCUAAAHg/9wDugAAAwsAAALSAAAC\v/+6AdYAAAMLAAADDgAAAyf/yADIAAABaAAAAa4AAAEiAAABkAAAAXwAAAGQAAABkAAAAYEAAAGQ\AAABkAAAAYEAAAGZAAkBmAAJAfQAAAEEABQBBAAKAmsAJAISAAABwgAAAUIAAAFAAAABSv/+ASwA\AAIwAAABSgAAAUoAAABkAAABQAAAAUAAAAFAAAABQAAAAGQAAAE2AAAA5gAAATYAAAE7AAABOwAA\ATsAAAE7AAABOwAAATsAAAE7AAABOwAAATsAAAE7AAABDQAAAMgAAAD/AAABCwAUAW4AAACMAAAA\jAAAAQ0AMgFu//UAqQAAAToAAAFA//0AUAAAAVQAAABkAAABGAAAAlgAAAC2AAABkAAFAIIAAACC\AAABLAAAASwAAADuAAAA/wAAAUkAAAGPAAAB2AAAAdgAAAIz//ADIP/hAXv/tAG4/9sBFv9+ARP/\2wDcAAAA6P/kAr//tAIz/7QCv/+0Ayv/2wFf/9sCaf9+AV//fgJp/34BXwAAAf0ABQG1AAABtQAA\AkQADQJEAA0BGAAAATYAAAEs//8BLAAAAPoAAADIAAABGP84APoAAADIAAAEDQAAAhwADAH0AAAB\9AAAAfQAAAH0AAAB9AAAAfQAAAB4AAAALQAAAhwAAAD6AAAA+v/oAcIAAAFIAAABQAAAAgoAAAIK\AAAAZAAAAAAAAwAAAAMAAAAcAAEAAAAAAuAAAwABAAAAHAAEAsQAAABgAEAABQAgAAAAIOAA4DDg\OeBI4FDgXOBi4GngjOCV4KTgqeCz4QHhu+Hn4gDiSeJk4mvig+Ss5MDk0eTq5QHlMeU55W3lguXQ\5eLmGOYk5jDmUOZV6RjpIOkl6V3qAuqk7Knst///AAAAAAAg4ADgMOA44EPgUOBc4GLgaeB64JTg\oOCp4LPhAeG54efh8uJA4mDiauKA5KDkwOTO5OHlAOUg5TnlZuWC5dDl4uYQ5iTmMOZQ5lXpEOkg\6SXpXeoC6qTsouy3//8AA//kIAUf1gAAAAAfvh+zH64fqAAAAAAAAB+CH3kfLAAAHkkAAAAAAAAA\AAAAAAAbkwAAAAAAAAAAGzcAABr0GqcalgAAGlkaThovGisAABdnF2MXLBaIFecAABPaAAEAAAAA\AAAAAABYAFoAAAAAAAAAAABcAIAAggAAAAAAAACEAAAAhgCiALQAvAC+AMQAAADaAOAA8gD0AAAB\FAAAAAAAAAEcAAAAAAAAAAABJAAAAAAAAAAAAAABKgAAAAAABwAIAAkAAAAKAAsADAANABIAEwAU\ABUAFgAAABcAGAAZABoAGwAcAB0AHgAfACAAIQAiACMAJAAlACYAJwAoACkAKgAuAAAALwAxAAAA\MgAAAAAAMwAAADQAAAAAADUAAAA2ADcAOAA5ADoAOwA8AD0APgA/AEAAQQBCAEMARABFAEYARwBI\AEkASgBLAEwATQBOAAAATwAAAFAAAAAAAAAAUQAAAAAAAABSAFQAAAAAAFUAVgBXAFgAWQBaAFsA\XABdAF4AXwBgAGEAYgBjAGQAZQBmAGcAAAAAAAAAaABpAGoAawBsAAAAbQBuAG8AcQByAAAAcwAA\AAAAdAB1AHkAAAB6AAAAewAAAAAAAAB8AIEAggCDAAAAhACFAAAAAACGAIwAjQAAAI4AAACPAAAA\kAAAAQYAAAMAAAAAAAAAAQIAAAACAAAAAAAAAAAAAAAAAAAAAQAABAAAAAAAAAAAAAAAAAAAAAAA\AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA\AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAiAogAAAAqACoAKgA2AD4AbgB6\AIYAkgCwASQBgAHwAjQCwANSA7IDxgRkBPYFTgWOBhAGMgZGBpgG6AcIB04HjgfICBQIVAiaCPQJ\CAkuCVQJhgmiCcQJ7AoCChwKUgpgCmwKeAqKCqYKyArWCuoK/AsMC1gLaAuCC5wL1AwMDFoMpg0M\DW4N7A5kDooOpA7UDv4PVg9wD4oPsBAKECoQaBCQEKQQsBC+EM4Q9hEeEVYRYhFuEXoRhhGoEc4S\BBJSErITJhNME3oTzhRCFJYU1hUaFXAWihdiF/gYqhlsGf4a0BvkHNAdEh1WHaAduh3eHfIeBh42\HkYeWB50Hooerh7eH7ogdiCeILwg7iEsIV4hoCGyIcAh3CH2IhwiPiJsIoYisCLsIv4AAAACACIA\AAEyAqoAAwAHAC6xAQAvPLIHBADtMrEGBdw8sgMCAO0yALEDAC88sgUEAO0ysgcGAfw8sgECAO0y\MxEhESczESMiARDuzMwCqv1WIgJmAAABAAAAAAGRAZAAAwAAMREhEQGRAZD+cAABAAAAAAAAAAAA\AAAAMQAAAQAAAAAAVwQDACAAABE1NjU0JyY1NDcGFRQXFhUUBxYVFAcGFRQXJjU0NzY1NDUjElc/\FSVNTSUVP1cSIwIDAhhDNmA5NGY6MksiOWFNYRgYZkxgOSVKMjpmNDlgNkgAAQAAAAAAIwPoAAMA\ABEzESMjIwPo/BgAAQAAAfQAJQPoAAMAABEzESMlJQPo/gwAAf//A2QAJARgAAMAABEzByMkASQE\YPwAAgAAAUAAZAKeAAcADwAAEiImNDYyFhQCIiY0NjIWFEcqHR0qHR0qHR0qHQI6HSodHSr+6R0q\HR0qAAAABQAAAAAEJAGuAC8ANwA/AEcAUwAAITUzHgEzMjY1NCcuBDU0NjMyFhc3MxcjLgEjIgYV\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\VVc9ARVWTUQJHVVXPQEVVk1E/o4CrClId0QhGTk2KykrLC0nKywtJyssJUg9OjczORuqKUl4RAMN\BCldQ1SGKUl4RAMNBCldQ1SGKUl4RAMNBCldQ1QAAAAFAAD9VQE8AhIAJAAyAEAATgBcAAAZATMe\BhUUBxYVFAcWFRQHFhUUBxYVFAc2NTQuAyM1HgMXNDY1NC4DJx4DFzQ2NTQuAyceAxc0NjU0LgMn\HgMXNDY1NC4DHgYnMzs4LhwSEhISEhISEx4FKT5IQBYJRE1WFQEpPkhBFglETVYVASk+SEEWCURN\VhUBKT5IQRYJRE1WFQEpPkhB/rsDVxs5Mzc6PUglLCsnLSwrJy0sKyctLCspKzY5GSE3ZEU0GKsk\VENdKQMNBDdlRTMZqyRUQ10pBAwEN2VFMxmrJFRDXSkDDgM3ZUUzGaskVENdKQQMBDdlRTMZAAAF\AAD9vAE8AnkAIwAwAD0ASgBXAAAZATMyPgI1NCcWFRQHFhUUBxYVFAcWFRQHFhUUDgUHNTI+AjU0\JjUOAycyPgI1NCY1DgMnMj4CNTQmNQ4DJzI+AjU0JjUOAx4cVVc9BR4TEhISEhISEhwuODszJwYd\VVc9ARVWTUQJHVVXPQEVVk1ECR1VVz0BFVZNRAkdVVc9ARVWTUT9vANXKUh3RCEZOTYrKSssLScr\LC0nKywtJyssJUg9OjczORuqKUl4RAMNBCldQ1SGKUl4RAMNBCldQ1SGKUl4RAMNBCldQ1SGKUl4\RAMNBCldQ1QAAAACAAD/ZADhAbAACgAWAAA3IgYdATY3NjU0JjcyFhUUBwYjETMRNmcUKyImKx0H\IzlLUkQoI3omE7kPODsvGyYmMiNJTFICTP68NAAAAgAA/oYAxQF6AAMADAAAFzc1BxEVNxEjNQcR\NxyQkKkZrAFlLZYtAUnoNP3A4jMCQwEAAAIAAP6YAP8BaAADAB8AADcVNzUDIzUHNTc1BzU3NTMV\NzUzFTcVBxU3FQcVIzUHU1paHjU1NTUeWh01NTU1HVpGpxun/jejD1wPpw9aD6ifHKujD1wPpw9a\D6ifHAAAAAEAFP+EAQsAegAeAAAXNSYnBzAVIzUzNycwIzUzFRYXNzA1MxUjBgcXMDMVwygMM0g5\MzM5SCESNEg5IRM0OXw7Jg0zO0oyMkg5IhEzOUciETRIAAQAAP9qAWwBsAAOABwAKwA6AAA3DgEd\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\ICAfGR0bIsoMKCggIB8ZHRsiygwoKCAgHxkdGyLLCQQpKB8gHhkdG00CAvtuDAAAAAEAAP0MAhkC\rgBWAAAlBiMiJjU0NjMyFhUUBzI/AQYjIiY1NDYzMhYVFAcyPwEiDgEjIiY1NDYzMhYVFAcyNzYy\FwEnEwYjIiY1NDYzMhYVFAcyPwEGIyImNTQ2MzIWFRQHMjcBPyghKzcnGxwpF0ELNigfKzcnGxwp\Fz8LNAEgHBMrNycbHCkXSC4BFgP+ai1VKCErNycbHCkXQQs6KCErNycbHCkXQQs0DCgoICAfGR0b\IsQMKCggIB8ZHRsixwkEKSgfIB4ZHRtNAgL6gAwBJAwoKCAgHxkdGyLIDCgoICAfGR0bIgAD//D/\BgImAPoABwAPABMAADYiJjQ2MhYUACImNDYyFhQFATMBUDIjIzIjAYgyIyMyI/3SAbh+/kdLIzIj\IzL+zyMyIyMyWgH0/gwABP/h/wYDBwD6AAcADwATABcAADYiJjQ2MhYUACImNDYyFhQFATMBMwEz\AUEyIyMyIwJ3MiMjMiP84wG4e/5HeQG4e/5HSyMyIyMy/s8jMiMjMloB9P4MAfT+DAAC/7T/iAF8\ARgAEQA7AAA3FjMyNjc2NTQnJiMiBgcGFRQXIicHMzIUKwEiNDsBEzY1NCMiDgMHBiY3Njc2MzIW\Fz4BMzIWFRQGxQIFEjIODQ8CBBI1Cw8nKhktNAsL4QsLS2gGCwgMDwsZCgUbBTEPFyUjJAcdJiMe\LVkoATUkICYlBQEzHCckKS4geh4eAR0SDA8HFBIsEAgPCVgQGRMaHg80MElrAAAB/9v/9gG+ARgA\UwAANwYHBisBIj8BNiYjIgYHBiY3PgMzMhc2MzIXPgEzMhYVFA8BBhUUMzI3PgU3NhYHDgIjIiY1\ND8BNjU0IyIPAQYHJwYmPwE2NTQjIgdQBwgEBDUNDUIEBggNFiQFFQQUECIfEjcLJCQtCQspExkk\BS8ECAEEBQsHDAMNAQYVBhIXLR8VGQU0ARUbCEEIDyYNCARDARUbCBURAwEapw0PGjkIDAklGjAS\KCgoEBgjGgsPfQsJDgIDCQYPBRIBCQ0LHx8aFhMNDYgCBA4UqxYBAQEPCKsCBA4UAAAAAf9+/2AB\XgG4AEEAAAciJjU0NjMyFhUUBwYVFDMyPgc3IyI1NDsBPgEzMhYVFAYjIiY1NDc2NCMiDgcHMzIU\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\AwGbFGk0IDAXExIXEgoZBwwKBwgFBgMGATYUFD8hdl8gMBcTEhcSChkLEA8LDQoPDRTmxcEmIBoi\FA8OCwcNDgYREyUkPDdVJxUTS18mIBoiFA8OCwYccwwGAUtfJiAaIhQPDgsGHAULChQNGg0eBijF\wSYgGiIUDw4LBw0OBhETJSQ8N1UAAAAB/37/YAN0AbgAqgAAEzM+ATMyFhUUBiMiJjU0NzY0IyIH\BgcXPgEzMhYVFAYjIiY1NDc2NCMiDgcHMzIUKwEOASMiJjU0NjMyFhUUBwYVFDMyPgc3Iw4BIyIm\NTQ2MzIWFRQHBhUUMzI+BzcjDgEjIiY1NDYzMhYVFAcGFRQzMj4HNyMiNTQ7AT4BMzIWFRQGIyIm\NTQ3NjQjIg4CBwbMnBRpNCAwFxMSFxIKGSYXAwGbFGk0IDAXExIXEgoZBwwKBwgFBgMGATYTEz8h\dl8gMBcTEhcSChkLEA8LDQoPDRQKmyF2XyAwFxMSFxIKGQsQDwsNCg4NFQqbIXZfIDAXExIXEgoZ\CxAPCw0KDg0UCjUTEUEUaTQgMBcTEhcSChkOFQ4IBgIBDktfJiAaIhQPDgsGHHMMBgFLXyYgGiIU\Dw4LBhwFCwoUDRoNHgYoxcEmIBoiFA8OCwcNDgYREyUkPDdVJ8XBJiAaIhQPDgsHDQ4GERMlJDs4\VSfFwSYgGiIUDw4LBw0OBhETJSQ8N1UnFRNLXyYgGiIUDw4LBhwTJyIbCgAB/37/YASAAbgA4AAA\ARc+ATMyFhUUBiMiJjU0NzY0IyIHBgcXPgEzMhYVFAYjIiY1NDc2NCMiDgcHMzIUKwEOASMiJjU0\NjMyFhUUBwYVFDMyPgc3Iw4BIyImNTQ2MzIWFRQHBhUUMzI+BzcjDgEjIiY1NDYzMhYVFAcGFRQz\Mj4HNyMOASMiJjU0NjMyFhUUBwYVFDMyPgc3IyI1NDsBPgEzMhYVFAYjIiY1NDc2NCMiBwYHFz4B\MzIWFRQGIyImNTQ3NjQjIg4HAdicFGk0IDAXExIXEgoZJhcDAZsUaTQgMBcTEhcSChkHDAoHCAUG\AwYBNhMTPyF2XyAwFxMSFxIKGQsQDwsNCg8NFAqbIXZfIDAXExIXEgoZCxAPCw0KDg0UCpshdl8g\MBcTEhcSChkLEA8LDQoPDRQKmyF2XyAwFxMSFxIKGQsQDwsNCg4NFAo1ExFBFGk0IDAXExIXEgoZ\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\Abn+b0ZpOCdFahwBTu81XEdOdUlIckFJ7wAAAAACAAD/eQILAqgAHwAoAAAlNREzHgQVFAcWFRQH\NjU0JiMRFAYjIiY1NDYzMhMeARc0NjU0JgEiHgkwODYjFRYiBXY4eVkyPHpYMT0OhRsBdmvmAVck\RztCWDMlMjAkLkEZIV+e/tZGaTgnRWoBdjuiNQMOA1+fAAABAAD/zgBkADIABwAAFiImNDYyFhRH\Kh0dKh0yHSodHSoAAAAAAA4ArgABAAAAAAAAAIMBCAABAAAAAAABAAcBnAABAAAAAAACAAcBtAAB\AAAAAAADAB8B/AABAAAAAAAEAAcCLAABAAAAAAAFAAgCRgABAAAAAAAGAAcCXwADAAEECQAAAQYA\AAADAAEECQABAA4BjAADAAEECQACAA4BpAADAAEECQADAD4BvAADAAEECQAEAA4CHAADAAEECQAF\ABACNAADAAEECQAGAA4CTwBDAG8AcAB5AHIAaQBnAGgAdAAgAFwAMgA1ADEAIAAyADAAMQA4AC0A\MgAwADEAOQAgAEoAZQBhAG4ALQBGAHIAYQBuAGMAbwBpAHMAIABNAG8AaQBuAGUALgAgAFQAaABp\AHMAIABmAG8AbgB0ACAAaQBzACAAbABpAGMAZQBuAHMAZQBkACAAdQBuAGQAZQByACAAdABoAGUA\IABTAEkATAAgAE8AcABlAG4AIABGAG8AbgB0ACAATABpAGMAZQBuAHMAZQAgAFwAKABoAHQAdABw\ADoALwAvAHMAYwByAGkAcAB0AHMALgBzAGkAbAAuAG8AcgBnAC8ATwBGAEwAXAApAC4AAENvcHly\aWdodCBcMjUxIDIwMTgtMjAxOSBKZWFuLUZyYW5jb2lzIE1vaW5lLiBUaGlzIGZvbnQgaXMgbGlj\ZW5zZWQgdW5kZXIgdGhlIFNJTCBPcGVuIEZvbnQgTGljZW5zZSBcKGh0dHA6Ly9zY3JpcHRzLnNp\bC5vcmcvT0ZMXCkuAABhAGIAYwAyAHMAdgBnAABhYmMyc3ZnAABSAGUAZwB1AGwAYQByAABSZWd1\bGFyAABGAG8AbgB0AEYAbwByAGcAZQAgADoAIABhAGIAYwAyAHMAdgBnACAAOgAgADEANAAtADQA\LQAyADAAMgAzAABGb250Rm9yZ2UgOiBhYmMyc3ZnIDogMTQtNC0yMDIzAABhAGIAYwAyAHMAdgBn\AABhYmMyc3ZnAABWAGUAcgBzAGkAbwBuACAAAFZlcnNpb24gAABhAGIAYwAyAHMAdgBnAABhYmMy\c3ZnAAAAAAACAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAJIAAAABAAIBAgADAQMBBAEF\AQYBBwEIAQkBCgELAQwBDQEOAQ8BEAERARIBEwEUARUBFgEXARgBGQEaARsBHAEdAR4BHwEgASEB\IgEjASQBJQEmAScBKAEpASoBKwEsAS0BLgEvATABMQEyATMBNAE1ATYBNwE4ATkBOgE7ATwBPQE+\AT8BQAFBAUIBQwFEAUUBRgFHAUgBSQFKAUsBTAFNAU4BTwFQAVEBUgFTAVQBVQFWAVcBWAFZAVoB\WwFcAV0BXgFfAWABYQFiAWMBZAFlAWYBZwFoAWkBagFrAWwBbQFuAW8BcAFxAXIBcwF0AXUBdgF3\AXgBeQF6AXsBfAF9AX4BfwGAAYEBggGDAYQBhQGGAYcBiAGJAYoBiwGMAY0BjgGPBi5ub2RlZgd1\bmlFMDAwB3VuaUUwMzAHdW5pRTAzOAd1bmlFMDM5B3VuaUUwNDMHdW5pRTA0NQd1bmlFMDQ2B3Vu\aUUwNDcHdW5pRTA0OAd1bmlFMDUwB3VuaUUwNUMHdW5pRTA2Mgd1bmlFMDY5B3VuaUUwN0EHdW5p\RTA3Qgd1bmlFMDdDB3VuaUUwN0QHdW5pRTA3RQd1bmlFMDgwB3VuaUUwODEHdW5pRTA4Mgd1bmlF\MDgzB3VuaUUwODQHdW5pRTA4NQd1bmlFMDg2B3VuaUUwODcHdW5pRTA4OAd1bmlFMDg5B3VuaUUw\OEEHdW5pRTA4Qgd1bmlFMDhDB3VuaUUwOTQHdW5pRTA5NQd1bmlFMEEwB3VuaUUwQTEHdW5pRTBB\Mgd1bmlFMEEzB3VuaUUwQTQHdW5pRTBBOQd1bmlFMEIzB3VuaUUxMDEHdW5pRTFCOQd1bmlFMUJC\B3VuaUUxRTcHdW5pRTFGMgd1bmlFMUY0B3VuaUUxRjcHdW5pRTFGOQd1bmlFMUZDB3VuaUUxRkUH\dW5pRTFGRgd1bmlFMjAwB3VuaUUyNDAHdW5pRTI0MQd1bmlFMjQyB3VuaUUyNDMHdW5pRTI0NAd1\bmlFMjQ1B3VuaUUyNDYHdW5pRTI0Nwd1bmlFMjQ4B3VuaUUyNDkHdW5pRTI2MAd1bmlFMjYxB3Vu\aUUyNjIHdW5pRTI2Mwd1bmlFMjY0B3VuaUUyNmEHdW5pRTI2Ygd1bmlFMjgwB3VuaUUyODEHdW5p\RTI4Mgd1bmlFMjgzB3VuaUU0QTAHdW5pRTRBMgd1bmlFNEE0B3VuaUU0QTgHdW5pRTRBQwd1bmlF\NEMwB3VuaUU0Q0UHdW5pRTREMQd1bmlFNEUxB3VuaUU0RTIHdW5pRTRFMwd1bmlFNEU0B3VuaUU0\RTUHdW5pRTRFNgd1bmlFNEU3B3VuaUU0RTgHdW5pRTRFOQd1bmlFNEVBB3VuaUU1MDAHdW5pRTUw\MQd1bmlFNTIwB3VuaUU1MjEHdW5pRTUyMgd1bmlFNTIzB3VuaUU1MjQHdW5pRTUyNQd1bmlFNTI5\B3VuaUU1MkEHdW5pRTUyQgd1bmlFNTJDB3VuaUU1MkQHdW5pRTUyRgd1bmlFNTMwB3VuaUU1MzEH\dW5pRTUzOQd1bmlFNTY2B3VuaUU1NjcHdW5pRTU2OQd1bmlFNTZDB3VuaUU1NkQHdW5pRTU4Mgd1\bmlFNUQwB3VuaUU1RTIHdW5pRTYxMAd1bmlFNjEyB3VuaUU2MTQHdW5pRTYxOAd1bmlFNjI0B3Vu\aUU2MzAHdW5pRTY1MAd1bmlFNjU1B3VuaUU5MTAHdW5pRTkxMQd1bmlFOTEyB3VuaUU5MTQHdW5p\RTkxNQd1bmlFOTE4B3VuaUU5MjAHdW5pRTkyNQd1bmlFOTVEB3VuaUVBMDIHdW5pRUFBNAd1bmlF\Q0EyB3VuaUVDQTMHdW5pRUNBNQd1bmlFQ0E3B3VuaUVDQTkHdW5pRUNCNwAAAAAAAAH//wACAAEA\AAAAAAAADAAUAAQAAAACAAAAAQAAAAEAAAAAAAEAAAAA399K6gAAAADRlyIXAAAAAOBezeg=\") format("truetype")'var font_scale_tb={serif:1,serifBold:1,'sans-serif':1,'sans-serifBold':1,Palatino:1.1,monospace:1.35},txt_ff="text,serif",fmt_lock={}var cfmt={"abc-version":"1",annotationfont:{name:"text,sans-serif",size:12},aligncomposer:1,beamslope:.4,bardef:{"[":"","[]":"","|:":"[|:","|::":"[|::","|:::":"[|:::",":|":":|]","::|":"::|]",":::|":":::|]","::":":][:"},breaklimit:.7,breakoneoln:true,cancelkey:true,composerfont:{name:txt_ff,style:"italic",size:14},composerspace:6,decoerr:true,dynalign:true,footerfont:{name:txt_ff,size:16},fullsvg:'',gchordfont:{name:"text,sans-serif",size:12},gracespace:new Float32Array([6,8,11]),graceslurs:true,headerfont:{name:txt_ff,size:16},historyfont:{name:txt_ff,size:16},hyphencont:true,indent:0,infofont:{name:txt_ff,style:"italic",size:14},infoname:'R "Rhythm: "\n\B "Book: "\n\S "Source: "\n\D "Discography: "\n\N "Notes: "\n\Z "Transcription: "\n\H "History: "',infospace:0,keywarn:true,leftmargin:1.4*CM,lineskipfac:1.1,linewarn:true,maxshrink:.65,maxstaffsep:2000,maxsysstaffsep:2000,measrepnb:1,measurefont:{name:txt_ff,style:"italic",size:10},measurenb:-1,musicfont:{name:"music",src:musicfont,size:24},musicspace:6,partsfont:{name:txt_ff,size:15},parskipfac:.4,partsspace:8,pagewidth:21*CM,"propagate-accidentals":"o",printmargin:0,rightmargin:1.4*CM,rbmax:4,rbmin:2,repeatfont:{name:txt_ff,size:9},scale:1,slurheight:1.0,spatab:new Float32Array([10.2,13.3,17.3,22.48,29.2,38,49.4,64.2,83.5,108.5]),staffsep:46,stemheight:21,stretchlast:.25,stretchstaff:true,subtitlefont:{name:txt_ff,size:16},subtitlespace:3,sysstaffsep:34,tempofont:{name:txt_ff,weight:"bold",size:12},textfont:{name:txt_ff,size:16},textspace:14,tieheight:1.0,titlefont:{name:txt_ff,size:20},titlespace:6,titletrim:true,topspace:22,tuplets:[0,0,0,0],tupletfont:{name:txt_ff,style:"italic",size:12},vocalfont:{name:txt_ff,weight:"bold",size:13},vocalspace:10,voicefont:{name:txt_ff,weight:"bold",size:13},writefields:"CMOPQsTWw",wordsfont:{name:txt_ff,size:16},wordsspace:5,"writeout-accidentals":"n"}var sfmt={bardef:true,barsperstaff:true,beamslope:true,breaklimit:true,bstemdown:true,cancelkey:true,dynalign:true,flatbeams:true,gracespace:true,hyphencont:true,keywarn:true,maxshrink:true,maxstaffsep:true,measrepnb:true,rbmax:true,rbmin:true,shiftunison:true,slurheight:true,squarebreve:true,staffsep:true,stemheight:true,stretchlast:true,stretchstaff:true,tieheight:true,timewarn:true,vocalspace:true}function get_bool(param){return!param||!/^(0|n|f)/i.test(param)}function get_font_scale(param){var i,font,a=info_split(param)if(a.length<=1)returnvar scale=+a[a.length-1]if(isNaN(scale)||scale<=0.5){syntax(1,"Bad scale value in %%font")return}font_scale_tb[a[0]]=scale}function set_font_fac(font){var scale=font_scale_tb[font.fname||font.name]if(!scale)scale=1.1;font.swfac=font.size*scale}function param_set_font(xxxfont,p){var font,n,a,ft2,kif(xxxfont[xxxfont.length-2]=='-'){n=xxxfont[xxxfont.length-1]if(n<'1'||n>'9')returnxxxfont="u"+n+"font"}font={}a=p.match(/\s+(no)?box(\s|$)/)if(a){if(a[1]){font.box=falsefont.pad=0}else{font.box=truefont.pad=2.5}p=p.replace(a[0],a[2])}a=p.match(/\s+padding=([\d.]+)(\s|$)/)if(a){font.pad=a[1]?+a[1]:0p=p.replace(a[0],a[2])}a=p.match(/\s+class=(.*?)(\s|$)/)if(a){font.class=a[1];p=p.replace(a[0],a[2])}a=p.match(/\s+wadj=(.*?)(\s|$)/)if(a){if(typeof document=="undefined")switch(a[1]){case'none':font.wadj=''breakcase'space':font.wadj='spacing'breakcase'glyph':font.wadj='spacingAndGlyphs'breakdefault:syntax(1,errs.bad_val,"%%"+xxxfont)break}p=p.replace(a[0],a[2])}a=p.match(/\s+([0-9.]+|\*)$/)if(a){if(a[1]!="*")font.size=+a[1]p=p.replace(a[0],"")}if(p[0]=='u'&&p.slice(0,4)=="url("){n=p.indexOf(')',1)if(n<0){syntax(1,"No end of url in font family")return}font.src=p.slice(0,n+1)font.fid=abc2svg.font_tb.lengthabc2svg.font_tb.push(font)font.name='ft'+font.fidp=p.replace(font.src,'')}a=p.match(/[- ]?[nN]ormal/)if(a){font.normal=truep=p.replace(a[0],'')}a=p.match(abc2svg.ft_re)if(a){font.weight=abc2svg.ft_w[a[0].replace(/[ -]/,'').toLowerCase()]p=p.replace(a[0],'')}a=p.match(/[- ]?[iI]talic/)if(a){font.style="italic"p=p.replace(a[0],'')}a=p.match(/[- ]?[oO]blique/)if(a){font.style="oblique"p=p.replace(a[0],'')}if(!font.src){if(p[0]=='"'){n=p.indexOf('"',1)if(n<0){syntax(1,"No end of string in font family")return}p=p.slice(1,n)}p=p.trim()switch(p){case"":case"*":p="";breakcase"Times-Roman":case"Times":p="serif";breakcase"Helvetica":p="sans-serif";breakcase"Courier":p="monospace";breakcase"music":p=cfmt.musicfont.name;breakdefault:if(p.indexOf("Fig")>0)font.figb=truebreak}}if(p&&!font.name)font.name=pif(font.size)set_font_fac(font)if(!font.name||!font.size){ft2=cfmt[xxxfont]for(k in ft2){if(!ft2.hasOwnProperty(k)||font[k]!=undefined)continueswitch(k){case"fid":case"used":breakcase"style":case"weight":if(font.normal)breakdefault:font[k]=ft2[k]break}}if(!font.swfac)set_font_fac(font)}if(font.pad==undefined)font.pad=0font.fname=font.nameif(font.weight>=700)font.fname+='Bold'cfmt[xxxfont]=font}function get_unit(param){var v=param.toLowerCase().match(/(-?[\d.]+)(.*)/)if(!v)return NaNv[1]=+v[1]switch(v[2]){case"cm":return v[1]*CMcase"in":return v[1]*INcase"pt":return v[1]*.75case"px":case"":return v[1]}return NaN}function set_infoname(param){var tmp=cfmt.infoname.split("\n"),letter=param[0]for(var i=0;i<tmp.length;i++){var infoname=tmp[i]if(infoname[0]!=letter)continueif(param.length==1)tmp.splice(i,1)elsetmp[i]=paramcfmt.infoname=tmp.join('\n')return}cfmt.infoname+="\n"+param}var textopt={align:'j',center:'c',fill:'f',justify:'j',obeylines:'l',ragged:'f',right:'r',skip:'s',"0":'l',"1":'j',"2":'f',"3":'c',"4":'s',"5":'r'}function get_textopt(v){var i=v.indexOf(' ')if(i>0)v=v.slice(0,i)return textopt[v]}var posval={above:C.SL_ABOVE,auto:0,below:C.SL_BELOW,down:C.SL_BELOW,hidden:C.SL_HIDDEN,opposite:C.SL_HIDDEN,under:C.SL_BELOW,up:C.SL_ABOVE}function set_pos(k,v){k=k.slice(0,3)if(k=="ste")k="stm"set_v_param("pos",'"'+k+' '+v+'"')}function set_writefields(parm){var c,i,a=parm.split(/\s+/)if(get_bool(a[1])){for(i=0;i<a[0].length;i++){c=a[0][i]if(cfmt.writefields.indexOf(c)<0)cfmt.writefields+=c}}else{for(i=0;i<a[0].length;i++){c=a[0][i]if(cfmt.writefields.indexOf(c)>=0)cfmt.writefields=cfmt.writefields.replace(c,'')}}}function set_v_param(k,v){k=[k+'=',v]if(parse.state<3)memo_kv_parm(curvoice?curvoice.id:'*',k)else if(curvoice)set_kv_parm(k)elsememo_kv_parm('*',k)}function set_page(){if(!img.chg)returnimg.chg=false;img.lm=cfmt.leftmargin-cfmt.printmarginif(img.lm<0)img.lm=0;img.rm=cfmt.rightmargin-cfmt.printmarginif(img.rm<0)img.rm=0;img.width=cfmt.pagewidth-2*cfmt.printmarginif(img.width-img.lm-img.rm<100){error(0,undefined,"Bad staff width");img.width=img.lm+img.rm+150}img.lw=(img.width-img.lm-img.rm-2)/ cfmt.scaleset_posx()}Abc.prototype.set_format=function(cmd,param){var f,f2,v,iif(/.+font(-[\d])?$/.test(cmd)){if(cmd=="soundfont")cfmt.soundfont=paramelseparam_set_font(cmd,param)return}if(sfmt[cmd]&&parse.ufmt)cfmt=Object.create(cfmt)switch(cmd){case"aligncomposer":case"barsperstaff":case"infoline":case"measurenb":case"rbmax":case"rbmin":case"measrepnb":case"shiftunison":v=parseInt(param)if(isNaN(v)){syntax(1,"Bad integer value");break}cfmt[cmd]=vbreakcase"abc-version":case"bgcolor":case"fgcolor":case"propagate-accidentals":case"titleformat":case"writeout-accidentals":cfmt[cmd]=parambreakcase"beamslope":case"breaklimit":case"lineskipfac":case"maxshrink":case"pagescale":case"parskipfac":case"scale":case"slurheight":case"stemheight":case"tieheight":f=+paramif(isNaN(f)||!param||f<0){syntax(1,errs.bad_val,'%%'+cmd)break}switch(cmd){case"scale":f/=.75case"pagescale":if(f<.1)f=.1cmd="scale";img.chg=truebreak}cfmt[cmd]=fbreakcase"annotationbox":case"gchordbox":case"measurebox":case"partsbox":param_set_font(cmd.replace("box","font"),"* * "+(get_bool(param)?"box":"nobox"))breakcase"altchord":case"bstemdown":case"breakoneoln":case"cancelkey":case"checkbars":case"contbarnb":case"custos":case"decoerr":case"flatbeams":case"graceslurs":case"graceword":case"hyphencont":case"keywarn":case"linewarn":case"quiet":case"squarebreve":case"splittune":case"straightflags":case"stretchstaff":case"timewarn":case"titlecaps":case"titleleft":cfmt[cmd]=get_bool(param)breakcase"dblrepbar":param=":: "+paramcase"bardef":v=param.split(/\s+/)if(v.length!=2){syntax(1,errs.bad_val,"%%bardef")}else{if(parse.ufmt)cfmt.bardef=Object.create(cfmt.bardef)cfmt.bardef[v[0]]=v[1]}breakcase"chordalias":v=param.split(/\s+/)if(!v.length)syntax(1,errs.bad_val,"%%chordalias")elseabc2svg.ch_alias[v[0]]=v[1]||""breakcase"composerspace":case"indent":case"infospace":case"maxstaffsep":case"maxsysstaffsep":case"musicspace":case"partsspace":case"staffsep":case"subtitlespace":case"sysstaffsep":case"textspace":case"titlespace":case"topspace":case"vocalspace":case"wordsspace":f=get_unit(param)if(isNaN(f))syntax(1,errs.bad_val,'%%'+cmd)elsecfmt[cmd]=fbreakcase"page-format":user.page_format=get_bool(param)breakcase"print-leftmargin":syntax(0,"$1 is deprecated - use %%printmargin instead",'%%'+cmd)cmd="printmargin"case"printmargin":case"leftmargin":case"pagewidth":case"rightmargin":f=get_unit(param)if(isNaN(f)){syntax(1,errs.bad_val,'%%'+cmd)break}cfmt[cmd]=f;img.chg=truebreakcase"concert-score":if(cfmt.sound!="play")cfmt.sound="concert"breakcase"writefields":set_writefields(param)breakcase"volume":cmd="dynamic"case"dynamic":case"gchord":case"gstemdir":case"ornament":case"stemdir":case"vocal":set_pos(cmd,param)breakcase"font":get_font_scale(param)breakcase"fullsvg":if(parse.state!=0){syntax(1,errs.not_in_tune,"%%fullsvg")break}cfmt[cmd]=parambreakcase"gracespace":v=param.split(/\s+/)for(i=0;i<3;i++)if(isNaN(+v[i])){syntax(1,errs.bad_val,"%%gracespace")break}if(parse.ufmt)cfmt[cmd]=new Float32Array(3)for(i=0;i<3;i++)cfmt[cmd][i]=+v[i]breakcase"tuplets":v=param.split(/\s+/)f=v[3]if(f)f=posval[f]if(f)v[3]=fif(curvoice)curvoice.tup=velsecfmt[cmd]=vbreakcase"infoname":set_infoname(param)breakcase"notespacingfactor":v=param.match(/([.\d]+)[,\s]*(\d+)?/)if(v){f=+v[1]if(isNaN(f)||f<1||f>2){f=0}else if(v[2]){f2=+v[2]if(isNaN(f))f=0}else{f2=cfmt.spatab[5]}}if(!f){syntax(1,errs.bad_val,"%%"+cmd)break}cfmt[cmd]=paramcfmt.spatab=new Float32Array(10)i=5;do{cfmt.spatab[i]=f2f2/=f}while(--i>=0)i=5;f2=cfmt.spatab[i]for(;++i<cfmt.spatab.length;){f2*=f;cfmt.spatab[i]=f2}breakcase"play":cfmt.sound="play"breakcase"pos":cmd=param.match(/(\w*)\s+(.*)/)if(!cmd||!cmd[2]){syntax(1,"Error in %%pos")break}if(cmd[1].slice(0,3)=='tup'&&curvoice){if(!curvoice.tup)curvoice.tup=cfmt.tupletselsecurvoice.tup=Object.create(curvoice.tup)v=posval[cmd[2]]switch(v){case C.SL_ABOVE:curvoice.tup[3]=1breakcase C.SL_BELOW:curvoice.tup[3]=2breakcase C.SL_HIDDEN:curvoice.tup[2]=1break}break}if(cmd[1].slice(0,3)=="vol")cmd[1]="dyn"set_pos(cmd[1],cmd[2])breakcase"sounding-score":if(cfmt.sound!="play")cfmt.sound="sounding"breakcase"staffwidth":v=get_unit(param)if(isNaN(v)){syntax(1,errs.bad_val,'%%'+cmd)break}if(v<100){syntax(1,"%%staffwidth too small")break}v=cfmt.pagewidth-v-cfmt.leftmarginif(v<2){syntax(1,"%%staffwidth too big")break}cfmt.rightmargin=v;img.chg=truebreakcase"textoption":cfmt[cmd]=get_textopt(param)breakcase"dynalign":case"singleline":case"stretchlast":case"titletrim":v=+paramif(isNaN(v))v=get_bool(param)?0:1if(cmd[1]=='t'){if(v<0||v>1){syntax(1,errs.bad_val,'%%'+cmd)break}}cfmt[cmd]=vbreakcase"combinevoices":syntax(1,"%%combinevoices is deprecated - use %%voicecombine instead")breakcase"voicemap":set_v_param("map",param)breakcase"voicescale":set_v_param("scale",param)breakcase"rbdbstop":v=get_bool(param)if(v&&cfmt["abc-version"]>="2.2")cfmt["abc-version"]="1"else if(!v&&cfmt["abc-version"]<"2.2")cfmt["abc-version"]="2.2"breakdefault:if(!parse.state)cfmt[cmd]=parambreak}if(sfmt[cmd]&&parse.ufmt){parse.ufmt=false}}function st_font(font){var n=font.name,r=""if(font.weight)r+=font.weight+" "if(font.style)r+=font.style+" "if(n.indexOf('"')<0&&n.indexOf(' ')>0)n='"'+n+'"'return r+font.size.toFixed(1)+'px '+n}function style_font(font){return'font:'+st_font(font)}Abc.prototype.style_font=style_fontfunction font_class(font){var f='f'+font.fid+cfmt.fullsvgif(font.class)f+=' '+font.classif(font.box)f+=' '+'box'return f}function use_font(font){if(!font.used){font.used=true;if(font.fid==undefined){font.fid=abc2svg.font_tb.lengthabc2svg.font_tb.push(font)if(!font.swfac)set_font_fac(font)if(!font.pad)font.pad=0}add_fstyle(".f"+font.fid+(cfmt.fullsvg||"")+"{"+style_font(font)+"}")if(font.src)add_fstyle("@font-face{\n\ font-family:"+font.name+";\n\ src:"+font.src+"}")if(font==cfmt.musicfont)add_fstyle(".f"+font.fid+(cfmt.fullsvg||"")+' text,tspan{white-space:pre}')}}function get_font(fn){var font,font2,fid,stfn+="font"font=cfmt[fn]if(!font){syntax(1,"Unknown font $1",fn)return gene.curfont}if(!font.name||!font.size){font2=Object.create(gene.deffont)if(font.name)font2.name=font.nameif(font.normal){if(font2.weight)font2.weight=nullif(font2.style)font2.style=null}else{if(font.weight)font2.weight=font.weightif(font.style)font2.style=font.style}if(font.src)font2.src=font.srcif(font.size)font2.size=font.sizest=st_font(font2)if(font.class){font2.class=font.classst+=' '+font.class}fid=abc2svg.font_st[st]if(fid!=undefined)return abc2svg.font_tb[fid]abc2svg.font_st[st]=abc2svg.font_tb.lengthfont2.fid=font2.used=undefinedfont=font2}use_font(font)return font}var sav={},mac={},maci={},modone={}var abc_utf={"=D":"Ä","=H":"Ħ","=T":"Ŧ","=d":"Ä‘","=h":"ħ","=t":"ŧ","/O":"Ø","/o":"ø","/L":"Å","/l":"Å‚","vL":"Ľ","vl":"ľ","vd":"Ä",".i":"ı","AA":"Ã…","aa":"Ã¥","AE":"Æ","ae":"æ","DH":"Ã","dh":"ð","OE":"Å’","oe":"Å“","ss":"ß","TH":"Þ","th":"þ"}var oct_acc={"1":"\u266f","2":"\u266d","3":"\u266e","4":"𝄪","5":"𝄫"}function cnv_escape(src,flag){var c,c2,dst="",i,j=0while(1){i=src.indexOf('\\',j)if(i<0)breakdst+=src.slice(j,i);c=src[++i]if(!c)return dst+'\\'switch(c){case'0':case'2':if(src[i+1]!='0')breakc2=oct_acc[src[i+2]]if(c2){dst+=c2;j=i+3continue}breakcase'u':j=Number("0x"+src.slice(i+1,i+5));if(isNaN(j)||j<0x20){dst+=src[++i]+"\u0306"j=i+1continue}c=String.fromCharCode(j)if(c=='\\'){i+=4break}dst+=cj=i+5continuecase't':dst+='\t';j=i+1continuecase'n':dst+='\n';j=i+1continuedefault:c2=abc_utf[src.slice(i,i+2)]if(c2){dst+=c2;j=i+2continue}c2=src[i+1]if(!c2)breakif(!/[A-Za-z]/.test(c2))breakswitch(c){case'`':dst+=c2+"\u0300"j=i+2continuecase"'":dst+=c2+"\u0301"j=i+2continuecase'^':dst+=c2+"\u0302"j=i+2continuecase'~':dst+=c2+"\u0303"j=i+2continuecase'=':dst+=c2+"\u0304"j=i+2continuecase'_':dst+=c2+"\u0305"j=i+2continuecase'.':dst+=c2+"\u0307"j=i+2continuecase'"':dst+=c2+"\u0308"j=i+2continuecase'o':dst+=c2+"\u030a"j=i+2continuecase'H':dst+=c2+"\u030b"j=i+2continuecase'v':dst+=c2+"\u030c"j=i+2continuecase'c':dst+=c2+"\u0327"j=i+2continuecase';':dst+=c2+"\u0328"j=i+2continue}break}if(flag=='w')dst+='\\'dst+=cj=i+1}return dst+src.slice(j)}var include=0function do_include(fn){var file,parse_savif(!user.read_file){syntax(1,"No read_file support")return}if(include>2){syntax(1,"Too many include levels")return}file=user.read_file(fn)if(!file){syntax(1,"Cannot read file '$1'",fn)return}include++;parse_sav=clone(parse);tosvg(fn,file);parse_sav.state=parse.state;parse=parse_sav;include--}function tosvg(in_fname,file,bol,eof){var i,c,eol,end,select,line0,line1,last_info,opt,text,a,b,s,pscom,txt_add='\n'function tune_selected(){var re,res,i=file.indexOf('K:',bol)if(i<0){return false}i=file.indexOf('\n',i)if(parse.select.test(file.slice(parse.bol,i)))return truere=/\n\w*\n/;re.lastIndex=i;res=re.exec(file)if(res)eol=re.lastIndexelseeol=eofreturn false}function uncomment(src,flag){if(!src)return srcvar i=src.indexOf('%')if(i==0)return''if(i>0)src=src.replace(/([^\\])%.*/,'$1').replace(/\\%/g,'%');src=src.replace(/\s+$/,'')if(flag&&src.indexOf('\\')>=0)return cnv_escape(src,flag)return src}function end_tune(){generate()cfmt=sav.cfmt;info=sav.info;char_tb=sav.char_tb;glovar=sav.glovar;maps=sav.maps;mac=sav.mac;maci=sav.maci;parse.tune_v_opts=null;parse.scores=null;parse.ufmt=falsedelete parse.ctrlinit_tune()img.chg=true;set_page()}function do_voice(select,in_tune){var opt,bolif(select=="end")returnif(in_tune){if(!parse.tune_v_opts)parse.tune_v_opts={};opt=parse.tune_v_opts}else{if(!parse.voice_opts)parse.voice_opts={};opt=parse.voice_opts}opt[select]=[]while(1){bol=++eolif(file[bol]!='%')breakeol=file.indexOf('\n',eol);if(file[bol+1]!=line1)continuebol+=2if(eol<0)text=file.slice(bol)elsetext=file.slice(bol,eol);a=text.match(/\S+/)switch(a[0]){default:opt[select].push(uncomment(text,true))continuecase"score":case"staves":case"tune":case"voice":bol-=2break}break}eol=parse.eol=bol-1}function tune_filter(){var o,opts,j,pc,h,i=file.indexOf('K:',bol)i=file.indexOf('\n',i);h=file.slice(parse.bol,i)for(i in parse.tune_opts){if(!parse.tune_opts.hasOwnProperty(i))continueif(!(new RegExp(i)).test(h))continueopts=parse.tune_opts[i]for(j=0;j<opts.t_opts.length;j++){pc=opts.t_opts[j]switch(pc.match(/\S+/)[0]){case"score":case"staves":if(!parse.scores)parse.scores=[];parse.scores.push(pc)breakdefault:self.do_pscom(pc)break}}opts=opts.v_optsif(!opts)continuefor(j in opts){if(!opts.hasOwnProperty(j))continueif(!parse.tune_v_opts)parse.tune_v_opts={};if(!parse.tune_v_opts[j])parse.tune_v_opts[j]=opts[j]elseparse.tune_v_opts[j]=parse.tune_v_opts[j].concat(opts[j])}}}if(abc2svg.mhooks){for(i in abc2svg.mhooks){if(!modone[i]){modone[i]=1abc2svg.mhooks[i](self)}}}parse.file=file;parse.fname=in_fnameif(bol==undefined)bol=0if(!eof)eof=file.lengthif(file.slice(bol,bol+5)=="%abc-")cfmt["abc-version"]=/[1-9.]+/.exec(file.slice(bol+5,bol+10))for(;bol<eof;bol=parse.eol+1){eol=file.indexOf('\n',bol)if(eol<0||eol>eof)eol=eof;parse.eol=eolwhile(1){eol--switch(file[eol]){case' ':case'\t':continue}break}eol++if(eol==bol){if(parse.state==1){parse.istart=bol;syntax(1,"Empty line in tune header - ignored")}else if(parse.state>=2){end_tune()parse.state=0if(parse.select){eol=file.indexOf('\nX:',parse.eol)if(eol<0)eol=eofparse.eol=eol}}continue}parse.istart=parse.bol=bol;parse.iend=eol;parse.line.index=0;line0=file[bol];line1=file[bol+1]if((line0=='I'&&line1==':')||line0=='%'){if(line0=='%'&&parse.prefix.indexOf(line1)<0)continueif(file[bol+2]=='a'&&file[bol+3]=='b'&&file[bol+4]=='c'&&file[bol+5]==' '){bol+=6;line0=file[bol];line1=file[bol+1]}else{pscom=true}}if(pscom){pscom=false;bol+=2text=file.slice(bol,eol)a=text.match(/([^\s]+)\s*(.*)/)if(!a||a[1][0]=='%')continueswitch(a[1]){case"abcm2ps":case"ss-pref":parse.prefix=a[2]continuecase"abc-include":do_include(uncomment(a[2]))continue}if(a[1].slice(0,5)=='begin'){b=a[1].substr(5);end='\n'+line0+line1+"end"+b;i=file.indexOf(end,eol)if(i<0){syntax(1,"No $1 after %%$2",end.slice(1),a[1]);parse.eol=eofcontinue}self.do_begin_end(b,uncomment(a[2]),file.slice(eol+1,i).replace(/\n%[^%].*$/gm,'').replace(/^%%/gm,''))parse.eol=file.indexOf('\n',i+6)if(parse.eol<0)parse.eol=eofcontinue}switch(a[1]){case"select":if(parse.state!=0){syntax(1,errs.not_in_tune,"%%select")continue}select=uncomment(text.slice(7))if(select[0]=='"')select=select.slice(1,-1);if(!select){delete parse.selectcontinue}select=select.replace(/\(/g,'\\(');select=select.replace(/\)/g,'\\)');parse.select=new RegExp(select,'m')continuecase"tune":if(parse.state!=0){syntax(1,errs.not_in_tune,"%%tune")continue}select=uncomment(a[2])if(!select){parse.tune_opts={}continue}if(select=="end")continueif(!parse.tune_opts)parse.tune_opts={};parse.tune_opts[select]=opt={t_opts:[]};while(1){bol=++eolif(file[bol]!='%')breakeol=file.indexOf('\n',eol);if(file[bol+1]!=line1)continuebol+=2if(eol<0)text=file.slice(bol)elsetext=file.slice(bol,eol);a=text.match(/([^\s]+)\s*(.*)/)switch(a[1]){case"tune":breakcase"voice":do_voice(uncomment(a[2],true),true)continuedefault:opt.t_opts.push(uncomment(text,true))continue}break}if(parse.tune_v_opts){opt.v_opts=parse.tune_v_opts;parse.tune_v_opts=null}parse.eol=bol-1continuecase"voice":if(parse.state!=0){syntax(1,errs.not_in_tune,"%%voice")continue}select=uncomment(a[2])if(!select){parse.voice_opts=nullcontinue}do_voice(select)continue}self.do_pscom(uncomment(text,true))continue}if(line1!=':'||!/[A-Za-z+]/.test(line0)){last_info=undefined;if(parse.state<2)continueparse.line.buffer=uncomment(file.slice(bol,eol))if(parse.line.buffer)parse_music_line()continue}bol+=2while(1){switch(file[bol]){case' ':case'\t':bol++continue}break}if(line0=='+'){if(!last_info){syntax(1,"+: without previous info field")continue}txt_add=' ';line0=last_info}text=uncomment(file.slice(bol,eol),line0)switch(line0){case'X':if(parse.state!=0){syntax(1,errs.ignored,line0)continue}if(parse.select&&!tune_selected()){eol=file.indexOf('\nX:',parse.eol)if(eol<0)eol=eof;parse.eol=eolcontinue}sav.cfmt=clone(cfmt);sav.info=clone(info,2)sav.char_tb=clone(char_tb);sav.glovar=clone(glovar);sav.maps=clone(maps,1);sav.mac=clone(mac);sav.maci=clone(maci);info.X=text;parse.state=1if(user.page_format&&blkdiv<1)blkdiv=1if(parse.tune_opts)tune_filter()continuecase'T':switch(parse.state){case 0:continuecase 1:case 2:if(info.T==undefined)info.T=textelseinfo.T+="\n"+textcontinue}s=new_block("title");s.text=textcontinuecase'K':switch(parse.state){case 0:continuecase 1:info.K=textbreak}do_info(line0,text)continuecase'W':if(parse.state==0||cfmt.writefields.indexOf(line0)<0)breakif(info.W==undefined)info.W=textelseinfo.W+=txt_add+textbreakcase'm':if(parse.state>=2){syntax(1,errs.ignored,line0)continue}a=text.match(/(.*?)[= ]+(.*)/)if(!a||!a[2]){syntax(1,errs.bad_val,"m:")continue}mac[a[1]]=a[2];maci[a[1][0]]=truebreakcase's':if(parse.state!=3||cfmt.writefields.indexOf(line0)<0)breakget_sym(text,txt_add==' ')breakcase'w':if(parse.state!=3||cfmt.writefields.indexOf(line0)<0)breakget_lyrics(text,txt_add==' ')breakcase'|':if(parse.state<2)continueparse.line.buffer=textparse_music_line()continuedefault:if("ABCDFGHNOSZ".indexOf(line0)>=0){if(parse.state>=2){syntax(1,errs.ignored,line0)continue}if(!info[line0])info[line0]=textelseinfo[line0]+=txt_add+textbreak}do_info(line0,text)continue}txt_add='\n';last_info=line0}if(include)returnif(parse.state>=2)end_tune();parse.state=0}Abc.prototype.tosvg=tosvgvar gene,staff_tb,nstaff,tsnext,realwidth,insert_meter,spf_last,smallest_durationvar dx_tb=new Float32Array([10,10,11,13,15])var hw_tb=new Float32Array([4.7,5,6,7.2,7.5])var w_note=new Float32Array([3.5,3.7,5,6,7])function identify_note(s,dur_o){var head,flags,dots=0,dur=dur_oif(dur%12!=0)error(1,s,"Invalid note duration $1",dur);dur/=12if(!dur)error(1,s,"Note too short")for(flags=5;dur;dur>>=1,flags--){if(dur&1)break}dur>>=1if((dur+1)&dur){if(s.type!=C.REST||dur_o!=s.p_v.wmeasure)error(0,s,"Non standard note duration $1",dur_o)}while(dur>>dots>0)dots++flags-=dotsif(flags>=0){head=C.FULL}else switch(flags){default:error(1,s,"Note too long")flags=-4case-4:head=C.SQUAREbreakcase-3:head=s.fmt.squarebreve?C.SQUARE:C.OVALBARSbreakcase-2:head=C.OVALbreakcase-1:head=C.EMPTYbreak}return[head,dots,flags]}function set_head_shift(s){var i,i1,i2,d,ps,dx,dx_head=dx_tb[s.head],dir=s.stem,n=s.nhdif(!n)returndx=dx_head*.74if(s.grace)dx*=.6if(dir>=0){i1=1;i2=n+1;ps=s.notes[0].pit}else{dx=-dx;i1=n-1;i2=-1;ps=s.notes[n].pit}var shift=false,dx_max=0for(i=i1;i!=i2;i+=dir){d=s.notes[i].pit-ps;ps=s.notes[i].pitif(!d){if(shift){var new_dx=s.notes[i].shhd=s.notes[i-dir].shhd+dxif(dx_max<new_dx)dx_max=new_dxcontinue}if(i+dir!=i2&&ps+dir==s.notes[i+dir].pit){s.notes[i].shhd=-dxif(dx_max<-dx)dx_max=-dxcontinue}}if(d<0)d=-dif(d>3||(d>=2&&s.head!=C.SQUARE)){shift=false}else{shift=!shiftif(shift){s.notes[i].shhd=dxif(dx_max<dx)dx_max=dx}}}s.xmx=dx_max}function acc_shift(notes,dx_head){var i,i1,i2,dx,dx1,dx2,ps,p1,acc,n=notes.lengthfor(i=n-1;--i>=0;){dx=notes[i].shhdif(!dx||dx>0)continuedx=dx_head-dx;ps=notes[i].pitfor(i1=n;--i1>=0;){if(!notes[i1].acc)continuep1=notes[i1].pitif(p1<ps-3)breakif(p1>ps+3)continueif(notes[i1].shac<dx)notes[i1].shac=dx}}for(i1=n;--i1>=0;){if(notes[i1].acc){p1=notes[i1].pitdx1=notes[i1].shacif(!dx1){dx1=notes[i1].shhdif(dx1<0)dx1=dx_head-dx1elsedx1=dx_head}break}}if(i1<0)returnfor(i2=0;i2<i1;i2++){if(notes[i2].acc){ps=notes[i2].pitdx2=notes[i2].shacif(!dx2){dx2=notes[i2].shhdif(dx2<0)dx2=dx_head-dx2elsedx2=dx_head}break}}if(i1==i2){notes[i1].shac=dx1return}if(p1>ps+4){if(dx1>dx2)dx2=dx1notes[i1].shac=notes[i2].shac=dx2}else{notes[i1].shac=dx1if(notes[i1].pit!=notes[i2].pit)dx1+=7notes[i2].shac=dx2=dx1}dx2+=7for(i=i1;--i>i2;){acc=notes[i].accif(!acc)continuedx=notes[i].shacif(dx<dx2)dx=dx2ps=notes[i].pitfor(i1=n;--i1>i;){if(!notes[i1].acc)continuep1=notes[i1].pitif(p1>=ps+4){if(p1>ps+4||acc<0||notes[i1].acc<0)continue}if(dx>notes[i1].shac-6){dx1=notes[i1].shac+7if(dx1>dx)dx=dx1}}notes[i].shac=dx}}function set_acc_shft(){var s,s2,st,i,acc,st,t,dx_head,notess=tsfirstwhile(s){if(s.type!=C.NOTE||s.invis){s=s.ts_nextcontinue}st=s.st;t=s.time;acc=falsefor(s2=s;s2;s2=s2.ts_next){if(s2.time!=t||s2.type!=C.NOTE||s2.st!=st)breakif(acc)continuefor(i=0;i<=s2.nhd;i++){if(s2.notes[i].acc){acc=truebreak}}}if(!acc){s=s2continue}dx_head=dx_tb[s.head]notes=[]for(;s!=s2;s=s.ts_next){if(!s.invis)Array.prototype.push.apply(notes,s.notes)}notes.sort(abc2svg.pitcmp)acc_shift(notes,dx_head)}}function lkvsym(s,next){s.next=next;s.prev=next.previf(s.prev)s.prev.next=selses.p_v.sym=s;next.prev=s}function lktsym(s,next){var old_wls.ts_next=nextif(next){s.ts_prev=next.ts_previf(s.ts_prev)s.ts_prev.ts_next=s;next.ts_prev=s}else{error(2,s,"Bad linkage")s.ts_prev=null}s.seqst=!s.ts_prev||s.time!=s.ts_prev.time||(w_tb[s.ts_prev.type]!=w_tb[s.type]&&!!w_tb[s.ts_prev.type])if(!next||next.seqst)returnnext.seqst=next.time!=s.time||(w_tb[s.type]!=w_tb[next.type]&&!!w_tb[s.type])if(next.seqst){old_wl=next.wlself.set_width(next)if(next.a_ly)ly_set(next)if(!next.shrink){next.shrink=next.wlif(next.prev)next.shrink+=next.prev.wr}else{next.shrink+=next.wl-old_wl}next.space=0}}function unlksym(s){if(s.next)s.next.prev=s.previf(s.prev)s.prev.next=s.nextelses.p_v.sym=s.nextif(s.ts_next){if(s.seqst){if(s.ts_next.seqst){s.ts_next.shrink+=s.shrink;s.ts_next.space+=s.space}else{s.ts_next.seqst=true;s.ts_next.shrink=s.shrink;s.ts_next.space=s.space}}else{if(s.ts_next.seqst&&s.ts_prev&&s.ts_prev.seqst&&!w_tb[s.ts_prev.type]){s.ts_next.seqst=falses.shrink=s.ts_next.shrinks.space=s.ts_next.space}}s.ts_next.ts_prev=s.ts_prev}if(s.ts_prev)s.ts_prev.ts_next=s.ts_nextif(tsfirst==s)tsfirst=s.ts_nextif(tsnext==s)tsnext=s.ts_next}function insert_clef(s,clef_type,clef_line){var p_voice=s.p_v,new_s,st=s.stif(s.type==C.BAR&&s.prev&&s.prev.type==C.BAR&&s.prev.bar_type[0]!=':')s=s.prev;p_voice.last_sym=s.previf(!p_voice.last_sym)p_voice.sym=null;p_voice.time=s.time;new_s=sym_add(p_voice,C.CLEF);new_s.next=s;s.prev=new_s;new_s.clef_type=clef_type;new_s.clef_line=clef_line;new_s.st=st;new_s.clef_small=truedelete new_s.second;new_s.notes=[]new_s.notes[0]={pit:s.notes[0].pit}new_s.nhd=0;while(!s.seqst)s=s.ts_prev;lktsym(new_s,s)if(s.soln){new_s.soln=truedelete s.soln}return new_s}function set_float(){var p_voice,st,staff_chg,v,s,s1,up,downfor(v=0;v<voice_tb.length;v++){p_voice=voice_tb[v]staff_chg=false;st=p_voice.stfor(s=p_voice.sym;s;s=s.next){if(!s.floating){while(s&&!s.floating)s=s.nextif(!s)breakstaff_chg=false}if(!s.dur){if(staff_chg)s.st++continue}if(s.notes[0].pit>=19){staff_chg=falsecontinue}if(s.notes[s.nhd].pit<=12){staff_chg=trues.st++continue}up=127for(s1=s.ts_prev;s1;s1=s1.ts_prev){if(s1.st!=st||s1.v==s.v)breakif(s1.type==C.NOTE)if(s1.notes[0].pit<up)up=s1.notes[0].pit}if(up==127){if(staff_chg)s.st++continue}if(s.notes[s.nhd].pit>up-3){staff_chg=falsecontinue}down=-127for(s1=s.ts_next;s1;s1=s1.ts_next){if(s1.st!=st+1||s1.v==s.v)breakif(s1.type==C.NOTE)if(s1.notes[s1.nhd].pit>down)down=s1.notes[s1.nhd].pit}if(down==-127){if(staff_chg)s.st++continue}if(s.notes[0].pit<down+3){staff_chg=trues.st++continue}up-=s.notes[s.nhd].pitdown=s.notes[0].pit-downif(!staff_chg){if(up<down+3)continuestaff_chg=true}else{if(up<down-3){staff_chg=falsecontinue}}s.st++}}}function set_graceoffs(s){var next,m,dx,x,gspleft=s.fmt.gracespace[0],gspinside=s.fmt.gracespace[1],gspright=s.fmt.gracespace[2],g=s.extra;if(s.prev&&s.prev.type==C.BAR)gspleft-=3;x=gspleft;g.beam_st=truefor(;;g=g.next){set_head_shift(g)acc_shift(g.notes,6.5)dx=0for(m=g.nhd;m>=0;m--){if(g.notes[m].shac-2>dx)dx=g.notes[m].shac-2}x+=dx;g.x=xif(g.nflags<=0)g.beam_st=g.beam_end=truenext=g.nextif(!next){g.beam_end=truebreak}if(next.nflags<=0)g.beam_end=trueif(g.beam_end){next.beam_st=true;x+=gspinside/4}if(g.nflags<=0)x+=gspinside/4if(g.y>next.y+8)x-=1.5x+=gspinside}next=s.nextif(next&&next.type==C.NOTE){if(g.y>=3*(next.notes[next.nhd].pit-18))gspright-=1else if(g.beam_st&&g.y<3*(next.notes[next.nhd].pit-18)-4)gspright+=2}x+=gspright;return x}function set_w_chs(s){var i,ch,w0,s0,dw,x=0,n=0set_font("vocal")for(;s;s=s.ts_next){if(s.shrink){x+=s.shrink;n++}if(s.a_ly)ly_set(s)if(!s.a_gch)continuefor(i=0;i<s.a_gch.length;i++){ch=s.a_gch[i]if(ch.type!='g'||ch.y<0)continueif(w0){if(w0>x+ch.x){if(s.prev&&s.prev.seqst&&s.prev.type==C.BAR)n--dw=(w0-x-ch.x)/nwhile(1){s0=s0.ts_nextif(s0.shrink)s0.shrink+=dwif(s0==s||s0.type==C.BAR)break}}}s0=s;w0=ch.text.wh[0];n=0;x=0break}}}function gchord_width(s,wlnote,wlw){var gch,w,ix,arspc=0for(ix=0;ix<s.a_gch.length;ix++){gch=s.a_gch[ix]switch(gch.type){case'<':w=gch.text.wh[0]+wlnoteif(w>wlw)wlw=wbreakcase'>':w=gch.text.wh[0]+s.wrif(w>arspc)arspc=wbreak}}if(s.wr<arspc)s.wr=arspcreturn wlw}Abc.prototype.set_width=function(s){var s2,i,m,xx,w,wlnote,wlw,acc,nt,bar_type,meter,last_acc,n1,n2,esp,tmpif(s.play){s.wl=s.wr=0return}switch(s.type){case C.NOTE:case C.REST:s.wr=wlnote=s.invis?0:hw_tb[s.head]if(s.xmx>0)s.wr+=s.xmx+4;for(s2=s.prev;s2;s2=s2.prev){if(w_tb[s2.type])break}if(s2){switch(s2.type){case C.BAR:case C.CLEF:case C.KEY:case C.METER:wlnote+=3breakcase C.STBRK:wlnote+=8break}}for(m=0;m<=s.nhd;m++){nt=s.notes[m]xx=nt.shhdif(xx<0){if(wlnote<-xx+5)wlnote=-xx+5}acc=nt.accif(acc){tmp=nt.shac+(typeof acc=="object"?5.5:3.5)if(wlnote<tmp)wlnote=tmp}if(nt.a_dd)wlnote+=deco_wch(nt)}if(s2){switch(s2.type){case C.BAR:case C.CLEF:case C.KEY:case C.METER:wlnote-=3break}}if(s.a_dd)wlnote=deco_width(s,wlnote)if(s.beam_st&&s.beam_end&&s.stem>0&&s.nflags>0){if(s.wr<s.xmx+9)s.wr=s.xmx+9}if(s.dots){if(s.wl==undefined)switch(s.head){case C.SQUARE:case C.OVALBARS:s.xmx+=3breakcase C.OVAL:s.xmx+=1break}if(s.wr<s.xmx+8)s.wr=s.xmx+8if(s.dots>=2)s.wr+=3.5*(s.dots-1)}if(s.trem2&&s.beam_end&&wlnote<20)wlnote=20wlw=wlnoteif(s2){switch(s2.type){case C.NOTE:if(s2.stem>0&&s.stem<0){if(wlw<7)wlw=7}if((s.y>27&&s2.y>27)||(s.y<-3&&s2.y<-3)){if(wlw<6)wlw=6}if(s2.tie){if(wlw<14)wlw=14}breakcase C.CLEF:if(s2.second||s2.clef_small)breakcase C.KEY:if(s.a_gch)wlw+=4case C.METER:wlw+=3break}}if(s.a_gch)wlw=gchord_width(s,wlnote,wlw)if(s.prev&&s.prev.type==C.GRACE){s.prev.wl+=wlnote-4.5s.wl=s.prev.wl}else{s.wl=wlw}returncase C.SPACE:xx=s.width/2;s.wr=xxif(s.a_gch)xx=gchord_width(s,xx,xx)if(s.a_dd)xx=deco_width(s,xx)s.wl=xxreturncase C.BAR:bar_type=s.bar_typeswitch(bar_type){case"|":w=5breakcase"[":w=0breakdefault:w=2+2.8*bar_type.lengthfor(i=0;i<bar_type.length;i++){switch(bar_type[i]){case"[":case"]":w+=1case":":w+=2break}}break}s.wl=wif(s.next&&s.next.type!=C.METER)s.wr=7elses.wr=5if(s.invis)s.wl=s.wr=2s2=s.previf(s2&&s2.type==C.GRACE)s.wl-=6for(;s2;s2=s2.prev){if(w_tb[s2.type]){if(s2.type==C.STBRK)s.wl-=12break}}if(s.a_dd)s.wl=deco_width(s,s.wl)if(s.text&&s.text.length<4&&s.next&&s.next.a_gch){set_font("repeat");s.wr+=strwh(s.text)[0]+2if(cfmt.measurenb>0&s.bar_num&&s.bar_num%cfmt.measurenb)s.wr+=4}returncase C.CLEF:if(s.invis){s.wl=s.wr=1return}if(s.prev&&s.prev.type==C.STBRK){s.wl=6s.wr=13delete s.clef_smallreturn}s.wl=s.clef_small?11:12s.wr=s.clef_small?8:13returncase C.KEY:if(s.invis){s.wl=s.wr=0return}s.wl=0esp=3n1=s.k_sfif(s.k_old_sf&&(s.fmt.cancelkey||n1==0))n2=s.k_old_sfelsen2=0if(n1*n2>=0){if(n1<0)n1=-n1if(n2<0)n2=-n2if(n2>n1)n1=n2}else{n1-=n2if(n1<0)n1=-n1;esp+=3}if(s.k_bagpipe=='p')n1++if(s.k_a_acc){n2=s.k_a_acc.lengthif(s.exp)n1=n2elsen1+=n2if(n2)last_acc=s.k_a_acc[0].accfor(i=1;i<n2;i++){acc=s.k_a_acc[i]if(acc.pit>s.k_a_acc[i-1].pit+6||acc.pit<s.k_a_acc[i-1].pit-6)n1--else if(acc.acc!=last_acc)esp+=3;last_acc=acc.acc}}if(!n1)breaks.wr=5.5*n1+espif(s.prev&&!s.prev.bar_type)s.wl+=2returncase C.METER:s.x_meter=[]if(!s.a_meter.length)breakwlw=0for(i=0;i<s.a_meter.length;i++){meter=s.a_meter[i]switch(meter.top[0]){case'C':case'c':case'o':s.x_meter[i]=wlw+6;wlw+=12breakcase'.':case'|':s.x_meter[i]=s.x_meter[i-1]breakdefault:w=0if(!meter.bot||meter.top.length>meter.bot.length)meter=meter.topelsemeter=meter.bot;for(m=0;m<meter.length;m++){switch(meter[m]){case'(':wlw+=4case')':case'1':w+=4breakdefault:w+=12break}}s.x_meter[i]=wlw+w/2wlw+=w}}s.wl=1s.wr=wlw+7returncase C.MREST:s.wl=6;s.wr=66returncase C.GRACE:if(s.invis)breaks.wl=set_graceoffs(s);s.wr=0if(s.a_ly)ly_set(s)returncase C.STBRK:s.wl=s.xmxs.wr=8returncase C.CUSTOS:s.wl=s.wr=4returncase C.TEMPO:tempo_build(s)breakcase C.BLOCK:case C.REMARK:case C.STAVES:breakdefault:error(2,s,"set_width - Cannot set width for symbol $1",s.type)break}s.wl=s.wr=0}function time2space(s,len){var i,l,spaceif(smallest_duration>=C.BLEN/2){if(smallest_duration>=C.BLEN)len/=4elselen/=2}else if(!s.next&&len>=C.BLEN){len/=2}if(len>=C.BLEN/4){if(len<C.BLEN/2)i=5else if(len<C.BLEN)i=6else if(len<C.BLEN*2)i=7else if(len<C.BLEN*4)i=8elsei=9}else{if(len>=C.BLEN/8)i=4else if(len>=C.BLEN/16)i=3else if(len>=C.BLEN/32)i=2else if(len>=C.BLEN/64)i=1elsei=0}l=len-((C.BLEN/16/8)<<i)space=cfmt.spatab[i]if(l){if(l<0){space=cfmt.spatab[0]*len/(C.BLEN/16/8)}else{if(i>=9)i=8space+=(cfmt.spatab[i+1]-cfmt.spatab[i])*l/((C.BLEN/16/8)<<i)}}return space}function set_space(s,ptime){var space,len,s2,stemdirlen=s.time-ptimeif(!len){switch(s.type){case C.MREST:return s.wl}return 0}if(s.ts_prev.type==C.MREST)return 71space=time2space(s,len)while(!s.dur){switch(s.type){case C.BAR:if(!s.next)space*=.9return space*.9-3case C.CLEF:return space-s.wl-s.wrcase C.BLOCK:case C.REMARK:case C.STAVES:case C.TEMPO:s=s.ts_nextif(!s)return spacecontinue}break}if(s.dur&&len<=C.BLEN/4){s2=swhile(s2){if(!s2.beam_st){space*=.9break}s2=s2.ts_nextif(!s2||s2.seqst)break}}if(s.type==C.NOTE&&s.nflags>=-1&&s.stem>0){stemdir=truefor(s2=s.ts_prev;s2&&s2.time==ptime;s2=s2.ts_prev){if(s2.type==C.NOTE&&(s2.nflags<-1||s2.stem>0)){stemdir=falsebreak}}if(stemdir){for(s2=s.ts_next;s2&&s2.time==s.time;s2=s2.ts_next){if(s2.type==C.NOTE&&(s2.nflags<-1||s2.stem<0)){stemdir=falsebreak}}if(stemdir)space*=.9}}return space}function set_sp_tup(s,s_et){var tim=s.time,ttim=s_et.time-tim,sp=time2space(s,ttim),s2=s,wsp=0while(1){s2=s2.ts_nextif(s2.seqst){wsp+=s2.spaceif(s2.bar_type)wsp+=10}if(s2==s_et)break}sp=(sp+wsp)/2/ttimwhile(1){s=s.ts_nextif(s.seqst){s.space=sp*(s.time-tim)tim=s.time}if(s==s_et)break}}function _bar(s){return{type:C.BAR,bar_type:"|",fname:s.fname,istart:s.istart,iend:s.iend,v:s.v,p_v:s.p_v,st:s.st,dur:0,time:s.time+(s.dur||0),nhd:0,notes:[{pit:s.notes?s.notes[0].pit:22}],seqst:true,invis:true,prev:s,fmt:s.fmt}}function add_end_bar(s){var b=_bar(s),sn=s.ts_nextb.wl=0b.wr=0b.ts_prev=sb.next=s.nextb.ts_next=s.ts_nextb.shrink=s.type==C.STBRK?0:(s.wr+3)if(s.next)s.next.prev=bs.ts_next.ts_prev=bs.next=s.ts_next=bb.space=sn.space*.9-3return b}function set_allsymwidth(first){var val,st,s_chs,stup,itup,s=tsfirst,s2=s,xa=0,xl=[],wr=[],maxx=xa,tim=s.timewhile(1){itup=0do{if((s.a_gch||s.a_ly)&&!s_chs)s_chs=s;self.set_width(s);st=s.stif(xl[st]==undefined)xl[st]=0if(wr[st]==undefined)wr[st]=0;val=xl[st]+wr[st]+s.wlif(val>maxx)maxx=valif(s.dur&&s.dur!=s.notes[0].dur&&first)itup=1s=s.ts_next}while(s&&!s.seqst);s2.shrink=maxx-xas2.space=s2.ts_prev?set_space(s2,tim):0if(s2.space==0&&s2.ts_prev&&s2.ts_prev.type==C.SPACE&&s2.ts_prev.seqst)s2.space=s2.ts_prev.space/=2if(itup){if(!stup)stup=s2}else if(stup&&stup.v==s2.v){set_sp_tup(stup,s2)stup=null}if(!s2.shrink){if(s2.type==C.CLEF&&!s2.ts_prev.bar_type){delete s2.seqst;s2.time=tim}else{s2.shrink=10}}tim=s2.timeif(!s)breaks=s2do{wr[s.st]=0s=s.ts_next}while(!s.seqst)xa=maxxdo{st=s2.st;xl[st]=xaif(s2.wr>wr[st])wr[st]=s2.wrs2=s2.ts_next}while(!s2.seqst)}if(stup)set_sp_tup(stup,s2)if(first&&s_chs)set_w_chs(s_chs)}function to_rest(so){var s=clone(so)s.prev.next=so.ts_prev=so.prev=s.ts_prev.ts_next=ss.next=s.ts_next=soso.seqst=falseso.invis=so.play=trues.type=C.RESTdelete s.in_tupletdelete s.tpdelete s.a_dddelete s.a_gchdelete s.slsreturn s}function set_repeat(s){var s2,s3,i,j,dur,n=s.repeat_n,k=s.repeat_k,st=s.st,v=s.vs.repeat_n=0if(n<0){n=-n;i=nfor(s3=s.prev;s3;s3=s3.prev){if(!s3.dur){if(s3.type==C.BAR){error(1,s3,"Bar in repeat sequence")return}continue}if(--i<=0)break}if(!s3){error(1,s,errs.not_enough_n)return}dur=s.time-s3.time;i=k*nfor(s2=s;s2;s2=s2.next){if(!s2.dur){if(s2.type==C.BAR){error(1,s2,"Bar in repeat sequence")return}continue}if(--i<=0)break}if(!s2||!s2.next){error(1,s,errs.not_enough_n)return}for(s2=s.prev;s2!=s3;s2=s2.prev){if(s2.type==C.NOTE){s2.beam_end=truebreak}}for(j=k;--j>=0;){i=nif(s.dur)i--;s2=s.ts_nextwhile(i>0){if(s2.st==st){s2.invis=s2.play=trueif(s2.seqst&&s2.ts_next.seqst)s2.seqst=falseif(s2.v==v&&s2.dur)i--}s2=s2.ts_next}s=to_rest(s)s.dur=s.notes[0].dur=dur;s.rep_nb=-1;s.beam_st=true;self.set_width(s)s.head=C.SQUARE;for(s=s2;s;s=s.ts_next){if(s.st==st&&s.v==v&&s.dur)break}}return}i=nfor(s2=s.prev.prev;s2;s2=s2.prev){if(s2.type==C.BAR||s2.time==tsfirst.time){if(--i<=0)break}}if(!s2){error(1,s,errs.not_enough_m)return}dur=s.time-s2.timeif(n==1)i=kelsei=nfor(s2=s;s2;s2=s2.next){if(s2.type==C.BAR){if(--i<=0)break}}if(!s2){error(1,s,errs.not_enough_m)return}i=kif(n==2&&i>1){s2=s2.nextif(!s2){error(1,s,errs.not_enough_m)return}s2.repeat_n=n;s2.repeat_k=--i}dur/=nif(n==2){s3=sfor(s2=s.ts_next;;s2=s2.ts_next){if(s2.st!=st)continueif(s2.type==C.BAR){if(s2.v==v)breakcontinue}s2.invis=s2.play=trueif(s2.seqst&&s2.ts_next.seqst)s2.seqst=false}s3=to_rest(s3)s3.dur=s3.notes[0].dur=dur;s3.invis=trues2.bar_mrep=2s3=s2.next;for(s2=s3.ts_next;;s2=s2.ts_next){if(s2.st!=st)continueif(s2.type==C.BAR){if(s2.v==v)breakcontinue}if(!s2.dur)continues2.invis=s2.play=trueif(s2.seqst&&s2.ts_next.seqst)s2.seqst=false}s3=to_rest(s3)s3.dur=s3.notes[0].dur=dur;s3.invis=true;self.set_width(s3)return}s3=sfor(j=k;--j>=0;){for(s2=s3.ts_next;;s2=s2.ts_next){if(s2.st!=st)continueif(s2.type==C.BAR){if(s2.v==v)breakcontinue}if(!s2.dur)continues2.invis=s2.play=trueif(s2.seqst&&s2.ts_next.seqst)s2.seqst=false}s3=to_rest(s3)s3.dur=s3.notes[0].dur=dur;s3.beam_st=trueif(k==1){s3.rep_nb=1break}s3.rep_nb=k-j+1;s3=s2.next}}function custos_add(s){var p_voice,new_s,i,s2=swhile(1){if(s2.type==C.NOTE)breaks2=s2.nextif(!s2)return}p_voice=s.p_v;p_voice.last_sym=s.prev;p_voice.time=s.time;new_s=sym_add(p_voice,C.CUSTOS);new_s.next=s;s.prev=new_s;new_s.wl=0new_s.wr=4lktsym(new_s,s);new_s.shrink=s.shrinkif(new_s.shrink<8+4)new_s.shrink=8+4;new_s.space=s2.space;new_s.head=C.FULLnew_s.stem=s2.stemnew_s.nhd=s2.nhd;new_s.notes=[]for(i=0;i<s2.notes.length;i++){new_s.notes[i]={pit:s2.notes[i].pit,shhd:0,dur:C.BLEN/4}}new_s.stemless=true}function set_nl(s){var p_voice,done,tim,ptypfunction bardiv(so){var s,s1,s2,t1,t2,ifunction new_type(s){var t=s.bar_type.match(/(:*)([^:]*)(:*)/)if(!t[3]){t1=t[1]+t[2]t2='['}else if(!t[1]){t1='||'t2='[|'+t[3]}else{i=(t[2].length/2)|0t1=t[1]+'|'+t[2].slice(0,i)t2=t[2].slice(i)+'|'+t[3]}}function eol_bar(s,so,sst){var s1,s2,s3for(s1=so.ts_prev;s1.time==s.time;s1=s1.ts_prev){if(s1.v!=s.v)continueif(s1.bar_type){if(s1.bar_type!='|')returns2=s1break}if(!s3)s3=s1.next}if(!s2){s2=clone(s)if(!s3)s3=ss2.next=s3s2.prev=s3.previf(s2.prev)s2.prev.next=s2s3.prev=s2s2.ts_prev=so.ts_prevs2.ts_prev.ts_next=s2s2.ts_next=soso.ts_prev=s2if(s==sst)s2.seqst=1if(s2.seqst){for(s=s2.ts_next;!s.seqst;s=s.ts_next);s2.shrink=s.shrinks.shrink=s2.wr+s.wls2.space=s.spaces.space=0}delete s2.part}s2.bar_type="||"}s=sowhile(s&&s.time==so.time){if(s.bar_type&&s.bar_type.slice(-1)==':'){s2=sbreak}s=s.ts_next}if(s2){s=s2while(1){eol_bar(s2,so,s)s2=s2.ts_nextif(!s2||s2.seqst)break}return so}s=sowhile(s.ts_prev&&s.ts_prev.time==so.time){s=s.ts_previf(s.bar_type)s1=selse if(!s1&&s.type==C.GRACE&&s.seqst)so=s}if(!s1||!s1.bar_type||(s1.bar_type.slice(-1)!=':'&&!s1.text))return sofor(so=s1;so.time==s1.time;so=so.ts_prev){switch(so.ts_prev.type){case C.KEY:case C.METER:case C.TEMPO:case C.STAVES:case C.STBRK:continue}break}s=s1while(1){new_type(s1)s2=clone(s1)s2.bar_type=t1s1.bar_type=t2s2.ts_prev=so.ts_prevs2.ts_prev.ts_next=s2s2.ts_next=soso.ts_prev=s2if(s1==s)s2.seqst=1s2.next=s1if(s2.prev)s2.prev.next=s2s1.prev=s2if(s1.rbstop)s2.rbstop=s1.rbstopif(s1.text){s1.invis=1delete s1.xshdelete s2.textdelete s2.rbstart}delete s2.partdelete s1.a_dddo{s1=s1.ts_next}while(!s1.seqst&&!s1.bar_type)if(s1.seqst)break}return so}function set_eol(s){if(cfmt.custos&&voice_tb.length==1)custos_add(s)s.nl=trues=s.ts_previf(s.type!=C.BAR)add_end_bar(s)}function do_warn(s){var s1,s2,s3,s4,wfor(s2=s;s2&&s2.time==s.time;s2=s2.ts_next){switch(s2.type){case C.KEY:if(!s.fmt.keywarn||s2.invis)continuefor(s1=s.ts_prev;s1;s1=s1.ts_prev){if(s1.type!=C.METER)break}case C.METER:if(s2.type==C.METER){if(!s.fmt.timewarn)continues1=s.ts_prev}case C.CLEF:if(!s2.prev)continueif(s2.type==C.CLEF){if(s2.invis)breakfor(s1=s.ts_prev;s1;s1=s1.ts_prev){switch(s1.type){case C.BAR:if(s1.bar_type[0]==':')breakcase C.KEY:case C.METER:continue}break}}s3=clone(s2)lktsym(s3,s1.ts_next)s1=s3while(1){s1=s1.ts_nextif(s1.v==s2.v)break}lkvsym(s3,s1)if(s3.seqst){self.set_width(s3)s3.shrink=s3.wls4=s3.ts_prevw=0while(1){if(s4.wr>w)w=s4.wrif(s4.seqst)breaks4=s4.ts_prev}s3.shrink+=ws3.space=0s4=s3while(1){if(s4.ts_next.seqst)breaks4=s4.ts_next}w=0while(1){if(s4.wl>w)w=s4.wls4=s4.ts_nextif(s4.seqst)break}s4.shrink=s3.wr+w}delete s3.partcontinue}if(w_tb[s2.type])break}}s=bardiv(s)do_warn(s)if(s.ts_prev.type!=C.STAVES){set_eol(s)return s}for(s=s.ts_prev;s;s=s.ts_prev){if(s.seqst&&s.type!=C.CLEF)break}done=0ptyp=s.typefor(;;s=s.ts_next){if(!s)return sif(s.type==ptyp)continueptyp=s.typeif(done<0)breakswitch(s.type){case C.STAVES:if(!s.ts_prev)returnif(s.ts_prev.type==C.BAR)breakwhile(s.ts_next){if(w_tb[s.ts_next.type]&&s.ts_next.type!=C.CLEF)breaks=s.ts_next}if(!s.ts_next||s.ts_next.type!=C.BAR)continues=s.ts_nextcase C.BAR:if(done)breakdone=1;continuecase C.STBRK:if(!s.stbrk_forced)unlksym(s)elsedone=-1continuecase C.CLEF:if(done)breakcontinuedefault:if(!done||(s.prev&&s.prev.type==C.GRACE))continuebreak}break}set_eol(s)return s}function get_ck_width(){var r0,r1,p_voice=voice_tb[0]self.set_width(p_voice.clef);self.set_width(p_voice.ckey);self.set_width(p_voice.meter)return[p_voice.clef.wl+p_voice.clef.wr+p_voice.ckey.wl+p_voice.ckey.wr,p_voice.meter.wl+p_voice.meter.wr]}function get_width(s,next){var shrink,space,w=0,wmx=0,sp_fac=(1-s.fmt.maxshrink)while(s!=next){if(s.seqst){shrink=s.shrinkwmx+=shrinkif((space=s.space)<shrink)w+=shrinkelsew+=shrink*s.fmt.maxshrink+space*sp_facs.x=w}s=s.ts_next}if(next)wmx+=next.wrreturn[w,wmx]}function set_lines(s,next,lwidth,indent){var first,s2,s3,s4,s5,x,xmin,xmid,xmax,wwidth,shrink,space,nlines,last=next?next.ts_prev:null,ws=get_width(s,next)if(s.fmt.keywarn&&next&&next.type==C.KEY&&!last.dur){ws[0]+=next.wrws[1]+=next.wr}if(ws[0]+indent<lwidth){if(next)next=set_nl(next)return next||last}wwidth=ws[0]+indentwhile(1){nlines=Math.ceil(wwidth/lwidth)if(nlines<=1){if(next)next=set_nl(next)return next||last}s2=first=s;xmin=s.x-s.shrink-indent;xmax=xmin+lwidth;xmid=xmin+wwidth/nlines;xmin+=wwidth/nlines*s.fmt.breaklimit;for(s=s.ts_next;s!=next;s=s.ts_next){if(!s.x)continueif(s.type==C.BAR)s2=sif(s.x>=xmin)break}s4=sif(s==next){if(s)s=set_nl(s)return s}s3=nullfor(;s!=next;s=s.ts_next){x=s.xif(!x)continueif(x>xmax)breakif(s.type!=C.BAR)continueif(x<xmid){s3=scontinue}if(!s3||x-xmid<xmid-s3.x)s3=sbreak}if(!s3){s=s4var beam=0,bar_time=s2.timexmax-=8;s5=sfor(;s!=next;s=s.ts_next){if(s.seqst){x=s.xif(x+s.wr>=xmax)breakif(!beam&&!s.in_tuplet&&(xmid-s5.x>x-xmid||(s.time-bar_time)%(C.BLEN/4)==0))s3=s}if(s.beam_st)beam|=1<<s.vif(s.beam_end)beam&=~(1<<s.v)s5=s}if(s3){do{s3=s3.ts_prev}while(!s3.seqst)}}if(!s3){s3=s=s4for(;s!=next;s=s.ts_next){x=s.xif(!x)continueif(x+s.wr>=xmax)breakif(s3&&x>=xmid){if(xmid-s3.x>x-xmid)s3=sbreak}s3=s}}s=s3while(s.ts_next){s=s.ts_nextif(s.seqst)break}if(s.nl){error(0,s,"Line split problem - adjust maxshrink and/or breaklimit");nlines=2for(s=s.ts_next;s!=next;s=s.ts_next){if(!s.x)continueif(--nlines<=0)break}}s=set_nl(s)if(!s||(next&&s.time>=next.time))breakwwidth-=s.x-first.x;indent=0}return s}function cut_tune(lwidth,lsh){var s2,i,mc,pg_sav={leftmargin:cfmt.leftmargin,rightmargin:cfmt.rightmargin,pagewidth:cfmt.pagewidth,scale:cfmt.scale},indent=lsh[0]-lsh[1],ckw=get_ck_width(),s=tsfirstlwidth-=lsh[1]if(cfmt.indent&&cfmt.indent>lsh[0])indent+=cfmt.indentlwidth-=ckw[0]indent+=ckw[1]if(cfmt.custos&&voice_tb.length==1)lwidth-=12i=s.fmt.barsperstaffif(i){for(s2=s;s2;s2=s2.ts_next){if(s2.type!=C.BAR||!s2.bar_num||--i>0)continuewhile(s2.ts_next&&s2.ts_next.type==C.BAR)s2=s2.ts_nextif(s2.ts_next)s2.ts_next.soln=truei=s.fmt.barsperstaff}}s2=sfor(;s;s=s.ts_next){if(s.type==C.BLOCK){switch(s.subtype){case"leftmargin":case"rightmargin":case"pagescale":case"pagewidth":case"scale":case"staffwidth":if(!s.soln)self.set_format(s.subtype,s.param)breakcase"mc_start":mc={lm:cfmt.leftmargin,rm:cfmt.rightmargin}breakcase"mc_new":case"mc_end":if(!mc)breakcfmt.leftmargin=mc.lmcfmt.rightmargin=mc.rmimg.chg=1break}}if(!s.ts_next){s=null}else if(!s.soln){continue}else{s.soln=falseif(s.time==s2.time)continuewhile(!s.seqst)s=s.ts_prev}set_page()lwidth=get_lwidth()-lsh[1]-ckw[0]s2=set_lines(s2,s,lwidth,indent)if(!s2)breaks=s2.type==C.BLOCK?s2.ts_prev:sindent=0}cfmt.leftmargin=pg_sav.leftmargincfmt.rightmargin=pg_sav.rightmargincfmt.pagewidth=pg_sav.pagewidthcfmt.scale=pg_sav.scaleimg.chg=1set_page()}function set_yval(s){switch(s.type){case C.CLEF:if(s.second||s.invis){s.ymx=s.ymn=12break}s.y=(s.clef_line-1)*6switch(s.clef_type){default:s.ymx=s.y+28s.ymn=s.y-14breakcase"c":s.ymx=s.y+13s.ymn=s.y-11breakcase"b":s.ymx=s.y+7s.ymn=s.y-12break}if(s.clef_small){s.ymx-=2;s.ymn+=2}if(s.ymx<26)s.ymx=26if(s.ymn>-1)s.ymn=-1if(s.clef_octave){if(s.clef_octave>0)s.ymx+=12elses.ymn-=12}breakcase C.KEY:if(s.k_sf>2)s.ymx=24+10else if(s.k_sf>0)s.ymx=24+6elses.ymx=24+2;s.ymn=-2breakdefault:s.ymx=24;s.ymn=0break}}function set_ottava(){var s,s1,st,o,d,m=nstaff+1,staff_d=new Int8Array(m)function sym_ott(s,d){var g,m,noteswitch(s.type){case C.REST:if(voice_tb.length==1)breakcase C.NOTE:if(!s.p_v.ckey.k_drum){for(m=s.nhd;m>=0;m--){note=s.notes[m];if(!note.opit)note.opit=note.pit;note.pit+=d}}breakcase C.GRACE:for(g=s.extra;g;g=g.next){if(!s.p_v.ckey.k_drum){for(m=0;m<=g.nhd;m++){note=g.notes[m]if(!note.opit)note.opit=note.pitnote.pit+=d}}}break}}function deco_rm(s){for(var i=s.a_dd.length;--i>=0;){if(s.a_dd[i].name.match(/1?[85][vm][ab]/))s.a_dd.splice(i,1)}}for(s=tsfirst;s;s=s.ts_next){st=s.sto=s.ottavaif(o){if(o[0]){if(staff_d[st]&&!o[1]){sym_ott(s,staff_d[st])deco_rm(s)continue}}else if(!staff_d[st]){deco_rm(s)continue}s1=swhile(s1&&!s1.seqst)s1=s1.ts_previf(s1){while(s1!=s){if(s1.st==st){if(o[1])sym_ott(s1,-staff_d[st])if(o[0])sym_ott(s1,-o[0]*7)}s1=s1.ts_next}}if(o[0]){staff_d[st]=-o[0]*7}else{staff_d[st]=0}}if(staff_d[st])sym_ott(s,staff_d[st])}}function mrest_expand(){var s,s2function mexp(s){var bar,s3,s4,tim,nbar,nb=s.nmes,dur=s.dur/nb,s2=s.nextwhile(!s2.bar_type)s2=s2.nextbar=s2while(!s2.bar_num)s2=s2.ts_prevnbar=s2.bar_num-s.nmess.type=C.RESTs.notes[0].dur=s.dur=s.dur_orig=durs.nflags=-2s.head=C.FULLs.fmr=1tim=s.time+durs3=swhile(--nb>0){s2=clone(bar)delete s2.solndelete s2.a_gchdelete s2.a_dddelete s2.textdelete s2.rbstartdelete s2.rbstoplkvsym(s2,s.next)s2.time=timwhile(s3.time<tim)s3=s3.ts_nextwhile(s3&&s3.v<s.v&&s3.type==C.BAR)s3=s3.ts_nextif(s3){if(s3.bar_type)s3.seqst=0lktsym(s2,s3)if(s3.type==C.BAR)delete s3.bar_num}else{s3=swhile(s3.ts_next)s3=s3.ts_nexts3.ts_next=s2s2.ts_prev=s3s2.ts_next=null}nbar++if(s2.seqst){s2.bar_num=nbars4=s2.ts_next}else{delete s2.bar_nums4=s2.ts_prev}s2.bar_type=s4.bar_type||"|"if(s4.bar_num&&!s4.seqst)delete s4.bar_nums4=clone(s)delete s4.a_dddelete s4.solndelete s4.a_gchdelete s4.partif(s2.next){s4.next=s2.nexts4.next.prev=s4}else{s4.next=null}s2.next=s4s4.prev=s2s4.time=timwhile(s3&&!s3.dur&&s3.time==tim)s3=s3.ts_nextwhile(s3&&s3.v<s.v){s3=s3.ts_nextif(s3&&s3.seqst)break}if(s3){if(s3.dur)s3.seqst=0lktsym(s4,s3)}else{s3=swhile(s3.ts_next)s3=s3.ts_nexts3.ts_next=s4s4.ts_prev=s3s4.ts_next=null}tim+=durs=s3=s4}}for(s=tsfirst;s;s=s.ts_next){if(s.type!=C.MREST)continueif(!s.seqst&&w_tb[s.ts_prev.type]){s2=s}else{s2=s.ts_nextwhile(!s2.seqst){if(s2.type!=C.MREST||s2.nmes!=s.nmes)breaks2=s2.ts_next}}if(!s2.seqst){while(s.type==C.MREST){mexp(s)s=s.ts_next}}else{s=s2.ts_prev}}}function set_auto_clef(st,s_start,clef_type_start){var s,time,s2,s3,max=12,min=20for(s=s_start;s;s=s.ts_next){if(s.type==C.STAVES&&s!=s_start)breakif(s.st!=st)continueif(s.type!=C.NOTE){if(s.type==C.CLEF){if(s.clef_type!='a')breakunlksym(s)}continue}if(s.notes[0].pit<min)min=s.notes[0].pitif(s.notes[s.nhd].pit>max)max=s.notes[s.nhd].pit}if(min>=19||(min>=13&&clef_type_start!='b'))return't'if(max<=13||(max<=19&&clef_type_start!='t'))return'b'if(clef_type_start=='a'){if((max+min)/2>=16)clef_type_start='t'elseclef_type_start='b'}var clef_type=clef_type_start,s_last=s,s_last_chg=nullfor(s=s_start;s!=s_last;s=s.ts_next){if(s.type==C.STAVES&&s!=s_start)breakif(s.st!=st||s.type!=C.NOTE)continuetime=s.timeif(clef_type=='t'){if(s.notes[0].pit>12||s.notes[s.nhd].pit>20){if(s.notes[0].pit>20)s_last_chg=scontinue}s2=s.ts_previf(s2&&s2.time==time&&s2.st==st&&s2.type==C.NOTE&&s2.notes[0].pit>=19)continues2=s.ts_nextif(s2&&s2.st==st&&s2.time==time&&s2.type==C.NOTE&&s2.notes[0].pit>=19)continue}else{if(s.notes[0].pit<=12||s.notes[s.nhd].pit<20){if(s.notes[s.nhd].pit<=12)s_last_chg=scontinue}s2=s.ts_previf(s2&&s2.time==time&&s2.st==st&&s2.type==C.NOTE&&s2.notes[0].pit<=13)continues2=s.ts_nextif(s2&&s2.st==st&&s2.time==time&&s2.type==C.NOTE&&s2.notes[0].pit<=13)continue}if(!s_last_chg){clef_type=clef_type_start=clef_type=='t'?'b':'t';s_last_chg=scontinue}s3=sfor(s2=s.ts_prev;s2!=s_last_chg;s2=s2.ts_prev){if(s2.st!=st)continueif(s2.type==C.BAR){s3=s2.bar_type[0]!=':'?s2:s2.nextbreak}if(s2.type!=C.NOTE)continueif(s2.beam_st&&!s2.p_v.second)s3=s2}if(s3.time==s_last_chg.time){s_last_chg=scontinue}s_last_chg=s;clef_type=clef_type=='t'?'b':'t';s2=insert_clef(s3,clef_type,clef_type=="t"?2:4);s2.clef_auto=true}return clef_type_start}function set_clefs(){var s,s2,st,v,p_voice,g,new_type,new_line,p_staff,pit,staff_clef=new Array(nstaff+1),sy=cur_sy,mid=[]staff_tb=new Array(nstaff+1)for(st=0;st<=nstaff;st++){staff_clef[st]={autoclef:true}staff_tb[st]={output:"",sc_out:""}}for(st=0;st<=sy.nstaff;st++)mid[st]=(sy.staves[st].stafflines.length-1)*3for(s=tsfirst;s;s=s.ts_next){if(s.repeat_n)set_repeat(s)switch(s.type){case C.STAVES:sy=s.syfor(st=0;st<=nstaff;st++)staff_clef[st].autoclef=truefor(v=0;v<voice_tb.length;v++){if(!sy.voices[v])continuep_voice=voice_tb[v];st=sy.voices[v].stif(!sy.voices[v].second){sy.staves[st].staffnonote=p_voice.staffnonoteif(p_voice.staffscale)sy.staves[st].staffscale=p_voice.staffscaleif(sy.voices[v].sep)sy.staves[st].sep=sy.voices[v].sepif(sy.voices[v].maxsep)sy.staves[st].maxsep=sy.voices[v].maxsep}s2=p_voice.clefif(!s2.clef_auto)staff_clef[st].autoclef=false}for(st=0;st<=sy.nstaff;st++)mid[st]=(sy.staves[st].stafflines.length-1)*3for(v=0;v<voice_tb.length;v++){if(!sy.voices[v]||sy.voices[v].second)continuep_voice=voice_tb[v];st=sy.voices[v].st;s2=p_voice.clefif(s2.clef_auto){new_type=set_auto_clef(st,s,staff_clef[st].clef?staff_clef[st].clef.clef_type:'a');new_line=new_type=='t'?2:4}else{new_type=s2.clef_type;new_line=s2.clef_line}if(!staff_clef[st].clef){if(s2.clef_auto){if(s2.clef_type!='a')p_voice.clef=clone(p_voice.clef);p_voice.clef.clef_type=new_type;p_voice.clef.clef_line=new_line}staff_tb[st].clef=staff_clef[st].clef=p_voice.clefcontinue}if(new_type==staff_clef[st].clef.clef_type&&new_line==staff_clef[st].clef.clef_line)continueg=s.ts_prevwhile(g&&g.time==s.time&&(g.v!=v||g.st!=st))g=g.ts_previf(!g||g.time!=s.time){g=s.ts_nextwhile(g&&(g.v!=v||g.st!=st))g=g.ts_nextif(!g||g.time!=s.time)g=s}if(g.type!=C.CLEF){g=insert_clef(g,new_type,new_line)if(s2.clef_auto)g.clef_auto=true}staff_clef[st].clef=p_voice.clef=g}continuedefault:s.mid=mid[s.st]continuecase C.CLEF:break}if(s.clef_type=='a'){s.clef_type=set_auto_clef(s.st,s.ts_next,staff_clef[s.st].clef.clef_type);s.clef_line=s.clef_type=='t'?2:4}p_voice=s.p_v;p_voice.clef=sif(s.second){unlksym(s)continue}st=s.stif(staff_clef[st].clef){if(s.clef_type==staff_clef[st].clef.clef_type&&s.clef_line==staff_clef[st].clef.clef_line){continue}}else{staff_tb[st].clef=s}staff_clef[st].clef=s}sy=cur_syfor(v=0;v<voice_tb.length;v++){if(!sy.voices[v])continues2=voice_tb[v].symif(!s2||s2.notes[0].pit!=127)continuest=sy.voices[v].stswitch(staff_tb[st].clef.clef_type){default:pit=22breakcase"c":pit=16breakcase"b":pit=10break}for(s=s2;s;s=s.next)s.notes[0].pit=pit}}var delta_tb={t:0-2*2,c:6-3*2,b:12-4*2,p:0-3*2}var rest_sp=[[18,18],[12,18],[12,12],[6,12],[6,8],[10,10],[6,4],[10,0],[10,4],[10,10]]Abc.prototype.set_pitch=function(last_s){var s,s2,g,st,delta,pitch,note,dur=C.BLEN,m=nstaff+1,staff_delta=new Int16Array(m*2),sy=cur_syfor(st=0;st<=nstaff;st++){s=staff_tb[st].clef;staff_delta[st]=delta_tb[s.clef_type]+s.clef_line*2if(s.clefpit)staff_delta[st]+=s.clefpitif(cfmt.sound){if(s.clef_octave&&!s.clef_oct_transp)staff_delta[st]+=s.clef_octave}else{if(s.clef_oct_transp)staff_delta[st]-=s.clef_octave}}for(s=tsfirst;s!=last_s;s=s.ts_next){st=s.stswitch(s.type){case C.CLEF:staff_delta[st]=delta_tb[s.clef_type]+s.clef_line*2if(s.clefpit)staff_delta[st]+=s.clefpitif(cfmt.sound){if(s.clef_octave&&!s.clef_oct_transp)staff_delta[st]+=s.clef_octave}else{if(s.clef_oct_transp)staff_delta[st]-=s.clef_octave}set_yval(s)breakcase C.GRACE:for(g=s.extra;g;g=g.next){delta=staff_delta[g.st]if(delta&&!s.p_v.ckey.k_drum){for(m=0;m<=g.nhd;m++){note=g.notes[m];note.opit=note.pitnote.pit+=delta}}g.ymn=3*(g.notes[0].pit-18)-2;g.ymx=3*(g.notes[g.nhd].pit-18)+2}set_yval(s)breakcase C.KEY:s.k_y_clef=staff_delta[st]default:set_yval(s)breakcase C.MREST:if(s.invis)breaks.y=12;s.ymx=24+15;s.ymn=-2breakcase C.REST:if(s.rep_nb>1||s.bar_mrep){s.y=12s.ymx=38s.ymn=0break}if(voice_tb.length==1){s.y=12;s.ymx=24;s.ymn=0break}case C.NOTE:delta=staff_delta[st]if(delta&&!s.p_v.ckey.k_drum){for(m=s.nhd;m>=0;m--){note=s.notes[m]note.opit=note.pitnote.pit+=delta}}if(s.type==C.REST){s.y=(((s.notes[0].pit-18)/2)|0)*6;s.ymx=s.y+rest_sp[5-s.nflags][0];s.ymn=s.y-rest_sp[5-s.nflags][1]}if(s.dur<dur)dur=s.durbreak}}if(!last_s)smallest_duration=dur}Abc.prototype.set_stem_dir=function(){var t,u,i,st,rvoice,v,v_st,st_v,vobj,v_st_tb,st_v_tb=[],s=tsfirst,sy=cur_sy,nst=sy.nstaffwhile(s){for(st=0;st<=nst;st++)st_v_tb[st]=[]v_st_tb=[]for(u=s;u;u=u.ts_next){if(u.type==C.BAR)break;if(u.type==C.STAVES){if(u!=s)breaksy=s.syfor(st=nst;st<=sy.nstaff;st++)st_v_tb[st]=[]nst=sy.nstaffcontinue}if((u.type!=C.NOTE&&u.type!=C.REST)||u.invis)continuest=u.st;if(st>nst){var msg="*** fatal set_stem_dir(): bad staff number "+st+" max "+nst;error(2,null,msg);throw new Error(msg)}v=u.v;v_st=v_st_tb[v]if(!v_st){v_st={st1:-1,st2:-1}v_st_tb[v]=v_st}if(v_st.st1<0){v_st.st1=st}else if(v_st.st1!=st){if(st>v_st.st1){if(st>v_st.st2)v_st.st2=st}else{if(v_st.st1>v_st.st2)v_st.st2=v_st.st1;v_st.st1=st}}st_v=st_v_tb[st];rvoice=sy.voices[v].range;for(i=st_v.length;--i>=0;){vobj=st_v[i]if(vobj.v==rvoice)break}if(i<0){vobj={v:rvoice,ymx:0,ymn:24}for(i=0;i<st_v.length;i++){if(rvoice<st_v[i].v){st_v.splice(i,0,vobj)break}}if(i==st_v.length)st_v.push(vobj)}if(u.type!=C.NOTE)continueif(u.ymx>vobj.ymx)vobj.ymx=u.ymxif(u.ymn<vobj.ymn)vobj.ymn=u.ymnif(u.xstem){if(u.ts_prev.st!=st-1||u.ts_prev.type!=C.NOTE){error(1,s,"Bad !xstem!");u.xstem=false}else{u.ts_prev.multi=1;u.multi=1;u.stemless=true}}}for(;s!=u;s=s.ts_next){if(s.multi)continueswitch(s.type){default:continuecase C.REST:if((s.combine!=undefined&&s.combine<0)||!s.ts_next||s.ts_next.type!=C.REST||s.ts_next.st!=s.st||s.time!=s.ts_next.time||s.dur!=s.ts_next.dur||(s.a_dd&&s.ts_next.a_dd)||(s.a_gch&&s.ts_next.a_gch)||s.invis)breakif(s.ts_next.a_dd)s.a_dd=s.ts_next.a_ddif(s.ts_next.a_gch)s.a_gch=s.ts_next.a_gchunlksym(s.ts_next)breakcase C.NOTE:case C.GRACE:break}st=s.st;v=s.v;v_st=v_st_tb[v];st_v=st_v_tb[st]if(v_st&&v_st.st2>=0){if(st==v_st.st1)s.multi=-1else if(st==v_st.st2)s.multi=1continue}if(st_v.length<=1){if(s.floating)s.multi=st==voice_tb[v].st?-1:1continue}rvoice=sy.voices[v].rangefor(i=st_v.length;--i>=0;){if(st_v[i].v==rvoice)break}if(i<0)continueif(i==st_v.length-1){s.multi=-1}else{s.multi=1if(i&&i+2==st_v.length){if(st_v[i].ymn-s.fmt.stemheight>=st_v[i+1].ymx)s.multi=-1;t=s.ts_nextif(s.ts_prev&&s.ts_prev.time==s.time&&s.ts_prev.st==s.st&&s.notes[s.nhd].pit==s.ts_prev.notes[0].pit&&s.beam_st&&s.beam_end&&(!t||t.st!=s.st||t.time!=s.time))s.multi=-1}}}while(s&&s.type==C.BAR)s=s.ts_next}}function set_rest_offset(){var s,s2,v,end_time,not_alone,v_s,y,ymax,ymin,shift,dots,dx,v_s_tb=[],sy=cur_syfor(s=tsfirst;s;s=s.ts_next){if(s.invis)continueif(s.type==C.STAVES)sy=s.syif(!s.dur)continuev_s=v_s_tb[s.v]if(!v_s){v_s={}v_s_tb[s.v]=v_s}v_s.s=s;v_s.st=s.st;v_s.end_time=s.time+s.durif(s.type!=C.REST)continueymin=-127;ymax=127;not_alone=dots=falsefor(v=0;v<=v_s_tb.length;v++){v_s=v_s_tb[v]if(!v_s||!v_s.s||v_s.st!=s.st||v==s.v)continueif(v_s.end_time<=s.time)continuenot_alone=true;s2=v_s.sif(sy.voices[v].range<sy.voices[s.v].range){if(s2.time==s.time){if(s2.ymn<ymax){ymax=s2.ymnif(s2.dots)dots=true}}else{if(s2.y<ymax)ymax=s2.y}}else{if(s2.time==s.time){if(s2.ymx>ymin){ymin=s2.ymxif(s2.dots)dots=true}}else{if(s2.y>ymin)ymin=s2.y}}}end_time=s.time+s.durfor(s2=s.ts_next;s2;s2=s2.ts_next){if(s2.time>=end_time)breakif(s2.st!=s.st||!s2.dur||s2.invis)continuenot_alone=trueif(sy.voices[s2.v].range<sy.voices[s.v].range){if(s2.time==s.time){if(s2.ymn<ymax){ymax=s2.ymnif(s2.dots)dots=true}}else{if(s2.y<ymax)ymax=s2.y}}else{if(s2.time==s.time){if(s2.ymx>ymin){ymin=s2.ymxif(s2.dots)dots=true}}else{if(s2.y>ymin)ymin=s2.y}}}if(!not_alone){s.y=12;s.ymx=24;s.ymn=0continue}if(ymax==127&&s.y<12){shift=12-s.ys.y+=shift;s.ymx+=shift;s.ymn+=shift}if(ymin==-127&&s.y>12){shift=s.y-12s.y-=shift;s.ymx-=shift;s.ymn-=shift}shift=ymax-s.ymxif(shift<0){shift=Math.ceil(-shift/6)*6if(s.ymn-shift>=ymin){s.y-=shift;s.ymx-=shift;s.ymn-=shiftcontinue}dx=dots?15:10;s.notes[0].shhd=dx;s.xmx=dxcontinue}shift=ymin-s.ymnif(shift>0){shift=Math.ceil(shift/6)*6if(s.ymx+shift<=ymax){s.y+=shift;s.ymx+=shift;s.ymn+=shiftcontinue}dx=dots?15:10;s.notes[0].shhd=dx;s.xmx=dxcontinue}}}function new_sym(s,p_v,last_s){s.p_v=p_vs.v=p_v.vs.st=p_v.sts.time=last_s.timeif(p_v.last_sym){s.next=p_v.last_sym.nextif(s.next)s.next.prev=s;p_v.last_sym.next=s;s.prev=p_v.last_sym}p_v.last_sym=s;lktsym(s,last_s)}function init_music_line(){var p_voice,s,s1,s2,s3,last_s,v,st,shr,shrmx,shl,shlp,p_st,top,nv=voice_tb.length,fmt=tsfirst.fmtfor(v=0;v<nv;v++){if(!cur_sy.voices[v])continuep_voice=voice_tb[v];p_voice.st=cur_sy.voices[v].stp_voice.second=cur_sy.voices[v].second;p_voice.last_sym=p_voice.sym;for(s=p_voice.sym;s&&s.time==tsfirst.time;s=s.next){switch(s.type){case C.CLEF:case C.KEY:case C.METER:switch(s.type){case C.CLEF:staff_tb[s.st].clef=sbreakcase C.KEY:s.p_v.ckey=sbreakcase C.METER:s.p_v.meter=sinsert_meter=cfmt.writefields.indexOf('M')>=0&&s.a_meter.lengthbreak}if(s.part)s.next.part=s.partunlksym(s)case C.TEMPO:case C.BLOCK:case C.REMARK:continue}break}}last_s=tsfirstfor(v=0;v<nv;v++){p_voice=voice_tb[v]if(!cur_sy.voices[v]||(cur_sy.voices[v].second&&!p_voice.bar_start))continuest=cur_sy.voices[v].stif(!staff_tb[st]||!staff_tb[st].clef)continues=clone(staff_tb[st].clef);s.v=v;s.p_v=p_voice;s.st=st;s.time=tsfirst.time;s.prev=null;s.next=p_voice.symif(s.next)s.next.prev=s;p_voice.sym=p_voice.last_sym=ss.ts_next=last_s;if(last_s)s.ts_prev=last_s.ts_prevelses.ts_prev=nullif(!s.ts_prev){tsfirst=s}else{s.ts_prev.ts_next=sdelete s.seqst}if(last_s)last_s.ts_prev=sdelete s.clef_small;delete s.parts.second=cur_sy.voices[v].secondif(!cur_sy.st_print[st])s.invis=trueelsedelete s.inviss.fmt=fmt}for(v=0;v<nv;v++){if(!cur_sy.voices[v]||cur_sy.voices[v].second||!cur_sy.st_print[cur_sy.voices[v].st])continuep_voice=voice_tb[v]s2=p_voice.ckeyif(s2.k_sf||s2.k_a_acc){s=clone(s2)new_sym(s,p_voice,last_s)delete s.invisdelete s.parts.k_old_sf=s2.k_sfs.fmt=fmt}}if(insert_meter){for(v=0;v<nv;v++){p_voice=voice_tb[v];s2=p_voice.meterif(!cur_sy.voices[v]||cur_sy.voices[v].second||!cur_sy.st_print[cur_sy.voices[v].st])continues=clone(s2)new_sym(s,p_voice,last_s)delete s.parts.fmt=fmt}insert_meter=false}for(v=0;v<nv;v++){p_voice=voice_tb[v]if(p_voice.sls.length){s={type:C.BAR,fname:last_s.fname,bar_type:"|",dur:0,multi:0,invis:true,sls:p_voice.sls,fmt:fmt}new_sym(s,p_voice,last_s)p_voice.sls=[]}}for(v=0;v<nv;v++){p_voice=voice_tb[v];s2=p_voice.bar_start;p_voice.bar_start=nullfor(s=last_s;s&&s.time==last_s.time;s=s.ts_next){if(s.rbstop){s2=nullbreak}}if(!s2)continueif(!cur_sy.voices[v]||!cur_sy.st_print[cur_sy.voices[v].st])continueif(p_voice.last_sym.type==C.BAR){if(!p_voice.last_sym.rbstop)p_voice.last_sym.rbstart=1}else{new_sym(s2,p_voice,last_s)s2.fmt=fmt}}self.set_pitch(last_s);s=tsfirsts.seqst=truefor(s=last_s;s.ts_next&&!s.ts_next.seqst;s=s.ts_next);if(s.ts_next&&s.ts_next.type!=C.CLEF&&!s.ts_next.a_ly)for(s=s.ts_next;s.ts_next&&!s.ts_next.seqst;s=s.ts_next);s2=s.ts_nexts.ts_next=nullset_allsymwidth()s.ts_next=s2}function check_end_bar(){var s2,s=tsfirstwhile(s.ts_next)s=s.ts_nextif(s.type!=C.BAR){s2=_bar(s)s2.ts_prev=ss.next=s.ts_next=s2}}function set_words(p_voice){var s,s2,nflags,lastnote,res,start_flag=true,pitch=127function trem_adj(s){s.prev.trem2=trues.prev.head=++s.headif(--s.nflags>0){s.nflags+=s.ntrem}else{if(s.nflags<=-2){s.stemless=trues.prev.stemless=true}s.nflags=s.ntrem}s.prev.nflags=s.nflags}for(s=p_voice.sym;s;s=s.next){if(s.type==C.NOTE){pitch=s.notes[0].pitbreak}}for(s=p_voice.sym;s;s=s.next){if(s.a_gch)self.gch_build(s)switch(s.type){case C.MREST:start_flag=truebreakcase C.BAR:res=s.fmt.bardef[s.bar_type]if(res)s.bar_type=resif(!s.beam_on)start_flag=trueif(!s.next&&s.prev&&!s.invis&&s.prev.head==C.OVALBARS)s.prev.head=C.SQUAREbreakcase C.GRACE:for(s2=s.extra;s2;s2=s2.next){s2.notes.sort(abc2svg.pitcmp)res=identify_note(s2,s2.dur_orig)s2.head=res[0]s2.dots=res[1]s2.nflags=res[2]if(s2.trem2&&(!s2.next||s2.next.trem2))trem_adj(s2)}breakcase C.NOTE:case C.REST:res=identify_note(s,s.dur_orig);s.head=res[0];s.dots=res[1];s.nflags=res[2]if(s.nflags<=-2)s.stemless=trueif(s.xstem)s.nflags=0if(s.trem1){if(s.nflags>0)s.nflags+=s.ntremelses.nflags=s.ntrem}if(s.next&&s.next.trem2)breakif(s.trem2){trem_adj(s)break}nflags=s.nflagsif(s.ntrem)nflags+=s.ntremif(s.type==C.REST&&s.beam_end&&!s.beam_on){start_flag=true}if(start_flag||nflags<=0){if(lastnote){lastnote.beam_end=true;lastnote=null}if(nflags<=0){s.beam_st=s.beam_end=true}else if(s.type==C.NOTE||s.beam_on){s.beam_st=true;start_flag=false}}if(s.beam_end)start_flag=trueif(s.type==C.NOTE||s.beam_on)lastnote=sbreak}if(s.type==C.NOTE){if(s.nhd)s.notes.sort(abc2svg.pitcmp)pitch=s.notes[0].pitfor(s2=s.prev;s2;s2=s2.prev){if(s2.type!=C.REST)breaks2.notes[0].pit=pitch}}else{if(!s.notes){s.notes=[]s.notes[0]={}s.nhd=0}s.notes[0].pit=pitch}}if(lastnote)lastnote.beam_end=true}function set_rb(p_voice){var s2,n,s=p_voice.symwhile(s){if(s.type!=C.BAR||!s.rbstart||s.norepbra){s=s.nextcontinue}n=0;s2=nullfor(s=s.next;s;s=s.next){if(s.type!=C.BAR)continueif(s.rbstop)breakif(!s.next){s.rbstop=2break}n++if(n==s.fmt.rbmin)s2=sif(n==s.fmt.rbmax){if(s2)s=s2;s.rbstop=1break}}}}var delpit=[0,-7,-14,0]function set_global(){var p_voice,v,nv=voice_tb.length,sy=cur_sy,st=sy.nstaffinsert_meter=cfmt.writefields.indexOf('M')>=0while(1){sy=sy.nextif(!sy)breakif(sy.nstaff>st)st=sy.nstaff}nstaff=st;check_end_bar()for(v=0;v<nv;v++){p_voice=voice_tb[v];set_words(p_voice)p_voice.ckey=p_voice.keyset_rb(p_voice)}if(nv>1){set_float()if(glovar.mrest_p)mrest_expand()}if(glovar.ottava&&cfmt.sound!="play")set_ottava();set_clefs();self.set_pitch(null)}function get_lshift(){var st,v,p_v,p1,po,fnt,w,sy=cur_sy,lsh1=0,lsho=0,nv=voice_tb.lengthfunction get_wx(p,wx){var w,j,i=0p+='\n'while(1){j=p.indexOf("\n",i)if(j<0)breakw=strwh(p.slice(i,j))[0]+12if(w>wx)wx=wif(j<0)breaki=j+1}return wx}for(v=0;v<nv;v++){p_v=voice_tb[v]p1=p_v.nmpo=p_v.snmif((p1||po)&&!fnt){set_font("voice")fnt=gene.deffont}if(p1){w=get_wx(p1,lsh1)if(w>lsh1)lsh1=w}if(po){w=get_wx(po,lsho)if(w>lsho)lsho=w}}w=0while(sy){for(st=0;st<=sy.nstaff;st++){if(sy.staves[st].flags&(OPEN_BRACE2|OPEN_BRACKET2)){w=12break}if(sy.staves[st].flags&(OPEN_BRACE|OPEN_BRACKET))w=6}if(w==12)breaksy=sy.next}lsh1+=wlsho+=wreturn[lsh1,lsho]}function set_indent(lsh){var st,v,w,p_voice,p,i,j,font,vnt=0,nv=voice_tb.lengthfor(v=0;v<nv;v++){p_voice=voice_tb[v]if(!cur_sy.voices[v]||!gene.st_print[p_voice.st])continueif(p_voice.new_name){vnt=2break}if(p_voice.snm)vnt=1}gene.vnt=vntreturn vnt==2?lsh[0]:lsh[1]}function set_beams(sym){var s,t,g,beam,s_opp,n,m,mid_p,pu,pd,laststem=-1for(s=sym;s;s=s.next){if(s.type!=C.NOTE){if(s.type!=C.GRACE)continueg=s.extraif(g.stem==2){s_opp=scontinue}if(!s.stem)s.stem=s.multi||1for(;g;g=g.next){g.stem=s.stem;g.multi=s.multi}continue}if(!s.stem&&s.multi)s.stem=s.multiif(!s.stem){mid_p=s.mid/3+18if(beam){s.stem=laststem}else if(s.beam_st&&!s.beam_end){beam=true;pu=s.notes[s.nhd].pit;pd=s.notes[0].pitfor(g=s.next;g;g=g.next){if(g.type!=C.NOTE)continueif(g.stem||g.multi)s.stem=g.stem||g.multiif(g.notes[g.nhd].pit>pu)pu=g.notes[g.nhd].pitif(g.notes[0].pit<pd)pd=g.notes[0].pitif(g.beam_end)break}if(!s.stem&&g.beam_end){if(pu+pd<mid_p*2){s.stem=1}else if(pu+pd>mid_p*2){s.stem=-1}else{if(s.fmt.bstemdown)s.stem=-1}}if(!s.stem)s.stem=laststem}else{n=(s.notes[s.nhd].pit+s.notes[0].pit)/2if(n==mid_p&&s.nhd>1){for(m=0;m<s.nhd;m++){if(s.notes[m].pit>=mid_p)break}n=m*2<s.nhd?mid_p-1:mid_p+1}if(n<mid_p)s.stem=1else if(n>mid_p||s.fmt.bstemdown)s.stem=-1elses.stem=laststem}}else{if(s.beam_st&&!s.beam_end)beam=true}if(s.beam_end)beam=false;laststem=s.stem;if(s_opp){for(g=s_opp.extra;g;g=g.next)g.stem=-laststem;s_opp.stem=-laststem;s_opp=null}}}function same_head(s1,s2){var i1,i2,l1,l2,head,i11,i12,i21,i22,sh1,sh2,shu=s1.fmt.shiftunison||0if(shu>=3)return falseif((l1=s1.dur)>=C.BLEN)return falseif((l2=s2.dur)>=C.BLEN)return falseif(s1.stemless&&s2.stemless)return falseif(s1.dots!=s2.dots){if(shu&1||s1.dots*s2.dots!=0)return false}if(s1.stem*s2.stem>0)return falsei1=i2=0if(s1.notes[0].pit>s2.notes[0].pit){if(s1.stem<0)return falsewhile(s2.notes[i2].pit!=s1.notes[0].pit){if(++i2>s2.nhd)return false}}else if(s1.notes[0].pit<s2.notes[0].pit){if(s2.stem<0)return falsewhile(s2.notes[0].pit!=s1.notes[i1].pit){if(++i1>s1.nhd)return false}}if(s2.notes[i2].acc!=s1.notes[i1].acc)return false;i11=i1;i21=i2;sh1=s1.notes[i1].shhd;sh2=s2.notes[i2].shhddo{i1++;i2++if(i1>s1.nhd){break}if(i2>s2.nhd){break}if(s2.notes[i2].acc!=s1.notes[i1].acc)return falseif(sh1<s1.notes[i1].shhd)sh1=s1.notes[i1].shhdif(sh2<s2.notes[i2].shhd)sh2=s2.notes[i2].shhd}while(s2.notes[i2].pit==s1.notes[i1].pit)if(i1<=s1.nhd){if(i2<=s2.nhd)return falseif(s2.stem>0)return false}else if(i2<=s2.nhd){if(s1.stem>0)return false}i12=i1;i22=i2;head=0if(l1!=l2){if(l1<l2){l1=l2;l2=s1.dur}if(l1<C.BLEN/2){if(s2.dots)head=2else if(s1.dots)head=1}else if(l2<C.BLEN/4){if(shu&2)return falsehead=s2.dur>=C.BLEN/2?2:1}else{return false}}if(!head)head=s1.p_v.scale<s2.p_v.scale?2:1if(head==1){for(i2=i21;i2<i22;i2++){s2.notes[i2].invis=truedelete s2.notes[i2].acc}for(i2=0;i2<=s2.nhd;i2++)s2.notes[i2].shhd+=sh1}else{for(i1=i11;i1<i12;i1++){s1.notes[i1].invis=truedelete s1.notes[i1].acc}for(i1=0;i1<=s1.nhd;i1++)s1.notes[i1].shhd+=sh2}return true}function unison_acc(s1,s2,i1,i2){var m,d,accacc=s2.notes[i2].accif(!acc){d=w_note[s2.head]*2+s2.xmx+s1.notes[i1].shac+2acc=s1.notes[i1].accif(typeof acc=="object")d+=2if(s2.dots)d+=6for(m=0;m<=s1.nhd;m++){s1.notes[m].shhd+=d;s1.notes[m].shac-=d}s1.xmx+=d}else{d=w_note[s1.head]*2+s1.xmx+s2.notes[i2].shac+2if(typeof acc=="object")d+=2if(s1.dots)d+=6for(m=0;m<=s2.nhd;m++){s2.notes[m].shhd+=d;s2.notes[m].shac-=d}s2.xmx+=d}}var MAXPIT=48*2function set_left(s){var m,i,j,shift,w_base=w_note[s.head],w=w_base,left=[]for(i=0;i<MAXPIT;i++)left.push(-100)if(s.nflags>-2){if(s.stem>0){w=-w;i=s.notes[0].pit*2;j=(Math.ceil((s.ymx-2)/3)+18)*2}else{i=(Math.ceil((s.ymn+2)/3)+18)*2;j=s.notes[s.nhd].pit*2}if(i<0)i=0if(j>=MAXPIT)j=MAXPIT-1while(i<=j)left[i++]=w}shift=s.notes[s.stem>0?0:s.nhd].shhd;for(m=0;m<=s.nhd;m++){w=-s.notes[m].shhd+w_base+shift;i=s.notes[m].pit*2if(i<0)i=0else if(i>=MAXPIT-1)i=MAXPIT-2if(w>left[i])left[i]=wif(s.head!=C.SQUARE)w-=1if(w>left[i-1])left[i-1]=wif(w>left[i+1])left[i+1]=w}return left}function set_right(s){var m,i,j,k,shift,w_base=w_note[s.head],w=w_base,flags=s.nflags>0&&s.beam_st&&s.beam_end,right=[]for(i=0;i<MAXPIT;i++)right.push(-100)if(s.nflags>-2){if(s.stem<0){w=-w;i=(Math.ceil((s.ymn+2)/3)+18)*2;j=s.notes[s.nhd].pit*2;k=i+4}else{i=s.notes[0].pit*2;j=(Math.ceil((s.ymx-2)/3)+18)*2}if(i<0)i=0if(j>MAXPIT)j=MAXPITwhile(i<j)right[i++]=w}if(flags){if(s.stem>0){if(s.xmx==0)i=s.notes[s.nhd].pit*2elsei=s.notes[0].pit*2;i+=4if(i<0)i=0for(;i<MAXPIT&&i<=j-4;i++)right[i]=11}else{i=kif(i<0)i=0for(;i<MAXPIT&&i<=s.notes[0].pit*2-4;i++)right[i]=3.5}}shift=s.notes[s.stem>0?0:s.nhd].shhdfor(m=0;m<=s.nhd;m++){w=s.notes[m].shhd+w_base-shift;i=s.notes[m].pit*2if(i<0)i=0else if(i>=MAXPIT-1)i=MAXPIT-2if(w>right[i])right[i]=wif(s.head!=C.SQUARE)w-=1if(w>right[i-1])right[i-1]=wif(w>right[i+1])right[i+1]=w}return right}function set_overlap(){var s,s1,s2,s3,i,i1,i2,m,sd,t,dp,d,d2,dr,dr2,dx,left1,right1,left2,right2,right3,pl,pr,sy=cur_syfunction v_invert(){s1=s2;s2=s;d=d2;pl=left1;pr=right1;dr2=dr}for(s=tsfirst;s;s=s.ts_next){if(s.type!=C.NOTE||s.invis){if(s.type==C.STAVES)sy=s.sycontinue}if(s.xstem&&s.ts_prev.stem<0){for(m=0;m<=s.nhd;m++){s.notes[m].shhd-=7;s.notes[m].shac+=16}}s2=swhile(1){s2=s2.ts_nextif(!s2)breakif(s2.time!=s.time){s2=nullbreak}if(s2.type==C.NOTE&&!s2.invis&&s2.st==s.st)break}if(!s2)continues1=sif(sy.voices[s1.v].range<sy.voices[s2.v].range)s2.dot_low=trueelses1.dot_low=trueif(s1.ymn>s2.ymx||s1.ymx<s2.ymn)continueif(same_head(s1,s2))continueif(!s1.dots&&!s2.dots)if((s1.stem>0&&s2.stem<0&&s1.notes[0].pit==s2.notes[s2.nhd].pit+1)||(s1.stem<0&&s2.stem>0&&s1.notes[s1.nhd].pit+1==s2.notes[0].pit)){if(s1.stem<0){s1=s2;s2=s}d=s1.notes[0].shhd+7for(m=0;m<=s2.nhd;m++)s2.notes[m].shhd+=ds2.xmx+=ds1.xmx=s2.xmxcontinue}right1=set_right(s1);left2=set_left(s2);s3=s1.ts_previf(s3&&s3.time==s1.time&&s3.st==s1.st&&s3.type==C.NOTE&&!s3.invis){right3=set_right(s3)for(i=0;i<MAXPIT;i++){if(right3[i]>right1[i])right1[i]=right3[i]}}else{s3=null}d=-10for(i=0;i<MAXPIT;i++){if(left2[i]+right1[i]>d)d=left2[i]+right1[i]}if(d<-3&&((s2.notes[0].pit&1)||!(s1.dots||s2.dots)||(!(s1.notes[s1.nhd].pit==s2.notes[0].pit+2&&s1.dot_low)&&!(s1.notes[s1.nhd].pit+2==s2.notes[0].pit&&s2.dot_low))))continueright2=set_right(s2);left1=set_left(s1)if(s3){right3=set_left(s3)for(i=0;i<MAXPIT;i++){if(right3[i]>left1[i])left1[i]=right3[i]}}d2=dr=dr2=-100for(i=0;i<MAXPIT;i++){if(left1[i]+right2[i]>d2)d2=left1[i]+right2[i]if(right2[i]>dr2)dr2=right2[i]if(right1[i]>dr)dr=right1[i]}t=0;i1=s1.nhd;i2=s2.nhdwhile(1){dp=s1.notes[i1].pit-s2.notes[i2].pitswitch(dp){case 2:if(!(s1.notes[i1].pit&1))s1.dot_low=falsebreakcase 1:if(s1.notes[i1].pit&1)s2.dot_low=trueelses1.dot_low=falsebreakcase 0:if(s1.notes[i1].acc!=s2.notes[i2].acc){t=-1break}if(s2.notes[i2].acc){if(!s1.notes[i1].acc)s1.notes[i1].acc=s2.notes[i2].accs2.notes[i2].acc=0}if(s1.dots&&s2.dots&&(s1.notes[i1].pit&1))t=1breakcase-1:if(s1.notes[i1].pit&1)s2.dot_low=falseelses1.dot_low=truebreakcase-2:if(!(s1.notes[i1].pit&1))s2.dot_low=falsebreak}if(t<0)breakif(dp>=0){if(--i1<0)break}if(dp<=0){if(--i2<0)break}}if(t<0){unison_acc(s1,s2,i1,i2)continue}sd=0;if(s1.dots){if(s2.dots){if(!t)sd=1}else{v_invert()}}else if(s2.dots){if(d2+dr<d+dr2)sd=1}pl=left2;pr=right2if(!s3&&d2+dr<d+dr2)v_invert()d+=3if(d<0)d=0;m=s1.stem>=0?0:s1.nhd;d+=s1.notes[m].shhd;m=s2.stem>=0?0:s2.nhd;d-=s2.notes[m].shhdif(s1.dots){dx=7.7+s1.xmx+3.5*s1.dots-3.5+3;if(!sd){d2=-100;for(i1=0;i1<=s1.nhd;i1++){i=s1.notes[i1].pitif(!(i&1)){if(!s1.dot_low)i++elsei--}i*=2if(i<1)i=1else if(i>=MAXPIT-1)i=MAXPIT-2if(pl[i]>d2)d2=pl[i]if(pl[i-1]+1>d2)d2=pl[i-1]+1if(pl[i+1]+1>d2)d2=pl[i+1]+1}if(dx+d2+2>d)d=dx+d2+2}else{if(dx<d+dr2+s2.xmx){d2=0for(i1=0;i1<=s1.nhd;i1++){i=s1.notes[i1].pitif(!(i&1)){if(!s1.dot_low)i++elsei--}i*=2if(i<1)i=1else if(i>=MAXPIT-1)i=MAXPIT-2if(pr[i]>d2)d2=pr[i]if(pr[i-1]+1>d2)d2=pr[i-1]=1if(pr[i+1]+1>d2)d2=pr[i+1]+1}if(d2>4.5&&7.7+s1.xmx+2<d+d2+s2.xmx)s2.xmx=d2+3-7.7}}}for(m=s2.nhd;m>=0;m--){s2.notes[m].shhd+=d}s2.xmx+=dif(sd)s1.xmx=s2.xmx}}Abc.prototype.set_stems=function(){var s,s2,g,slen,scale,ymn,ymx,nflags,ymin,ymaxfor(s=tsfirst;s;s=s.ts_next){if(s.type!=C.NOTE){if(s.type!=C.GRACE)continueymin=ymax=s.midfor(g=s.extra;g;g=g.next){slen=GSTEMif(g.nflags>1)slen+=1.2*(g.nflags-1);ymn=3*(g.notes[0].pit-18);ymx=3*(g.notes[g.nhd].pit-18)if(s.stem>=0){g.y=ymn;g.ys=ymx+slen;ymx=Math.round(g.ys)}else{g.y=ymx;g.ys=ymn-slen;ymn=Math.round(g.ys)}ymx+=4ymn-=4if(ymn<ymin)ymin=ymnelse if(ymx>ymax)ymax=ymx;g.ymx=ymx;g.ymn=ymn}s.ymx=ymax;s.ymn=ymincontinue}set_head_shift(s);nflags=s.nflagsif(s.beam_st&&!s.beam_end){if(s.feathered_beam)nflags=++s.nflagsfor(s2=s.next;;s2=s2.next){if(s2.type==C.NOTE){if(s.feathered_beam)s2.nflags++if(s2.beam_end)break}}if(s2.nflags>nflags)nflags=s2.nflags}else if(!s.beam_st&&s.beam_end){for(s2=s.prev;;s2=s2.prev){if(s2.beam_st)break}if(s2.nflags>nflags)nflags=s2.nflags}slen=s.fmt.stemheightswitch(nflags){case 2:slen+=0;breakcase 3:slen+=4;breakcase 4:slen+=8;breakcase 5:slen+=12;break}if((scale=s.p_v.scale)!=1)slen*=(scale+1)*.5;ymn=3*(s.notes[0].pit-18)if(s.nhd>0){slen-=2;ymx=3*(s.notes[s.nhd].pit-18)}else{ymx=ymn}if(s.ntrem)slen+=2*s.ntremif(s.stemless){if(s.stem>=0){s.y=ymn;s.ys=ymx}else{s.ys=ymn;s.y=ymx}s.ymx=ymx+4;s.ymn=ymn-4}else if(s.stem>=0){if(s.notes[s.nhd].pit>26&&(nflags<=0||!s.beam_st||!s.beam_end)){slen-=2if(s.notes[s.nhd].pit>28)slen-=2}s.y=ymnif(s.notes[0].tie)ymn-=3;s.ymn=ymn-4;s.ys=ymx+slenif(s.ys<s.mid)s.ys=s.mid;s.ymx=(s.ys+2.5)|0}else{if(s.notes[0].pit<18&&(nflags<=0||!s.beam_st||!s.beam_end)){slen-=2if(s.notes[0].pit<16)slen-=2}s.ys=ymn-slenif(s.ys>s.mid)s.ys=s.mid;s.ymn=(s.ys-2.5)|0;s.y=ymxif(s.notes[s.nhd].tie)ymx+=3;s.ymx=ymx+4}}}var blocks=[]Abc.prototype.block_gen=function(s){switch(s.subtype){case"leftmargin":case"rightmargin":case"pagescale":case"pagewidth":case"scale":case"staffwidth":self.set_format(s.subtype,s.param)breakcase"mc_start":if(multicol){error(1,s,"No end of the previous %%multicol")break}multicol={posy:posy,maxy:posy,lm:cfmt.leftmargin,rm:cfmt.rightmargin,w:cfmt.pagewidth,sc:cfmt.scale}breakcase"mc_new":if(!multicol){error(1,s,"%%multicol new without start")break}if(posy>multicol.maxy)multicol.maxy=posycfmt.leftmargin=multicol.lmcfmt.rightmargin=multicol.rmcfmt.pagewidth=multicol.wcfmt.scale=multicol.scposy=multicol.posyimg.chg=1breakcase"mc_end":if(!multicol){error(1,s,"%%multicol end without start")break}if(posy<multicol.maxy)posy=multicol.maxycfmt.leftmargin=multicol.lmcfmt.rightmargin=multicol.rmcfmt.pagewidth=multicol.wcfmt.scale=multicol.scmulticol=undefinedblk_flush()img.chg=1breakcase"ml":blk_flush()user.img_out(s.text)breakcase"newpage":if(!user.page_format)breakblk_flush()if(blkdiv<0)user.img_out('</div>')blkdiv=2breakcase"sep":set_page();vskip(s.sk1);output+='<path class="stroke"\n\td="M';out_sxsy((img.width-s.l)/2-img.lm,' ',0)output+='h'+s.l.toFixed(1)+'"/>\n';vskip(s.sk2);breakcase"text":set_font(s.font)use_font(s.font)write_text(s.text,s.opt)breakcase"title":write_title(s.text,true)breakcase"vskip":vskip(s.sk);break}}function sym_staff_move(st){for(var s=tsfirst;s;s=s.ts_next){if(s.nl)breakif(s.st==st&&s.type!=C.CLEF){s.st++if(s.type!=C.TEMPO)s.invis=true}}}function set_piece(){var s,last,p_voice,st,v,nv,tmp,non_empty=[],non_empty_gl=[],sy=cur_syfunction reset_staff(st){var p_staff=staff_tb[st],sy_staff=sy.staves[st]if(!p_staff)p_staff=staff_tb[st]={}p_staff.y=0;p_staff.stafflines=sy_staff.stafflines;p_staff.staffscale=sy_staff.staffscale;p_staff.ann_top=p_staff.ann_bot=0}function set_brace(){var st,i,empty_fl,n=sy.staves.lengthfor(st=0;st<n;st++){if(!(sy.staves[st].flags&(OPEN_BRACE|OPEN_BRACE2)))continueempty_fl=0;i=stwhile(st<n){empty_fl|=non_empty[st]?1:2if(sy.staves[st].flags&(CLOSE_BRACE|CLOSE_BRACE2))breakst++}if(empty_fl==3){while(i<=st){non_empty[i]=true;non_empty_gl[i++]=true}}}}function set_top_bot(){var st,p_staff,i,j,lfor(st=0;st<=nstaff;st++){p_staff=staff_tb[st]p_staff.hlu=[]p_staff.hld=[]l=p_staff.stafflines.length;p_staff.topbar=6*(l-1)for(i=0;i<l-1;i++){switch(p_staff.stafflines[i]){case'.':case'-':continue}break}p_staff.botline=p_staff.botbar=i*6if(i>=l-2){if(p_staff.stafflines[i]!='.'){p_staff.botbar-=6;p_staff.topbar+=6}else{p_staff.botbar-=12;p_staff.topbar+=12continue}}if(!non_empty_gl[st])continuep_staff.hll=17+i*2p_staff.hlmap=new Int8Array((l-i+1)*2+2)for(j=1;i<l;i++,j+=2){switch(p_staff.stafflines[i]){case'|':case'[':p_staff.hlmap[j-1]=1;p_staff.hlmap[j]=1;p_staff.hlmap[j+1]=1break}}}}if(tsfirst.type==C.STAVES){s=tsfirsttsfirst=tsfirst.ts_nexttsfirst.ts_prev=nullif(s.seqst)tsfirst.seqst=trues.p_v.sym=s.nextif(s.next)s.next.prev=null}nstaff=sy.nstafffor(st=0;st<=nstaff;st++)reset_staff(st);for(s=tsfirst;s;s=s.ts_next){if(s.nl)breakswitch(s.type){case C.STAVES:set_brace();sy.st_print=new Uint8Array(non_empty);sy=s.sy;while(nstaff<sy.nstaff)reset_staff(++nstaff)non_empty=[]continuecase C.BLOCK:if(!s.play){blocks.push(s)unlksym(s)}else if(s.ts_next&&s.ts_next.shrink)s.ts_next.shrink=0continue}st=s.stif(st>nstaff){switch(s.type){case C.CLEF:staff_tb[st].clef=sbreakcase C.KEY:s.p_v.ckey=sbreakcase C.METER:s.p_v.meter=sbreak}unlksym(s)continue}if(non_empty[st])continueswitch(s.type){default:continuecase C.BAR:if(s.bar_mrep||sy.staves[st].staffnonote>1)breakcontinuecase C.GRACE:breakcase C.NOTE:case C.REST:case C.SPACE:case C.MREST:if(sy.staves[st].staffnonote>1)breakif(s.invis)continueif(sy.staves[st].staffnonote||s.type==C.NOTE)breakcontinue}non_empty_gl[st]=non_empty[st]=true}tsnext=s;set_brace()sy.st_print=new Uint8Array(non_empty);set_top_bot()for(st=0;st<nstaff;st++){if(!non_empty_gl[st])sym_staff_move(st)}if(!non_empty_gl[nstaff])staff_tb[nstaff].topbar=0if(tsnext){s=tsnext;delete s.nl;last=s.ts_prev;last.ts_next=null;nv=voice_tb.lengthfor(v=0;v<nv;v++){p_voice=voice_tb[v]if(p_voice.sym&&p_voice.sym.time<=tsnext.time){for(s=last;s;s=s.ts_prev){if(s.v==v){p_voice.s_next=s.next;s.next=null;break}}if(s)continue}p_voice.s_next=p_voice.sym;p_voice.sym=null}}init_music_line()gene.st_print=new Uint8Array(non_empty_gl)}Abc.prototype.set_sym_glue=function(width){var s,g,ll,x,some_grace,spf,xmin=0,xx=0,xs=0,xse=0for(s=tsfirst;s;s=s.ts_next){if(s.type==C.GRACE&&!some_grace)some_grace=sif(s.seqst){xmin+=s.shrinkif(xmin>width){error(1,s,"Line too much shrunk $1 $2 $3",xmin.toFixed(1),xx.toFixed(1),width.toFixed(1))break}if(s.space){if(s.space<s.shrink){xse+=s.shrink;xx+=s.shrink}else{xx+=s.space}}else{xs+=s.shrink}}}if(!xx){realwidth=0return}ll=!tsnext||(tsnext.type==C.BLOCK&&!tsnext.play)||blocks.lengths=tsfirstif(xmin>=width){x=0for(;s;s=s.ts_next){if(s.seqst)x+=s.shrink;s.x=x}spf_last=0}else if((ll&&xx+xs>width*(1-s.fmt.stretchlast))||(!ll&&(xx+xs>width||s.fmt.stretchstaff))){if(xx==xse)xx+=5for(var cnt=4;--cnt>=0;){spf=(width-xs-xse)/(xx-xse);xx=0;xse=0;x=0for(s=tsfirst;s;s=s.ts_next){if(s.seqst){if(s.space){if(s.space*spf<=s.shrink){xse+=s.shrink;xx+=s.shrink;x+=s.shrink}else{xx+=s.space;x+=s.space*spf}}else{x+=s.shrink}}s.x=x}if(Math.abs(x-width)<0.1)break}spf_last=spf}else{spf=1-s.fmt.maxshrinkif(spf_last&&xx*spf_last+xs<width)spf=spf_lastx=0for(;s;s=s.ts_next){if(s.seqst)x+=s.space<=s.shrink?s.shrink:s.shrink*(1-spf)+s.space*spfs.x=x}}realwidth=xfor(s=some_grace;s;s=s.ts_next){if(s.type!=C.GRACE)continueif(s.gr_shift)x=s.prev.x+s.prev.wrelsex=s.x-s.wlfor(g=s.extra;g;g=g.next)g.x+=x}}function set_sym_line(){var p_v,s,v=voice_tb.lengthwhile(--v>=0){p_v=voice_tb[v]if(p_v.sym&&p_v.s_prev){p_v.sym.prev=p_v.s_prevp_v.s_prev.next=p_v.sym}s=p_v.s_nextp_v.s_next=nullp_v.sym=sif(s){if(s.prev)s.prev.next=sp_v.s_prev=s.prevs.prev=null}else{p_v.s_prev=null}}}function set_posx(){posx=img.lm/cfmt.scale}function gen_init(){var s=tsfirst,tim=s.timefor(;s;s=s.ts_next){if(s.time!=tim){set_page()return}switch(s.type){case C.NOTE:case C.REST:case C.MREST:case C.SPACE:set_page()returndefault:continuecase C.STAVES:cur_sy=s.sycontinuecase C.BLOCK:if(s.play)continueself.block_gen(s)break}unlksym(s)if(s.p_v.s_next==s)s.p_v.s_next=s.next}tsfirst=null}Abc.prototype.output_music=function(){var v,lwidth,indent,lsh,line_height,ts1st,tslast,p_v,nv=voice_tb.lengthset_global()if(nv>1)self.set_stem_dir()for(v=0;v<nv;v++)set_beams(voice_tb[v].sym);self.set_stems()set_acc_shft()if(nv>1){set_rest_offset();set_overlap()}set_allsymwidth(1)lsh=get_lshift()if(cfmt.singleline){v=get_ck_width();lwidth=lsh[0]+v[0]+v[1]+get_width(tsfirst,null)[0]v=cfmt.singleline==2?get_lwidth():lwidthif(v>lwidth)lwidth=velseimg.width=lwidth*cfmt.scale+img.lm+img.rm+2}else{lwidth=get_lwidth();cut_tune(lwidth,lsh)}gen_init()if(!tsfirst)returnts1st=tsfirstv=nvwhile(--v>=0)voice_tb[v].osym=voice_tb[v].symspf_last=0while(1){set_piece();indent=set_indent(lsh)if(!line_height&&cfmt.indent&&indent<cfmt.indent)indent=cfmt.indentself.set_sym_glue(lwidth-indent)if(realwidth){if(indent)posx+=indent;draw_sym_near();line_height=set_staff();draw_systems(indent);draw_all_sym();delayed_update();if(output)vskip(line_height)if(indent)posx-=indent}blk_flush()while(blocks.length)self.block_gen(blocks.shift())if(tslast)tslast.ts_next.ts_prev=tslastif(!tsnext)breaktsnext.ts_prev.ts_next=tsfirst=tsnextgen_init()if(!tsfirst)breaktslast=tsfirst.ts_prevtsfirst.ts_prev=null;set_sym_line();lwidth=get_lwidth()}tsfirst=ts1stv=nvwhile(--v>=0){p_v=voice_tb[v]if(p_v.sym&&p_v.s_prev)p_v.sym.prev=p_v.s_prevp_v.sym=p_v.osym}}var a_gch,a_dcn=[],multicol,maps={}var qplet_tb=new Int8Array([0,1,3,2,3,0,2,0,3,0]),ntb="CDEFGABcdefgab"function set_ref(s){s.fname=parse.fname;s.istart=parse.istart;s.iend=parse.iend}function new_clef(clef_def){var s={type:C.CLEF,clef_line:2,clef_type:"t",v:curvoice.v,p_v:curvoice,time:curvoice.time,dur:0},i=1set_ref(s)switch(clef_def[0]){case'"':i=clef_def.indexOf('"',1);s.clef_name=clef_def.slice(1,i);i++breakcase'a':if(clef_def[1]=='u'){s.clef_type="a";s.clef_auto=true;i=4break}i=4case'C':s.clef_type="c";s.clef_line=3breakcase'b':i=4case'F':s.clef_type="b";s.clef_line=4breakcase'n':i=4s.invis=truebreakcase't':if(clef_def[1]=='e'){s.clef_type="c";s.clef_line=4break}i=6case'G':breakcase'p':i=4case'P':s.clef_type="p";s.clef_line=3;breakdefault:syntax(1,"Unknown clef '$1'",clef_def)return}if(clef_def[i]>='1'&&clef_def[i]<='9'){s.clef_line=+clef_def[i]i++}delete curvoice.snd_octif(clef_def[i+1]!='8'&&clef_def[i+1]!='1')return sswitch(clef_def[i]){case'^':s.clef_oct_transp=truecase'+':s.clef_octave=clef_def[i+1]=='8'?7:14if(!s.clef_oct_transp)curvoice.snd_oct=clef_def[i+1]==8?12:24breakcase'_':s.clef_oct_transp=truecase'-':s.clef_octave=clef_def[i+1]=='8'?-7:-14if(!s.clef_oct_transp)curvoice.snd_oct=clef_def[i+1]==8?-12:-24break}return s}function get_interval(param,score){var i,val,tmp,note,pittmp=new scanBuf;tmp.buffer=parampit=[]for(i=0;i<2;i++){note=tmp.buffer[tmp.index]?parse_acc_pit(tmp):nullif(!note){if(i!=1||!score){syntax(1,errs.bad_transp)return}pit[i]=242}else{if(typeof note.acc=="object"){syntax(1,errs.bad_transp)return}pit[i]=abc2svg.pab40(note.pit,note.acc)}}return pit[1]-pit[0]}function nt_trans(nt,a){var ak,an,d,b40,nif(typeof a=="object"){n=a[0]d=a[1]a=n>0?1:-1}b40=abc2svg.pab40(nt.pit,a)+curvoice.tr_scont.pit=abc2svg.b40p(b40)an=abc2svg.b40a(b40)if(!d){if(an==-3)return ana=anif(nt.acc){if(!a)a=3}else{if(!curvoice.ckey.k_none)a=0}nt.acc=areturn an}switch(an){case-2:if(n>0)n-=d*2elsen-=dbreakcase-1:if(n>0)n-=dbreakcase 0:case 3:if(n>0)n-=delsen+=dbreakcase 1:if(n<0)n+=dbreakcase 2:if(n<0)n+=d*2elsen+=dbreak}nt.acc=[n,d]return an}function set_linebreak(param){var i,itemfor(i=0;i<128;i++){if(char_tb[i]=="\n")char_tb[i]=nil}param=param.split(/\s+/)for(i=0;i<param.length;i++){item=param[i]switch(item){case'!':case'$':case'*':case';':case'?':case'@':breakcase"<none>":continuecase"<EOL>":item='\n'breakdefault:syntax(1,"Bad value '$1' in %%linebreak - ignored",item)continue}char_tb[item.charCodeAt(0)]='\n'}}function set_user(parm){var k,c,v,a=parm.match(/(.)[=\s]*(\[I:.+\]|".+"|!.+!)$/)if(!a){syntax(1,'Lack of starting [, ! or " in U: / %%user')return}c=a[1];v=a[2]if(c[0]=='\\'){if(c[1]=='t')c='\t'else if(!c[1])c=' '}k=c.charCodeAt(0)if(k>=128){syntax(1,errs.not_ascii)return}switch(char_tb[k][0]){case'0':case'd':case'i':case' ':breakcase'"':case'!':case'[':if(char_tb[k].length>1)breakdefault:syntax(1,"Bad user character '$1'",c)return}switch(v){case"!beambreak!":v=" "breakcase"!ignore!":v="i"breakcase"!nil!":case"!none!":v="d"break}char_tb[k]=v}function get_st_lines(param){if(!param)returnif(/^[\]\[|.-]+$/.test(param))return param.replace(/\]/g,'[')var n=+paramswitch(n){case 0:return"..."case 1:return"..|"case 2:return".||"case 3:return".|||"}if(isNaN(n)||n<0||n>16)returnreturn"||||||||||||||||".slice(0,n)}function new_block(subtype){var c_v,s={type:C.BLOCK,subtype:subtype,dur:0}c_v=curvoiceif(subtype.slice(0,4)!="midi")curvoice=voice_tb[0]sym_link(s)if(c_v)curvoice=c_vreturn s}Abc.prototype.set_vp=function(a){var s,item,pos,val,clefpit,tr_p=0while(1){item=a.shift()if(!item)breakif(item.slice(-1)=='='&&!a.length){syntax(1,errs.bad_val,item)break}switch(item){case"clef=":s=a.shift()breakcase"clefpitch=":item=a.shift()if(item){val=ntb.indexOf(item[0])if(val>=0){switch(item[1]){case"'":val+=7breakcase',':val-=7if(item[2]==',')val-=7break}clefpit=4-valbreak}}syntax(1,errs.bad_val,item)breakcase"octave=":val=+a.shift()if(isNaN(val))syntax(1,errs.bad_val,item)elsecurvoice.octave=valbreakcase"cue=":curvoice.scale=a.shift()=='on'?.7:1breakcase"instrument=":item=a.shift()val=item.indexOf('/')if(val<0){val=get_interval('c'+item)if(val==undefined)breakcurvoice.sound=valtr_p|=2val=0}else{val=get_interval('c'+item.slice(val+1))if(val==undefined)breakcurvoice.sound=valtr_p|=2val=get_interval(item.replace('/',''))if(val==undefined)break}curvoice.score=cfmt.sound?curvoice.sound:valtr_p|=1breakcase"map=":curvoice.map=a.shift()breakcase"name=":case"nm=":curvoice.nm=a.shift()if(curvoice.nm[0]=='"')curvoice.nm=cnv_escape(curvoice.nm.slice(1,-1))curvoice.new_name=truebreakcase"stem=":case"pos=":if(item=="pos=")item=a.shift().slice(1,-1).split(' ')elseitem=["stm",a.shift()];val=posval[item[1]]if(val==undefined){syntax(1,errs.bad_val,"%%pos")break}switch(item[2]){case"align":val|=C.SL_ALIGN;breakcase"center":val|=C.SL_CENTER;breakcase"close":val|=C.SL_CLOSE;break}if(!pos)pos={}pos[item[0]]=valbreakcase"scale=":val=+a.shift()if(isNaN(val)||val<.5||val>2)syntax(1,errs.bad_val,"%%voicescale")elsecurvoice.scale=valbreakcase"score=":if(cfmt.nedo){syntax(1,errs.notransp)break}item=a.shift()if(cfmt.sound)breakval=get_interval(item,true)if(val!=undefined){curvoice.score=valtr_p|=1}breakcase"shift=":if(cfmt.nedo){syntax(1,errs.notransp)break}val=get_interval(a.shift())if(val!=undefined){curvoice.shift=valtr_p=3}breakcase"sound=":if(cfmt.nedo){syntax(1,errs.notransp)break}val=get_interval(a.shift())if(val==undefined)breakcurvoice.sound=valif(cfmt.sound)curvoice.score=valtr_p|=2breakcase"subname=":case"sname=":case"snm=":curvoice.snm=a.shift()if(curvoice.snm[0]=='"')curvoice.snm=curvoice.snm.slice(1,-1);breakcase"stafflines=":val=get_st_lines(a.shift())if(val==undefined)syntax(1,"Bad %%stafflines value")else if(curvoice.st!=undefined)par_sy.staves[curvoice.st].stafflines=valelsecurvoice.stafflines=valbreakcase"staffnonote=":val=+a.shift()if(isNaN(val))syntax(1,"Bad %%staffnonote value")elsecurvoice.staffnonote=valbreakcase"staffscale=":val=+a.shift()if(isNaN(val)||val<.3||val>2)syntax(1,"Bad %%staffscale value")elsecurvoice.staffscale=valbreakcase"tacet=":val=a.shift()curvoice.tacet=val||undefinedbreakcase"transpose=":if(cfmt.nedo){syntax(1,errs.notransp)break}val=get_transp(a.shift())if(val==undefined){syntax(1,errs.bad_transp)}else{curvoice.sound=valif(cfmt.sound)curvoice.score=valtr_p=2}breakdefault:switch(item.slice(0,4)){case"treb":case"bass":case"alto":case"teno":case"perc":s=itembreakdefault:if("GFC".indexOf(item[0])>=0)s=itemelse if(item.slice(-1)=='=')a.shift()break}break}}if(pos){curvoice.pos=clone(curvoice.pos)for(item in pos)if(pos.hasOwnProperty(item))curvoice.pos[item]=pos[item]}if(s){s=new_clef(s)if(s){if(clefpit)s.clefpit=clefpitget_clef(s)}}if(tr_p&2){tr_p=(curvoice.sound|0)+(curvoice.shift|0)if(tr_p)curvoice.tr_snd=abc2svg.b40m(tr_p+122)-36else if(curvoice.tr_snd)curvoice.tr_snd=0}}function set_kv_parm(a){if(!curvoice.init){curvoice.init=trueif(info.V){if(info.V[curvoice.id])a=info.V[curvoice.id].concat(a)if(info.V['*'])a=info.V['*'].concat(a)}}if(a.length)self.set_vp(a)}function memo_kv_parm(vid,a){if(!a.length)returnif(!info.V)info.V={}if(info.V[vid])Array.prototype.push.apply(info.V[vid],a)elseinfo.V[vid]=a}function new_key(param){var i,key_end,c,tmp,note,sf="FCGDAEB".indexOf(param[0])-1,mode=0,s={type:C.KEY,dur:0}set_ref(s);i=1if(sf<-1){switch(param[0]){case'H':key_end=trueif(param[1].toLowerCase()!='p'){syntax(1,"Unknown bagpipe-like key")break}s.k_bagpipe=param[1];sf=param[1]=='P'?0:2;i++if(!cfmt.temper)cfmt.temper=new Float32Array([11.62,12.55,1.66,2.37,3.49,0,1.66,2.37,3.49,4.41,5.53,0,3.49,4.41,5.53,6.63,7.35,4.41,5.53,6.63,7.35,8.19,0,6.63,7.35,8.19,9.39,10.51,0,8.19,9.39,10.51,11.62,12.55,0,10.51,11.62,12.55,1.66,1.66])breakcase'P':syntax(1,"K:P is deprecated");sf=0;s.k_drum=true;key_end=truebreakcase'n':if(param.indexOf("none")==0){sf=0;s.k_none=true;i=4break}default:s.k_map=[]s.k_mode=0return[s,info_split(param)]}}if(!key_end){switch(param[i]){case'#':sf+=7;i++;breakcase'b':sf-=7;i++;break}param=param.slice(i).trim()switch(param.slice(0,3).toLowerCase()){default:if(param[0]!='m'||(param[1]!=' '&¶m[1]!='\t'&¶m[1]!='\n')){key_end=truebreak}case"aeo":case"m":case"min":sf-=3;mode=5breakcase"dor":sf-=2;mode=1breakcase"ion":case"maj":breakcase"loc":sf-=5;mode=6breakcase"lyd":sf+=1;mode=3breakcase"mix":sf-=1;mode=4breakcase"phr":sf-=4;mode=2break}if(!key_end)param=param.replace(/\w+\s*/,'')if(param.indexOf("exp ")==0){param=param.replace(/\w+\s*/,'')if(!param)syntax(1,"No accidental after 'exp'");s.exp=1}c=param[0]if(c=='^'||c=='_'||c=='='){s.k_a_acc=[];tmp=new scanBuf;tmp.buffer=paramdo{note=parse_acc_pit(tmp)if(!note)breaks.k_a_acc.push(note);c=param[tmp.index]while(c==' ')c=param[++tmp.index]}while(c=='^'||c=='_'||c=='=');param=param.slice(tmp.index)}else if(s.exp&¶m.indexOf("none")==0){sf=0param=param.replace(/\w+\s*/,'')}}if(sf<-7||sf>7){syntax(1,"Key with double sharps/flats")if(sf>7)sf-=12elsesf+=12}s.k_sf=sf;s.k_map=s.k_bagpipe&&!sf?abc2svg.keys[9]:abc2svg.keys[sf+7]if(s.k_a_acc){s.k_map=new Int8Array(s.k_map)i=s.k_a_acc.lengthwhile(--i>=0){note=s.k_a_acc[i]s.k_map[(note.pit+19)%7]=note.acc}}s.k_mode=modes.k_b40=[1,24,7,30,13,36,19,2,25,8,31,14,37,20,3][sf+7]return[s,info_split(param)]}function new_meter(p){var p_v,s={type:C.METER,dur:0,a_meter:[]},meter={},val,v,m1=0,m2,i=0,j,wmeasure,in_parenth;set_ref(s)if(p.indexOf("none")==0){i=4;wmeasure=1}else{wmeasure=0while(i<p.length){if(p[i]=='=')breakswitch(p[i]){case'C':meter.top=p[i++]if(!m1){m1=4;m2=4}breakcase'c':case'o':meter.top=p[i++]if(!m1){if(p[i-1]=='c'){m1=2;m2=4}else{m1=3;m2=4}switch(p[i]){case'|':m2/=2breakcase'.':m1*=3;m2*=2break}}breakcase'.':case'|':m1=0;meter.top=p[i++]breakcase'(':if(p[i+1]=='('){in_parenth=true;meter.top=p[i++];s.a_meter.push(meter);meter={}}j=i+1while(j<p.length){if(p[j]==')'||p[j]=='/')breakj++}if(p[j]==')'&&p[j+1]=='/'){i++continue}case')':in_parenth=p[i]=='(';meter.top=p[i++];s.a_meter.push(meter);meter={}continuedefault:if(p[i]<='0'||p[i]>'9'){syntax(1,"Bad char '$1' in M:",p[i])return}m2=2;meter.top=p[i++]for(;;){while(p[i]>='0'&&p[i]<='9')meter.top+=p[i++]if(p[i]==')'){if(p[i+1]!='/')breaki++}if(p[i]=='/'){i++;if(p[i]<='0'||p[i]>'9'){syntax(1,"Bad char '$1' in M:",p[i])return}meter.bot=p[i++]while(p[i]>='0'&&p[i]<='9')meter.bot+=p[i++]break}if(p[i]!=' '&&p[i]!='+')breakif(i>=p.length||p[i+1]=='(')breakmeter.top+=p[i++]}m1=+meter.topbreak}if(!in_parenth){if(meter.bot)m2=+meter.botwmeasure+=m1*C.BLEN/m2}s.a_meter.push(meter);meter={}while(p[i]==' ')i++if(p[i]=='+'){meter.top=p[i++];s.a_meter.push(meter);meter={}}}}if(p[i]=='='){val=p.substring(++i).match(/^(\d+)\/(\d+)$/)if(!val){syntax(1,"Bad duration '$1' in M:",p.substring(i))return}wmeasure=C.BLEN*val[1]/val[2]}if(!wmeasure){syntax(1,errs.bad_val,'M:')return}s.wmeasure=wmeasureif(cfmt.writefields.indexOf('M')<0)s.a_meter=[]if(parse.state!=3){info.M=p;glovar.meter=sif(parse.state){if(!glovar.ulen){if(wmeasure<=1||wmeasure>=C.BLEN*3/4)glovar.ulen=C.BLEN/8elseglovar.ulen=C.BLEN/16}for(v=0;v<voice_tb.length;v++){voice_tb[v].meter=s;voice_tb[v].wmeasure=wmeasure}}}else{curvoice.wmeasure=wmeasureif(is_voice_sig())curvoice.meter=selsesym_link(s)for(p_v=curvoice.voice_down;p_v;p_v=p_v.voice_down)p_v.wmeasure=wmeasure}}function new_tempo(text){var i,c,d,nd,txt=text,s={type:C.TEMPO,dur:0}function get_nd(p){var n,d,nd=p.match(/(\d+)\/(\d+)/)if(nd){d=+nd[2]if(d&&!isNaN(d)&&!(d&(d-1))){n=+nd[1]if(!isNaN(n))return C.BLEN*n/d}}syntax(1,"Invalid note duration $1",c)}set_ref(s)if(cfmt.writefields.indexOf('Q')<0)s.invis=trueif(text[0]=='"'){c=text.match(/"([^"]*)"/)if(!c){syntax(1,"Unterminated string in Q:")return}s.tempo_str1=c[1]text=text.slice(c[0].length).replace(/^\s+/,'')}if(text.slice(-1)=='"'){i=text.indexOf('"')s.tempo_str2=text.slice(i+1,-1)text=text.slice(0,i).replace(/\s+$/,'')}i=text.indexOf('=')if(i>0){d=text.slice(0,i).split(/\s+/)text=text.slice(i+1).replace(/^\s+/,'')while(1){c=d.shift()if(!c)breaknd=get_nd(c)if(!nd)returnif(!s.tempo_notes)s.tempo_notes=[]s.tempo_notes.push(nd)}if(text.slice(0,4)=="ca. "){s.tempo_ca='ca. 'text=text.slice(4)}i=text.indexOf('/')if(i>0){nd=get_nd(text)if(!nd)returns.new_beat=nd}else{s.tempo=+textif(!s.tempo||isNaN(s.tempo)){syntax(1,"Bad tempo value")return}}}if(parse.state<2||(!curvoice.time&&!glovar.tempo)){info.Q=txtglovar.tempo=sreturn}if(!glovar.tempo)syntax(0,"No previous tempo")if(new_ctrl(s))sym_link(s)}function do_info(info_type,text){var s,d1,d2,a,vid,tim,v,p_vif(curvoice&&curvoice.ignore){switch(info_type){default:returncase'P':case'Q':case'V':break}}switch(info_type){case'I':self.do_pscom(text)breakcase'L':a=text.match(/^1\/(\d+)(=(\d+)\/(\d+))?$/)if(a){d1=+a[1]if(!d1||(d1&(d1-1))!=0)breakd1=C.BLEN/d1if(a[2]){d2=+a[4]d2=d2?+a[3]/d2*C.BLEN:0}else{d2=d1}}else if(text=="auto"){d1=d2=-1}if(!d2){syntax(1,"Bad L: value")break}if(parse.state<=1){glovar.ulen=d1}else{curvoice.ulen=d1;curvoice.dur_fact=d2/d1}breakcase'M':new_meter(text)breakcase'U':set_user(text)breakcase'P':if(!parse.state)breakif(parse.state==1){info.P=textbreak}s={type:C.PART,text:text,time:tim}if(!new_ctrl(s))breaksym_link(s)if(cfmt.writefields.indexOf(info_type)<0)s.invis=truebreakcase'Q':if(!parse.state)breaknew_tempo(text)breakcase'V':get_voice(text)if(parse.state==3)curvoice.ignore=!par_sy.voices[curvoice.v]breakcase'K':if(!parse.state)breakget_key(text)breakcase'N':case'R':if(!info[info_type])info[info_type]=textelseinfo[info_type]+='\n'+textbreakcase'r':if(!user.keep_remark||parse.state!=3)breaks={type:C.REMARK,text:text,dur:0}sym_link(s)breakdefault:syntax(0,"'$1:' line ignored",info_type)break}}function adjust_dur(s){var s2,time,auto_time,i,fac;s2=curvoice.last_symif(!s2)return;if(s2.type==C.MREST||s2.type==C.BAR)returnwhile(s2.type!=C.BAR&&s2.prev)s2=s2.prev;time=s2.time;auto_time=curvoice.time-timefac=curvoice.wmeasure/auto_timeif(fac==1)returnfor(;s2;s2=s2.next){s2.time=timeif(!s2.dur||s2.grace)continues2.dur*=fac;s2.dur_orig*=fac;time+=s2.durif(s2.type!=C.NOTE&&s2.type!=C.REST)continuefor(i=0;i<=s2.nhd;i++)s2.notes[i].dur*=fac}curvoice.time=s.time=time}function new_bar(){var s2,c,bar_type,line=parse.line,s={type:C.BAR,fname:parse.fname,istart:parse.bol+line.index,dur:0,multi:0}if(vover&&vover.bar)get_vover('|')if(glovar.new_nbar){s.bar_num=glovar.new_nbar;glovar.new_nbar=0}bar_type=line.char()while(1){c=line.next_char()switch(c){case'|':case'[':case']':case':':bar_type+=ccontinue}break}if(bar_type[0]==':'){if(bar_type==':'){bar_type='|';s.bar_dotted=true}else{s.rbstop=2}}if(a_gch)csan_add(s)if(a_dcn.length)deco_cnv(s)if(bar_type.slice(-1)=='['&&!(/[0-9" ]/.test(c))){bar_type=bar_type.slice(0,-1);line.index--;c='['}if(c>'0'&&c<='9'){s.text=cwhile(1){c=line.next_char()if("0123456789,.-".indexOf(c)<0)breaks.text+=c}}else if(c=='"'&&bar_type.slice(-1)=='['){s.text=""while(1){c=line.next_char()if(!c){syntax(1,"No end of repeat string")return}if(c=='"'){line.index++break}s.text+=c}}if(bar_type[0]==']'){s.rbstop=2if(bar_type.length!=1)bar_type=bar_type.slice(1)elses.invis=true}s.iend=parse.bol+line.indexif(s.text&&bar_type.slice(-1)=='['&&bar_type!='[')bar_type=bar_type.slice(0,-1)if(bar_type.slice(-1)==':'){s.rbstop=1if(s.text){syntax(1,"Variant ending on a left repeat bar")delete s.text}curvoice.tie_s_rep=null}if(s.text){s.rbstart=s.rbstop=2if(s.text[0]=='1'){curvoice.tie_s_rep=curvoice.tie_sif(curvoice.acc_tie)curvoice.acc_tie_rep=curvoice.acc_tie.slice()else if(curvoice.acc_tie_rep)curvoice.acc_tie_rep=null}else{curvoice.tie_s=curvoice.tie_s_repif(curvoice.acc_tie_rep)curvoice.acc_tie=curvoice.acc_tie_rep.slice()}if(curvoice.norepbra&&!curvoice.second)s.norepbra=1}if(curvoice.ulen<0)adjust_dur(s);if((bar_type=="["||bar_type=="|:")&&!curvoice.eoln&&!s.a_gch&&!s.invis){s2=curvoice.last_symif(s2&&s2.type==C.BAR){if((bar_type=="["&&!s2.text)||s.norepbra){if(s.text){s2.text=s.textif(curvoice.st&&!s.norepbra&&!(par_sy.staves[curvoice.st-1].flags&STOP_BAR))s2.xsh=4}if(s.norepbra)s2.norepbra=1if(s.rbstart)s2.rbstart=s.rbstartif(s.rbstop)s2.rbstop=s.rbstopreturn}if(bar_type=="|:"){switch(s2.bar_type){case":|":s2.bar_type="::";s2.rbstop=2return}}}}switch(bar_type){case"[":case"[]":case"[|]":s.invis=true;bar_type=s.rbstart?"[":"[]"breakcase":|:":case":||:":bar_type="::"breakcase"||":if(cfmt["abc-version"]>="2.2")breakcase"[|":case"|]":s.rbstop=2break}s.bar_type=bar_typeif(!curvoice.lyric_restart)curvoice.lyric_restart=sif(!curvoice.sym_restart)curvoice.sym_restart=ssym_link(s);s.st=curvoice.stif(s.text&&s.st>0&&!s.norepbra&&!(par_sy.staves[s.st-1].flags&STOP_BAR)&&bar_type!='[')s.xsh=4if(!s.bar_dotted&&!s.invis)curvoice.acc=[]}function parse_staves(p){var v,vid,vids={},a_vf=[],err=false,flags=0,brace=0,bracket=0,parenth=0,flags_st=0,e,a=p.match(/[^[\]|{}()*+\s]+|[^\s]/g)if(!a){syntax(1,errs.bad_val,"%%score")return}while(1){e=a.shift()if(!e)breakswitch(e){case'[':if(parenth||brace+bracket>=2){syntax(1,errs.misplaced,'[');err=truebreak}flags|=brace+bracket==0?OPEN_BRACKET:OPEN_BRACKET2;bracket++;flags_st<<=8;flags_st|=OPEN_BRACKETbreakcase'{':if(parenth||brace||bracket>=2){syntax(1,errs.misplaced,'{');err=truebreak}flags|=!bracket?OPEN_BRACE:OPEN_BRACE2;brace++;flags_st<<=8;flags_st|=OPEN_BRACEbreakcase'(':if(parenth){syntax(1,errs.misplaced,'(');err=truebreak}flags|=OPEN_PARENTH;parenth++;flags_st<<=8;flags_st|=OPEN_PARENTHbreakcase'*':if(brace&&!parenth&&!(flags&(OPEN_BRACE|OPEN_BRACE2)))flags|=FL_VOICEbreakcase'+':flags|=MASTER_VOICEbreakcase']':case'}':case')':syntax(1,"Bad voice ID in %%score");err=truebreakdefault:vid=ewhile(1){e=a.shift()if(!e)breakswitch(e){case']':if(!(flags_st&OPEN_BRACKET)){syntax(1,errs.misplaced,']');err=truebreak}bracket--;flags|=brace+bracket==0?CLOSE_BRACKET:CLOSE_BRACKET2;flags_st>>=8continuecase'}':if(!(flags_st&OPEN_BRACE)){syntax(1,errs.misplaced,'}');err=truebreak}brace--;flags|=!bracket?CLOSE_BRACE:CLOSE_BRACE2;flags&=~FL_VOICE;flags_st>>=8continuecase')':if(!(flags_st&OPEN_PARENTH)){syntax(1,errs.misplaced,')');err=truebreak}parenth--;flags|=CLOSE_PARENTH;flags_st>>=8continuecase'|':flags|=STOP_BARcontinue}break}if(vids[vid]){syntax(1,"Double voice in %%score")err=true}else{vids[vid]=truea_vf.push([vid,flags])}flags=0if(!e)breaka.unshift(e)break}}if(flags_st!=0){syntax(1,"'}', ')' or ']' missing in %%score");err=true}if(err||!a_vf.length)returnreturn a_vf}function info_split(text){if(!text)return[]var a=text.match(/[^\s"=]+=?|"[^"]*"/g)if(!a){syntax(1,"Unterminated string")return[]}return a}var reg_dur=/(\d*)(\/*)(\d*)/gfunction parse_dur(line){var res,num,den;reg_dur.lastIndex=line.index;res=reg_dur.exec(line.buffer)if(!res[0])return[1,1];num=res[1]||1;den=res[3]||1if(!res[3])den*=1<<res[2].length;line.index=reg_dur.lastIndexreturn[+num,+den]}function parse_acc_pit(line){var note,acc,pit,d,nd,c=line.char()switch(c){case'^':c=line.next_char()if(c=='^'){acc=2;c=line.next_char()}else{acc=1}breakcase'=':acc=3;c=line.next_char()breakcase'_':c=line.next_char()if(c=='_'){acc=-2;c=line.next_char()}else{acc=-1}break}if(acc==1||acc==-1){if((c>='1'&&c<='9')||c=='/'){nd=parse_dur(line);if(acc<0)nd[0]=-nd[0]if(cfmt.nedo&&nd[1]==1){nd[0]*=12nd[1]*=cfmt.nedo}acc=ndc=line.char()}}pit=ntb.indexOf(c)+16;c=line.next_char()if(pit<16){syntax(1,"'$1' is not a note",line.buffer[line.index-1])return}while(c=="'"){pit+=7;c=line.next_char()}while(c==','){pit-=7;c=line.next_char()}note={pit:pit,shhd:0,shac:0}if(acc)note.acc=accreturn note}function set_map(note,acc){var pit=note.pit,nn=not2abc(pit,acc),map=maps[curvoice.map]if(!map[nn]){nn='o'+nn.replace(/[',]+/,'')if(!map[nn]){nn='k'+ntb[(pit+75-curvoice.ckey.k_sf*11)%7]if(!map[nn]){nn='all'if(!map[nn])return}}}note.map=map=map[nn]if(map[1]){note.pit=pit=map[1].pitnote.acc=map[1].accif(map[1].notrp){note.notrp=1note.noplay=1}}if(map[2])note.color=map[2]nn=map[3]if(nn)note.midi=pit2mid(nn.pit+19,nn.acc)}function parse_basic_note(line,ulen){var nd,note=parse_acc_pit(line)if(!note)returnif(line.char()=='0'){parse.stemless=true;line.index++}nd=parse_dur(line);note.dur=ulen*nd[0]/nd[1]return note}function parse_vpos(){var line=parse.line,ty=0if(a_dcn.length&&a_dcn[a_dcn.length-1]=="dot"){ty=C.SL_DOTTEDa_dcn.pop()}switch(line.next_char()){case"'":line.index++return ty+C.SL_ABOVEcase",":line.index++return ty+C.SL_BELOWcase'?':line.index++return ty+C.SL_CENTER}return ty+C.SL_AUTO}function slur_add(s,nt){var i,s2,slfor(i=curvoice.sls.length;--i>=0;){sl=curvoice.sls[i]if(sl.ss==s)continuecurvoice.sls.splice(i,1)sl.se=sif(nt)sl.nte=nts2=sl.ssif(!s2.sls)s2.sls=[]s2.sls.push(sl)if(sl.grace)sl.grace.sl1=truereturn}for(s2=s.prev;s2;s2=s2.prev){if(s2.type==C.BAR&&s2.bar_type[0]==':'&&s2.text){if(!s2.sls)s2.sls=[];s2.sls.push({ty:C.SL_AUTO,ss:s2,se:s})if(nt)s2.sls[s2.sls.length-1].nte=ntreturn}}if(!s.sls)s.sls=[];s.sls.push({ty:C.SL_AUTO,se:s,loc:'i'})if(nt)s.sls[s.sls.length-1].nte=nt}function pit2mid(pit,acc){var p=[0,2,4,5,7,9,11][pit%7],o=((pit/7)|0)*12,p0,p1,s,b40if(curvoice.snd_oct)o+=curvoice.snd_octif(acc==3)acc=0if(acc){if(typeof acc=="object"){s=acc[0]/acc[1]if(acc[1]==100)return p+o+s}else{s=acc}}else{if(cfmt.temper)return cfmt.temper[abc2svg.p_b40[pit%7]]+oreturn p+o}if(!cfmt.nedo){if(!cfmt.temper){p+=o+sreturn p}}else{if(typeof acc!="object"){b40=abc2svg.p_b40[pit%7]+accreturn cfmt.temper[b40]+o}if(acc[1]==cfmt.nedo){b40=abc2svg.p_b40[pit%7]return cfmt.temper[b40]+o+s}}p0=cfmt.temper[abc2svg.p_b40[pit%7]]if(s>0){p1=cfmt.temper[(abc2svg.p_b40[pit%7]+1)%40]if(p1<p0)p1+=12}else{p1=cfmt.temper[(abc2svg.p_b40[pit%7]+39)%40]if(p1>p0)p1-=12s=-s}return p0+o+(p1-p0)*s}function do_ties(s,tie_s){var i,m,not1,not2,mid,g,nt=0,se=(tie_s.time+tie_s.dur)==curvoice.timefor(m=0;m<=s.nhd;m++){not2=s.notes[m]mid=not2.midiif(tie_s.type!=C.GRACE){for(i=0;i<=tie_s.nhd;i++){not1=tie_s.notes[i]if(!not1.tie_ty)continueif(not1.midi==mid&&(!se||!not1.tie_e)){not2.tie_s=not1not2.s=sif(se){not1.tie_e=not2not1.s=tie_s}nt++break}}}else{for(g=tie_s.extra;g;g=g.next){not1=g.notes[0]if(!not1.tie_ty)continueif(not1.midi==mid){g.ti1=truenot2.tie_s=not1not2.s=snot1.tie_e=not2not1.s=gnt++break}}}}if(!nt)error(1,tie_s,"Bad tie")elses.ti2=true}Abc.prototype.new_note=function(grace,sls){var note,s,in_chord,c,dcn,type,tie_s,acc_tie,i,n,s2,nd,res,num,dur,apit,div,ty,dpit=0,sl1=[],line=parse.line,a_dcn_sav=a_dcna_dcn=[]parse.stemless=false;s={type:C.NOTE,fname:parse.fname,stem:0,multi:0,nhd:0,xmx:0}s.istart=parse.bol+line.indexif(curvoice.color)s.color=curvoice.colorif(grace){s.grace=true}else{if(curvoice.tie_s){tie_s=curvoice.tie_scurvoice.tie_s=null}if(a_gch)csan_add(s)if(parse.repeat_n){s.repeat_n=parse.repeat_n;s.repeat_k=parse.repeat_k;parse.repeat_n=0}}c=line.char()switch(c){case'X':s.invis=truecase'Z':s.type=C.MREST;c=line.next_char()s.nmes=(c>'0'&&c<='9')?line.get_int():1;if(curvoice.wmeasure==1){error(1,s,"multi-measure rest, but no measure!")return}s.dur=curvoice.wmeasure*s.nmesif(curvoice.second){delete curvoice.eolncurvoice.time+=s.durreturn}if(s.nmes==1){s.type=C.REST;s.dur_orig=s.dur;s.fmr=1s.notes=[{pit:18,dur:s.dur}]}else{glovar.mrest_p=trueif(par_sy.voices.length==1){s.tacet=curvoice.tacetdelete s.invis}}breakcase'y':s.type=C.SPACE;s.invis=true;s.dur=0;c=line.next_char()if(c>='0'&&c<='9')s.width=line.get_int()elses.width=10if(tie_s){curvoice.tie_s=tie_stie_s=null}breakcase'x':s.invis=truecase'z':s.type=C.REST;line.index++;nd=parse_dur(line);s.dur_orig=((curvoice.ulen<0)?C.BLEN:curvoice.ulen)*nd[0]/nd[1];s.dur=s.dur_orig*curvoice.dur_fact;if(s.dur==curvoice.wmeasure)s.fmr=1s.notes=[{pit:18,dur:s.dur_orig}]breakcase'[':in_chord=true;c=line.next_char()default:if(curvoice.acc_tie){acc_tie=curvoice.acc_tiecurvoice.acc_tie=null}s.notes=[]while(1){if(in_chord){while(1){if(!c)breaki=c.charCodeAt(0);if(i>=128){syntax(1,errs.not_ascii)return}type=char_tb[i]switch(type[0]){case'(':sl1.push(parse_vpos());c=line.char()continuecase'!':if(type.length>1)a_dcn.push(type.slice(1,-1))elseget_deco()c=line.next_char()continue}break}}note=parse_basic_note(line,s.grace?C.BLEN/4:curvoice.ulen<0?C.BLEN:curvoice.ulen)if(!note)returnif(curvoice.octave)note.pit+=curvoice.octave*7apit=note.pit+19i=note.accif(!i){if(cfmt["propagate-accidentals"][0]=='p')i=curvoice.acc[apit%7]elsei=curvoice.acc[apit]if(!i)i=curvoice.ckey.k_map[apit%7]||0}if(i){if(cfmt["propagate-accidentals"][0]=='p')curvoice.acc[apit%7]=ielse if(cfmt["propagate-accidentals"][0]!='n')curvoice.acc[apit]=i}if(acc_tie&&acc_tie[apit])i=acc_tie[apit]if(curvoice.map&&maps[curvoice.map])set_map(note,i)if(!note.midi)note.midi=pit2mid(apit,i)if(curvoice.tr_sco&&!note.notrp){i=nt_trans(note,i)if(i==-3){error(1,s,"triple sharp/flat")i=note.acc>0?1:-1note.pit+=inote.acc=i}dpit=note.pit+19-apit}if(curvoice.tr_snd)note.midi+=curvoice.tr_sndif(i){switch(cfmt["writeout-accidentals"][1]){case'd':s2=curvoice.ckeyif(!s2.k_a_acc)breakfor(n=0;n<s2.k_a_acc.length;n++){if((s2.k_a_acc[n].pit-note.pit)%7==0){note.acc=ibreak}}breakcase'l':note.acc=ibreak}}if(sl1.length){while(1){i=sl1.shift()if(!i)breakcurvoice.sls.push({ty:i,ss:s,nts:note})}}if(a_dcn.length){s.time=curvoice.timedh_cnv(s,note)}s.notes.push(note)if(!in_chord)breakc=line.char()while(1){switch(c){case')':slur_add(s,note)c=line.next_char()continuecase'-':note.tie_ty=parse_vpos()note.s=scurvoice.tie_s=ss.ti1=trueif(curvoice.acc[apit]||(acc_tie&&acc_tie[apit])){if(!curvoice.acc_tie)curvoice.acc_tie=[]i=curvoice.acc[apit]if(acc_tie&&acc_tie[apit])i=acc_tie[apit]curvoice.acc_tie[apit]=i}c=line.char()continuecase'.':c=line.next_char()switch(c){case'-':case'(':a_dcn.push("dot")continue}syntax(1,"Misplaced dot")break}break}if(c==']'){line.index++;nd=parse_dur(line);s.nhd=s.notes.length-1for(i=0;i<=s.nhd;i++){note=s.notes[i];note.dur=note.dur*nd[0]/nd[1]}break}}if(sls.length){while(1){i=sls.shift()if(!i)breakcurvoice.sls.push({ty:i,ss:s})if(grace)curvoice.sls[curvoice.sls.length-1].grace=grace}}s.dur_orig=s.notes[0].dur;s.dur=s.notes[0].dur*curvoice.dur_factbreak}if(s.grace&&s.type!=C.NOTE){syntax(1,errs.bad_grace)return}if(s.notes){if(!grace){switch(curvoice.pos.stm&0x07){case C.SL_ABOVE:s.stem=1;breakcase C.SL_BELOW:s.stem=-1;breakcase C.SL_HIDDEN:s.stemless=true;break}num=curvoice.brk_rhythmif(num){curvoice.brk_rhythm=0;s2=curvoice.last_noteif(num>0){n=num*2-1;s.dur=s.dur*n/num;s.dur_orig=s.dur_orig*n/numfor(i=0;i<=s.nhd;i++)s.notes[i].dur=s.notes[i].dur*n/num;s2.dur/=num;s2.dur_orig/=numfor(i=0;i<=s2.nhd;i++)s2.notes[i].dur/=num}else{num=-num;n=num*2-1;s.dur/=num;s.dur_orig/=numfor(i=0;i<=s.nhd;i++)s.notes[i].dur/=num;s2.dur=s2.dur*n/num;s2.dur_orig=s2.dur_orig*n/numfor(i=0;i<=s2.nhd;i++)s2.notes[i].dur=s2.notes[i].dur*n/num}curvoice.time=s2.time+s2.dur;for(s2=s2.next;s2;s2=s2.next)s2.time=curvoice.time}}else{div=curvoice.ckey.k_bagpipe?8:4for(i=0;i<=s.nhd;i++)s.notes[i].dur/=div;s.dur/=div;s.dur_orig/=divif(grace.stem)s.stem=grace.stem}curvoice.last_note=sc=line.char()while(1){switch(c){case'.':if(line.buffer[line.index+1]!='-')breaka_dcn.push("dot")line.index++case'-':ty=parse_vpos()for(i=0;i<=s.nhd;i++){s.notes[i].tie_ty=tys.notes[i].s=s}curvoice.tie_s=grace||scurvoice.tie_s.ti1=truefor(i=0;i<=s.nhd;i++){note=s.notes[i]apit=note.pit+19-dpitif(curvoice.acc[apit]||(acc_tie&&acc_tie[apit])){if(!curvoice.acc_tie)curvoice.acc_tie=[]n=curvoice.acc[apit]if(acc_tie&&acc_tie[apit])n=acc_tie[apit]curvoice.acc_tie[apit]=n}}c=line.char()continue}break}if(tie_s)do_ties(s,tie_s)}sym_link(s)if(!grace){if(!curvoice.lyric_restart)curvoice.lyric_restart=sif(!curvoice.sym_restart)curvoice.sym_restart=s}if(a_dcn_sav.length){a_dcn=a_dcn_savdeco_cnv(s,s.prev)}if(grace&&s.ottava)grace.ottava=s.ottavaif(parse.stemless)s.stemless=trues.iend=parse.bol+line.indexreturn s}function tp_adj(s,fact){var d,tim=s.time,to=curvoice.time-tim,tt=to*factcurvoice.time=tim+ttwhile(1){s.in_tuplet=trueif(!s.grace){s.time=timif(s.dur){d=Math.round(s.dur*tt/to)to-=s.durs.dur=dtt-=s.durtim+=s.dur}}if(!s.next){if(s.tpe)s.tpe++elses.tpe=1break}s=s.next}}function get_deco(){var c,line=parse.line,i=line.index,dcn=""while(1){c=line.next_char()if(!c){line.index=isyntax(1,"No end of decoration")return}if(c=='!')breakdcn+=c}a_dcn.push(dcn)}var nil="0",char_tb=[nil,nil,nil,nil,nil,nil,nil,nil,nil," ","\n",nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil," ","!",'"',"i","\n",nil,"&",nil,"(",")","i",nil,nil,"-","!dot!",nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,nil,"|","i","<","n","<","i","i","n","n","n","n","n","n","n","!fermata!","d","d","d","!emphasis!","!lowermordent!","d","!coda!","!uppermordent!","d","d","!segno!","!trill!","d","d","d","n","d","n","[","\\","|","n","n","i","n","n","n","n","n","n","n","d","d","d","d","d","d","d","d","d","d","d","d","d","!upbow!","!downbow!","d","n","n","n","{","|","}","!gmark!",nil,]function parse_music_line(){var grace,last_note_sav,a_dcn_sav,no_eol,s,tps,tp=[],tpn=-1,sls=[],line=parse.linefunction check_mac(m){var i,j,bfor(i=1,j=line.index+1;i<m.length;i++,j++){if(m[i]==line.buffer[j])continueif(m[i]!='n')returnb=ntb.indexOf(line.buffer[j])if(b<0)returnwhile(line.buffer[j+1]=="'"){b+=7;j++}while(line.buffer[j+1]==','){b-=7;j++}}line.index=jreturn b}function n2n(n){var c=''while(n<0){n+=7;c+=','}while(n>=14){n-=7;c+="'"}return ntb[n]+c}function expand(m,b){if(b==undefined)return mvar c,i,r="",n=m.lengthfor(i=0;i<n;i++){c=m[i]if(c>='h'&&c<='z'){r+=n2n(b+c.charCodeAt(0)-'n'.charCodeAt(0))}else{r+=c}}return r}function parse_mac(k,m,b){var te,ti,curv,s,line_sav=line,istart_sav=parse.istart;parse.line=line=new scanBuf;parse.istart+=line_sav.index;if(cfmt.writefields.indexOf('m')<0){line.buffer=k.replace('n',n2n(b))s=curvoice.last_symti=curvoice.timeparse_seq(true)if(!s)s=curvoice.symfor(s=s.next;s;s=s.next)s.noplay=truete=curvoice.timecurv=curvoicecurvoice=clone_voice(curv.id+'-p')if(!par_sy.voices[curvoice.v]){curvoice.second=truepar_sy.voices[curvoice.v]={st:curv.st,second:true,range:curvoice.v}}curvoice.time=tis=curvoice.last_symparse.line=line=new scanBufparse.istart+=line_sav.indexline.buffer=expand(m,b)parse_seq(true)if(curvoice.time!=te)syntax(1,"Bad length of the macro sequence")if(!s)s=curvoice.symfor(;s;s=s.next)s.invis=s.play=truecurvoice=curv}else{line.buffer=expand(m,b)parse_seq(true)}parse.line=line=line_savparse.istart=istart_sav}function parse_seq(in_mac){var c,idx,type,k,s,dcn,i,n,text,notewhile(1){c=line.char()if(!c)breakif(!in_mac&&maci[c]){n=undefinedfor(k in mac){if(!mac.hasOwnProperty(k)||k[0]!=c)continueif(k.indexOf('n')<0){if(line.buffer.indexOf(k,line.index)!=line.index)continueline.index+=k.length}else{n=check_mac(k)if(n==undefined)continue}parse_mac(k,mac[k],n)n=1break}if(n)continue}idx=c.charCodeAt(0)if(idx>=128){syntax(1,errs.not_ascii)line.index++break}type=char_tb[idx]switch(type[0]){case' ':s=curvoice.last_noteif(s){s.beam_end=trueif(grace)grace.gr_shift=true}breakcase'\n':if(cfmt.barsperstaff)breakcurvoice.eoln=truebreakcase'&':if(grace){syntax(1,errs.bad_grace)break}c=line.next_char()if(c==')'){get_vover(c)break}get_vover('&')continuecase'(':c=line.next_char()if(c>'0'&&c<='9'){if(grace){syntax(1,errs.bad_grace)break}var pplet=line.get_int(),qplet=qplet_tb[pplet],rplet=ppletc=line.char()if(c==':'){c=line.next_char()if(c>'0'&&c<='9'){qplet=line.get_int();c=line.char()}if(c==':'){c=line.next_char()if(c>'0'&&c<='9'){rplet=line.get_int();c=line.char()}else{syntax(1,"Invalid 'r' in tuplet")continue}}}if(qplet==0||qplet==undefined)qplet=(curvoice.wmeasure%9)==0?3:2;if(tpn<0)tpn=tp.lengthtp.push({p:pplet,q:qplet,r:rplet,ro:rplet,f:curvoice.tup||cfmt.tuplets})continue}if(c=='&'){if(grace){syntax(1,errs.bad_grace)break}get_vover('(')break}line.index--;sls.push(parse_vpos())continuecase')':s=curvoice.last_symif(s){switch(s.type){case C.SPACE:if(!s.notes){s.notes=[]s.notes[0]={}}case C.NOTE:case C.REST:breakcase C.GRACE:for(s=s.extra;s.next;s=s.next);breakdefault:s=nullbreak}}if(!s){syntax(1,errs.bad_char,c)break}slur_add(s)breakcase'!':if(type.length>1)a_dcn.push(type.slice(1,-1))elseget_deco()breakcase'"':if(grace){syntax(1,errs.bad_grace)break}parse_gchord(type)breakcase'[':if(type.length>1){self.do_pscom(type.slice(3,-1))break}var c_next=line.buffer[line.index+1]if('|[]: "'.indexOf(c_next)>=0||(c_next>='1'&&c_next<='9')){if(grace){syntax(1,errs.bar_grace)break}new_bar()continue}if(line.buffer[line.index+2]==':'){if(grace){syntax(1,errs.bad_grace)break}i=line.buffer.indexOf(']',line.index+1)if(i<0){syntax(1,"Lack of ']'")break}text=line.buffer.slice(line.index+3,i).trim()parse.istart=parse.bol+line.index;parse.iend=parse.bol+ ++i;line.index=0;do_info(c_next,text);line.index=icontinue}case'n':s=self.new_note(grace,sls)if(!s)continueif(grace||!s.notes)continueif(tpn>=0){s.tp=tp.slice(tpn)tpn=-1if(tps)s.tp[0].s=tpstps=s}else if(!tps){continue}k=tp[tp.length-1]if(--k.r>0)continuewhile(1){tp_adj(tps,k.q/k.p)i=k.roif(k.s)tps=k.stp.pop()if(!tp.length){tps=nullbreak}k=tp[tp.length-1]k.r-=iif(k.r>0)break}continuecase'<':if(!curvoice.last_note){syntax(1,"No note before '<'")break}if(grace){syntax(1,"Cannot have a broken rhythm in grace notes")break}n=c=='<'?1:-1while(c=='<'||c=='>'){n*=2;c=line.next_char()}curvoice.brk_rhythm=ncontinuecase'i':breakcase'{':if(grace){syntax(1,"'{' in grace note")break}last_note_sav=curvoice.last_note;curvoice.last_note=null;a_dcn_sav=a_dcn;a_dcn=[]grace={type:C.GRACE,fname:parse.fname,istart:parse.bol+line.index,dur:0,multi:0}if(curvoice.color)grace.color=curvoice.colorswitch(curvoice.pos.gst&0x07){case C.SL_ABOVE:grace.stem=1;breakcase C.SL_BELOW:grace.stem=-1;breakcase C.SL_HIDDEN:grace.stem=2;break}sym_link(grace);c=line.next_char()if(c=='/'){grace.sappo=truebreak}continuecase'|':if(grace){syntax(1,errs.bar_grace)break}new_bar()continuecase'}':if(curvoice.ignore){grace=nullbreak}s=curvoice.last_noteif(!grace||!s){syntax(1,errs.bad_char,c)break}if(a_dcn.length)syntax(1,"Decoration ignored");grace.extra=grace.next;grace.extra.prev=null;grace.next=null;curvoice.last_sym=grace;grace=nullif(!s.prev&&!curvoice.ckey.k_bagpipe){for(i=0;i<=s.nhd;i++)s.notes[i].dur*=2;s.dur*=2;s.dur_orig*=2}curvoice.last_note=last_note_sav;a_dcn=a_dcn_savbreakcase"\\":if(!line.buffer[line.index+1]){no_eol=truebreak}default:syntax(1,errs.bad_char,c)break}line.index++}}if(parse.state!=3)returnif(parse.tp){tp=parse.tptpn=parse.tpntps=parse.tpsparse.tp=null}parse_seq()if(tp.length){parse.tp=tpparse.tps=tpsparse.tpn=tpn}if(sls.length)syntax(1,"Start of slur without note")if(grace){syntax(1,"No end of grace note sequence");curvoice.last_sym=grace.prev;curvoice.last_note=last_note_savif(grace.prev)grace.prev.next=null}if(!no_eol&&!cfmt.barsperstaff&&!vover&&char_tb['\n'.charCodeAt(0)]=='\n')curvoice.eoln=trueif(curvoice.eoln&&cfmt.breakoneoln&&curvoice.last_note)curvoice.last_note.beam_end=true}var sheetvar add_fstyle=typeof document!="undefined"?function(s){var eif(cfmt.fullsvg)font_style+="\n"+sif(!sheet){if(abc2svg.sheet){sheet=abc2svg.sheete=sheet.cssRules.lengthwhile(--e>=0)sheet.deleteRule(e)}else{e=document.createElement('style')document.head.appendChild(e)abc2svg.sheet=sheet=e.sheet}}s=s.match(/[^{]+{[^}]+}/g)while(1){e=s.shift()if(!e)breaksheet.insertRule(e,sheet.cssRules.length)}}:function(s){font_style+="\n"+s}varsw_tb=new Float32Array([.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.250,.333,.408,.500,.500,.833,.778,.333,.333,.333,.500,.564,.250,.564,.250,.278,.500,.500,.500,.500,.500,.500,.500,.500,.500,.500,.278,.278,.564,.564,.564,.444,.921,.722,.667,.667,.722,.611,.556,.722,.722,.333,.389,.722,.611,.889,.722,.722,.556,.722,.667,.556,.611,.722,.722,.944,.722,.722,.611,.333,.278,.333,.469,.500,.333,.444,.500,.444,.500,.444,.333,.500,.500,.278,.278,.500,.278,.778,.500,.500,.500,.500,.333,.389,.278,.500,.500,.722,.500,.500,.444,.480,.200,.480,.541,.500]),ssw_tb=new Float32Array([.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.000,.278,.278,.355,.556,.556,.889,.667,.191,.333,.333,.389,.584,.278,.333,.278,.278,.556,.556,.556,.556,.556,.556,.556,.556,.556,.556,.278,.278,.584,.584,.584,.556,1.015,.667,.667,.722,.722,.667,.611,.778,.722,.278,.500,.667,.556,.833,.722,.778,.667,.778,.722,.667,.611,.722,.667,.944,.667,.667,.611,.278,.278,.278,.469,.556,.333,.556,.556,.500,.556,.556,.278,.556,.556,.222,.222,.500,.222,.833,.556,.556,.556,.556,.333,.500,.278,.556,.500,.722,.500,.500,.500,.334,.260,.334,.584,.512]),cw_tb=sw_tbfunction cwid(c){var i=c.charCodeAt(0)if(i>=0x80){if(i>=0x300&&i<0x370)return 0;i=0x61}return cw_tb[i]}function cwidf(c){return cwid(c)*gene.curfont.swfac}var strwh(function(){if(typeof document!="undefined"){var elstrwh=function(str){if(str.wh)return str.whif(!el){el=document.createElement('text')el.style.position='absolute'el.style.top='-1000px'el.style.padding='0'document.body.appendChild(el)}var c,font=gene.curfont,h=font.size,w=0,n=str.length,i0=0,i=0el.className=font_class(font)el.style.lineHeight=1if(typeof str=="object"){el.innerHTML=strstr.wh=[el.clientWidth,el.clientHeight]return str.wh}str=str.replace(/<|>|&[^&\s]*?;|&/g,function(c){switch(c){case'<':return"<"case'>':return">"case'&':return"&"}return c})while(1){i=str.indexOf('$',i)if(i>=0){c=str[i+1]if(c=='0'){font=gene.deffont}else if(c>='1'&&c<='9'){font=get_font("u"+c)}else{i++continue}}el.innerHTML=str.slice(i0,i>=0?i:undefined)w+=el.clientWidthif(el.clientHeight>h)h=el.clientHeightif(i<0)breakel.style.font=style_font(font).slice(5);i+=2;i0=i}return[w,h]}}else{strwh=function(str){var font=gene.curfont,swfac=font.swfac,h=font.size,w=0,i,j,c,n=str.lengthfor(i=0;i<n;i++){c=str[i]switch(c){case'$':c=str[i+1]if(c=='0'){font=gene.deffont}else if(c>='1'&&c<='9'){font=get_font("u"+c)}else{c='$'break}i++;swfac=font.swfacif(font.size>h)h=font.sizecontinuecase'&':if(str[i+1]==' ')breakj=str.indexOf(';',i)if(j>0&&j-i<10){i=j;c='a'}break}w+=cwid(c)*swfac}return[w,h]}}})()function str2svg(str){if(typeof str=="object")return strvar n_font,wh,o_font=gene.deffont,c_font=gene.curfont,o=""function tspan(nf,of){var clif(nf.class&&nf.name==of.name&&nf.size==of.size&&nf.weight==of.weight&&nf.style==of.style)cl=nf.classelsecl=font_class(nf)return'<tspan\n\tclass="'+cl+'">'}if(c_font!=o_font)o=tspan(c_font,o_font)o+=str.replace(/<|>|&[^&\s]*?;|&|\$./g,function(c){switch(c){case'<':return"<"case'>':return">"case'&':return"&"default:if(c[0]!='$')breakif(c[1]=='0')n_font=gene.deffontelse if(c[1]>='1'&&c[1]<='9')n_font=get_font("u"+c[1])elsebreakc=''if(n_font==c_font)return cif(c_font!=o_font)c="</tspan>"c_font=n_fontif(c_font==o_font)return creturn c+tspan(c_font,o_font)}return c})if(c_font!=o_font)o+="</tspan>"o=new String(o)if(typeof document!="undefined")strwh(o)elseo.wh=strwh(str)gene.curfont=c_fontreturn o}function set_font(xxx){if(typeof xxx=="string")xxx=get_font(xxx)cw_tb=xxx.name.slice(0,4)=='sans'?ssw_tb:sw_tbgene.curfont=gene.deffont=xxx}function out_str(str){output+=str2svg(str)}function xy_str(x,y,str,action,w,wh){if(!wh)wh=str.wh||strwh(str)output+='<text class="'+font_class(gene.deffont)if(action!='j'&&str.length>5&&gene.deffont.wadj)output+='" lengthAdjust="'+gene.deffont.wadj+'" textLength="'+wh[0].toFixed(1);output+='" x="';out_sxsy(x,'" y="',y)switch(action){case'c':output+='" text-anchor="middle">'breakcase'j':output+='" textLength="'+w.toFixed(1)+'">'breakcase'r':output+='" text-anchor="end">'breakdefault:output+='">'break}out_str(str);output+="</text>\n"}function trim_title(title,is_subtitle){var iif(cfmt.titletrim){i=title.lastIndexOf(", ")if(i<0||title[i+2]<'A'||title[i+2]>'Z'){i=0}else if(cfmt.titletrim==1){if(i<title.length-7||title.indexOf(' ',i+3)>=0)i=0}else{if(i<title.length-cfmt.titletrim-2)i=0}if(i)title=title.slice(i+2).trim()+' '+title.slice(0,i)}if(!is_subtitle&&cfmt.writefields.indexOf('X')>=0)title=info.X+'.  '+titleif(cfmt.titlecaps)return title.toUpperCase()return title}function get_lwidth(){if(img.chg)set_page()return img.lw}function write_title(title,is_subtitle){var h,whif(!title)returnset_page();title=trim_title(title,is_subtitle)if(is_subtitle){set_font("subtitle");h=cfmt.subtitlespace}else{set_font("title");h=cfmt.titlespace}wh=strwh(title)wh[1]+=gene.curfont.pad*2vskip(wh[1]+h+gene.curfont.pad)h=gene.curfont.pad+wh[1]*.22if(cfmt.titleleft)xy_str(0,h,title,null,null,wh)elsexy_str(get_lwidth()/2,h,title,"c",null,wh)}function put_inf2r(x,y,str1,str2,action){if(!str1){if(!str2)returnstr1=str2;str2=null}if(!str2)xy_str(x,y,str1,action)elsexy_str(x,y,str1+' ('+str2+')',action)}function write_text(text,action){if(action=='s')returnset_page();var wh,font,o,strlw=get_lwidth(),sz=gene.curfont.size,lineskip=sz*cfmt.lineskipfac,parskip=sz*cfmt.parskipfac,i,j,x,words,w,k,ww,str;switch(action){default:font=gene.curfontswitch(action){case'c':x=strlw/2;breakcase'r':x=strlw-font.pad;breakdefault:x=font.pad;break}j=0while(1){i=text.indexOf('\n',j)if(i==j){vskip(parskip);blk_flush()use_font(gene.curfont)while(text[i+1]=='\n'){vskip(lineskip);i++}if(i==text.length)break}else{if(i<0)str=text.slice(j)elsestr=text.slice(j,i)ww=strwh(str)vskip(ww[1]*cfmt.lineskipfac+font.pad*2)xy_str(x,font.pad+ww[1]*.2,str,action)if(i<0)break}j=i+1}vskip(parskip);blk_flush()breakcase'f':case'j':j=0while(1){i=text.indexOf('\n\n',j)if(i<0)words=text.slice(j)elsewords=text.slice(j,i);words=words.split(/\s+/);w=k=wh=0for(j=0;j<words.length;j++){ww=strwh(words[j]+' ')w+=ww[0]if(w>=strlw){vskip(wh*cfmt.lineskipfac)xy_str(0,ww[1]*.2,words.slice(k,j).join(' '),action,strlw)k=j;w=ww[0]wh=0}if(ww[1]>wh)wh=ww[1]}if(w!=0){vskip(wh*cfmt.lineskipfac)xy_str(0,ww[1]*.2,words.slice(k).join(' '))}vskip(parskip);blk_flush()if(i<0)breakwhile(text[i+2]=='\n'){vskip(lineskip);i++}if(i==text.length)breakuse_font(gene.curfont);j=i+2}break}}function put_words(words){var p,i,j,nw,w,lw,x1,x2,i1,i2,do_flush,maxn=0,n=1function put_wline(p,x){var i=0,k=0if(p[0]=='$'&&p[1]>='0'&&p[1]<='9'){gene.curfont=p[1]=='0'?gene.deffont:get_font("u"+p[1])p=p.slice(2)}if((p[i]>='0'&&p[i]<='9')||p[i+1]=='.'){while(i<p.length){i++if(p[i]==' '||p[i-1]==':'||p[i-1]=='.')break}k=iwhile(p[i]==' ')i++}var y=gene.curfont.size*.22if(k!=0)xy_str(x,y,p.slice(0,k),'r')if(i<p.length)xy_str(x+5,y,p.slice(i),'l')}set_font("words")vskip(cfmt.wordsspace)svg_flush()words=words.split('\n')nw=words.lengthfor(i=0;i<nw;i++){p=words[i]if(!p){while(i+1<nw&&!words[i+1])i++n++}else if(p.length>maxn){maxn=p.lengthi1=i}}w=get_lwidth()/2lw=strwh(words[i1])[0]i1=i2=0if(lw<w){j=n>>1for(i=0;i<nw;i++){p=words[i]if(!p){if(--j<=0)i1=iwhile(i+1<nw&&!words[i+1])i++if(j<=0){i2=i+1break}}}n>>=1}if(i2){x1=(w-lw)/2+10x2=x1+w}else{x2=w-lw/2+10}do_flush=truefor(i=0;i<i1||i2<nw;i++,i2++){vskip(cfmt.lineskipfac*gene.curfont.size)if(i<i1){p=words[i]if(p)put_wline(p,x1)elseuse_font(gene.curfont)}if(i2<nw){p=words[i2]if(p){put_wline(p,x2)}else{if(--n==0){if(i<i1){n++}else if(i2<nw-1){x2=w-lw/2+10svg_flush()}}}}if(!words[i+1]&&!words[i2+1]){if(do_flush){svg_flush()do_flush=false}}else{do_flush=true}}}function put_history(){var i,j,c,str,font,h,w,wh,head,names=cfmt.infoname.split("\n"),n=names.lengthfor(i=0;i<n;i++){c=names[i][0]if(cfmt.writefields.indexOf(c)<0)continuestr=info[c]if(!str)continueif(!font){font=true;set_font("history");vskip(cfmt.textspace);h=gene.curfont.size*cfmt.lineskipfac}head=names[i].slice(2)if(head[0]=='"')head=head.slice(1,-1);vskip(h);wh=strwh(head);xy_str(0,wh[1]*.22,head,null,null,wh);w=wh[0];str=str.split('\n');xy_str(w,wh[1]*.22,str[0])for(j=1;j<str.length;j++){if(!str[j]){vskip(gene.curfont.size*cfmt.parskipfac)continue}vskip(h);xy_str(w,wh[1]*.22,str[j])}vskip(h*cfmt.parskipfac)use_font(gene.curfont)}}var info_font_init={A:"info",C:"composer",O:"composer",P:"parts",Q:"tempo",R:"info",T:"title",X:"title"}function write_headform(lwidth){var c,font,font_name,align,x,y,sz,w,info_val={},info_font=Object.create(info_font_init),info_sz={A:cfmt.infospace,C:cfmt.composerspace,O:cfmt.composerspace,R:cfmt.infospace},info_nb={}var fmt="",p=cfmt.titleformat,j=0,i=0while(1){while(p[i]==' ')i++c=p[i++]if(!c)breakif(c<'A'||c>'Z'){switch(c){case'+':align='+'c=p[i++]breakcase',':fmt+='\n'default:continuecase'<':align='l'c=p[i++]breakcase'>':align='r'c=p[i++]break}}else{switch(p[i]){case'-':align='l'i++breakcase'1':align='r'i++breakcase'0':i++default:align='c'break}}if(!info_val[c]){if(!info[c])continueinfo_val[c]=info[c].split('\n');info_nb[c]=1}else{info_nb[c]++}fmt+=align+c}fmt+='\n'var ya={l:cfmt.titlespace,c:cfmt.titlespace,r:cfmt.titlespace},xa={l:0,c:lwidth*.5,r:lwidth},yb={},str;p=fmt;i=0while(1){yb.l=yb.c=yb.r=y=0;j=iwhile(1){align=p[j++]if(align=='\n')breakc=p[j++]if(align=='+'||yb[align])continuestr=info_val[c]if(!str)continuefont_name=info_font[c]if(!font_name)font_name="history";font=get_font(font_name);sz=font.size*1.1if(info_sz[c])sz+=info_sz[c]if(y<sz)y=sz;yb[align]=sz}ya.l+=y-yb.l;ya.c+=y-yb.c;ya.r+=y-yb.rwhile(1){align=p[i++]if(align=='\n')breakc=p[i++]if(!info_val[c].length)continuestr=info_val[c].shift()if(p[i]=='+'){info_nb[c]--;i++c=p[i++];if(info_val[c].length){if(str)str+=' '+info_val[c].shift()elsestr=' '+info_val[c].shift()}}font_name=info_font[c]if(!font_name)font_name="history";font=get_font(font_name);sz=font.size*1.1if(info_sz[c])sz+=info_sz[c];set_font(font);x=xa[align];y=ya[align]+szif(c=='Q'){self.set_width(glovar.tempo)if(!glovar.tempo.invis){if(align!='l'){tempo_build(glovar.tempo)w=glovar.tempo.tempo_wh[0]if(align=='c')w*=.5;x-=w}writempo(glovar.tempo,x,-y)}}else if(str){if(c=='T')str=trim_title(str,info_font.T[0]=='s')xy_str(x,-y,str,align)}if(c=='T'){font_name=info_font.T="subtitle";info_sz.T=cfmt.subtitlespace}if(info_nb[c]<=1){if(c=='T'){font=get_font(font_name);sz=font.size*1.1if(info_sz[c])sz+=info_sz[c];set_font(font)}while(info_val[c].length>0){y+=sz;str=info_val[c].shift();xy_str(x,-y,str,align)}}info_nb[c]--;ya[align]=y}if(ya.c>ya.l)ya.l=ya.cif(ya.r>ya.l)ya.l=ya.rif(i>=p.length)breakya.c=ya.r=ya.l}vskip(ya.l)}function write_heading(){var i,j,area,composer,origin,rhythm,down1,down2,lwidth=get_lwidth()vskip(cfmt.topspace)if(cfmt.titleformat){write_headform(lwidth);vskip(cfmt.musicspace)return}if(info.T&&cfmt.writefields.indexOf('T')>=0){i=0while(1){j=info.T.indexOf("\n",i)if(j<0){write_title(info.T.substring(i),i!=0)break}write_title(info.T.slice(i,j),i!=0);i=j+1}}down1=down2=0if(parse.ckey.k_bagpipe&&!cfmt.infoline&&cfmt.writefields.indexOf('R')>=0)rhythm=info.Rif(rhythm){set_font("composer");down1=cfmt.composerspace+gene.curfont.size+2xy_str(0,-down1+gene.curfont.size*.22,rhythm)}area=info.Aif(cfmt.writefields.indexOf('C')>=0)composer=info.Cif(cfmt.writefields.indexOf('O')>=0)origin=info.Oif(composer||origin||cfmt.infoline){var xcomp,align;set_font("composer");if(cfmt.aligncomposer<0){xcomp=0;align=' '}else if(cfmt.aligncomposer==0){xcomp=lwidth*.5;align='c'}else{xcomp=lwidth;align='r'}if(composer||origin){down2=cfmt.composerspace+2i=0while(1){down2+=gene.curfont.sizeif(composer)j=composer.indexOf("\n",i)elsej=-1if(j<0){put_inf2r(xcomp,-down2+gene.curfont.size*.22,composer?composer.substring(i):null,origin,align)break}xy_str(xcomp,-down2+gene.curfont.size*.22,composer.slice(i,j),align);i=j+1}}rhythm=rhythm?null:info.Rif((rhythm||area)&&cfmt.infoline){set_font("info");down2+=cfmt.infospace+gene.curfont.sizeput_inf2r(lwidth,-down2+gene.curfont.size*.22,rhythm,area,'r')}}if(info.P&&cfmt.writefields.indexOf('P')>=0){set_font("parts");i=cfmt.partsspace+gene.curfont.size+gene.curfont.padif(down1+i>down2)down2=down1+ielsedown2+=ixy_str(0,-down2+gene.curfont.size*.22,info.P)down2+=gene.curfont.pad}else if(down1>down2){down2=down1}vskip(down2+cfmt.musicspace)}var output="",style='\\n.stroke{stroke:currentColor;fill:none}\\n.bW{stroke:currentColor;fill:none;stroke-width:1}\\n.bthW{stroke:currentColor;fill:none;stroke-width:3}\\n.slW{stroke:currentColor;fill:none;stroke-width:.7}\\n.slthW{stroke:currentColor;fill:none;stroke-width:1.5}\\n.sW{stroke:currentColor;fill:none;stroke-width:.7}\\n.box{outline:1px solid black;outline-offset:1px}',font_style='',posx=cfmt.leftmargin/cfmt.scale,posy=0,img={width:cfmt.pagewidth,lm:cfmt.leftmargin,rm:cfmt.rightmargin,chg:1},defined_glyph={},defs='',fulldefs='',stv_g={scale:1,dy:0,st:-1,v:-1,g:0},blkdiv=0var tgls={"mtr ":{x:0,y:0,c:"\u0020"},brace:{x:0,y:0,c:"\ue000"},lphr:{x:0,y:23,c:"\ue030"},mphr:{x:0,y:23,c:"\ue038"},sphr:{x:0,y:26,c:"\ue039"},short:{x:0,y:32,c:"\ue038"},tick:{x:0,y:29,c:"\ue039"},rdots:{x:-1,y:0,c:"\ue043"},dsgn:{x:-12,y:0,c:"\ue045"},dcap:{x:-12,y:0,c:"\ue046"},sgno:{x:-5,y:0,c:"\ue047"},coda:{x:-10,y:0,c:"\ue048"},tclef:{x:-8,y:0,c:"\ue050"},cclef:{x:-8,y:0,c:"\ue05c"},bclef:{x:-8,y:0,c:"\ue062"},pclef:{x:-6,y:0,c:"\ue069"},spclef:{x:-6,y:0,c:"\ue069"},stclef:{x:-8,y:0,c:"\ue07a"},scclef:{x:-8,y:0,c:"\ue07b"},sbclef:{x:-7,y:0,c:"\ue07c"},oct:{x:0,y:2,c:"\ue07d"},oct2:{x:0,y:2,c:"\ue07e"},mtr0:{x:0,y:0,c:"\ue080"},mtr1:{x:0,y:0,c:"\ue081"},mtr2:{x:0,y:0,c:"\ue082"},mtr3:{x:0,y:0,c:"\ue083"},mtr4:{x:0,y:0,c:"\ue084"},mtr5:{x:0,y:0,c:"\ue085"},mtr6:{x:0,y:0,c:"\ue086"},mtr7:{x:0,y:0,c:"\ue087"},mtr8:{x:0,y:0,c:"\ue088"},mtr9:{x:0,y:0,c:"\ue089"},mtrC:{x:0,y:0,c:"\ue08a"},"mtr+":{x:0,y:0,c:"\ue08c"},"mtr(":{x:0,y:0,c:"\ue094"},"mtr)":{x:0,y:0,c:"\ue095"},HDD:{x:-7,y:0,c:"\ue0a0"},breve:{x:-7,y:0,c:"\ue0a1"},HD:{x:-5.2,y:0,c:"\ue0a2"},Hd:{x:-3.8,y:0,c:"\ue0a3"},hd:{x:-3.7,y:0,c:"\ue0a4"},ghd:{x:2,y:0,c:"\ue0a4",sc:.66},pshhd:{x:-3.7,y:0,c:"\ue0a9"},pfthd:{x:-3.7,y:0,c:"\ue0b3"},x:{x:-3.7,y:0,c:"\ue0a9"},"circle-x":{x:-3.7,y:0,c:"\ue0b3"},srep:{x:-5,y:0,c:"\ue101"},"dot+":{x:-5,y:0,sc:.7,c:"\ue101"},diamond:{x:-4,y:0,c:"\ue1b9"},triangle:{x:-4,y:0,c:"\ue1bb"},dot:{x:-1,y:0,c:"\ue1e7"},flu1:{x:-.3,y:0,c:"\ue240"},fld1:{x:-.3,y:0,c:"\ue241"},flu2:{x:-.3,y:0,c:"\ue242"},fld2:{x:-.3,y:0,c:"\ue243"},flu3:{x:-.3,y:3.5,c:"\ue244"},fld3:{x:-.3,y:-4,c:"\ue245"},flu4:{x:-.3,y:8,c:"\ue246"},fld4:{x:-.3,y:-9,c:"\ue247"},flu5:{x:-.3,y:12.5,c:"\ue248"},fld5:{x:-.3,y:-14,c:"\ue249"},"acc-1":{x:-1,y:0,c:"\ue260"},"cacc-1":{x:-18,y:0,c:"\ue26a\ue260\ue26b"},"sacc-1":{x:-1,y:0,sc:.7,c:"\ue260"},acc3:{x:-1,y:0,c:"\ue261"},"cacc3":{x:-18,y:0,c:"\ue26a\ue261\ue26b"},sacc3:{x:-1,y:0,sc:.7,c:"\ue261"},acc1:{x:-2,y:0,c:"\ue262"},"cacc1":{x:-18,y:0,c:"\ue26a\ue262\ue26b"},sacc1:{x:-2,y:0,sc:.7,c:"\ue262"},acc2:{x:-3,y:0,c:"\ue263"},"acc-2":{x:-3,y:0,c:"\ue264"},"acc-1_2":{x:-2,y:0,c:"\ue280"},"acc-3_2":{x:-3,y:0,c:"\ue281"},acc1_2:{x:-1,y:0,c:"\ue282"},acc3_2:{x:-3,y:0,c:"\ue283"},accent:{x:-3,y:2,c:"\ue4a0"},stc:{x:0,y:-2,c:"\ue4a2"},emb:{x:0,y:-2,c:"\ue4a4"},wedge:{x:0,y:0,c:"\ue4a8"},marcato:{x:-3,y:-2,c:"\ue4ac"},hld:{x:-7,y:-2,c:"\ue4c0"},brth:{x:0,y:0,c:"\ue4ce"},caes:{x:0,y:8,c:"\ue4d1"},r00:{x:-1.5,y:0,c:"\ue4e1"},r0:{x:-1.5,y:0,c:"\ue4e2"},r1:{x:-3.5,y:-6,c:"\ue4e3"},r2:{x:-3.2,y:0,c:"\ue4e4"},r4:{x:-3,y:0,c:"\ue4e5"},r8:{x:-3,y:0,c:"\ue4e6"},r16:{x:-4,y:0,c:"\ue4e7"},r32:{x:-4,y:0,c:"\ue4e8"},r64:{x:-4,y:0,c:"\ue4e9"},r128:{x:-4,y:0,c:"\ue4ea"},mrep:{x:-6,y:0,c:"\ue500"},mrep2:{x:-9,y:0,c:"\ue501"},p:{x:-3,y:0,c:"\ue520"},f:{x:-3,y:0,c:"\ue522"},pppp:{x:-15,y:0,c:"\ue529"},ppp:{x:-14,y:0,c:"\ue52a"},pp:{x:-8,y:0,c:"\ue52b"},mp:{x:-8,y:0,c:"\ue52c"},mf:{x:-8,y:0,c:"\ue52d"},ff:{x:-7,y:0,c:"\ue52f"},fff:{x:-10,y:0,c:"\ue530"},ffff:{x:-14,y:0,c:"\ue531"},sfz:{x:-10,y:0,c:"\ue539"},trl:{x:-5,y:-2,c:"\ue566"},turn:{x:-5,y:0,c:"\ue567"},turnx:{x:-5,y:0,c:"\ue569"},umrd:{x:-6,y:2,c:"\ue56c"},lmrd:{x:-6,y:2,c:"\ue56d"},dplus:{x:-3,y:0,c:"\ue582"},sld:{x:-8,y:12,c:"\ue5d0"},grm:{x:-3,y:-2,c:"\ue5e2"},dnb:{x:-3,y:0,c:"\ue610"},upb:{x:-2,y:0,c:"\ue612"},opend:{x:-2,y:-2,c:"\ue614"},roll:{x:0,y:0,c:"\ue618"},thumb:{x:-2,y:-2,c:"\ue624"},snap:{x:-2,y:-2,c:"\ue630"},ped:{x:-10,y:0,c:"\ue650"},pedoff:{x:-5,y:0,c:"\ue655"},mtro:{x:0,y:0,c:"\ue911"},mtrc:{x:0,y:0,c:"\ue915"},"mtr.":{x:0,y:0,c:"\ue920"},"mtr|":{x:0,y:0,c:"\ue925"},longa:{x:-4.7,y:0,c:"\ue95d"},custos:{x:-4,y:3,c:"\uea02"},ltr:{x:2,y:6,c:"\ueaa4"}}var glyphs={}function m_gl(s){return s.replace(/[Cco]\||[co]\.|./g,function(e){var m=tgls["mtr"+e]return m?m.c:0})}function def_use(gl){var i,j,gif(defined_glyph[gl])returndefined_glyph[gl]=true;g=glyphs[gl]if(!g){error(1,null,"Unknown glyph: '$1'",gl)return}j=0while(1){i=g.indexOf('xlink:href="#',j)if(i<0)breaki+=13;j=g.indexOf('"',i);def_use(g.slice(i,j))}defs+='\n'+g}function defs_add(text){var i,j,gl,tag,is,ie=0text=text.replace(/<!--.*?-->/g,'')while(1){is=text.indexOf('<',ie);if(is<0)breaki=text.indexOf('id="',is)if(i<0)breaki+=4;j=text.indexOf('"',i);if(j<0)breakgl=text.slice(i,j);ie=text.indexOf('>',j);if(ie<0)breakif(text[ie-1]=='/'){ie++}else{i=text.indexOf(' ',is);if(i<0)breaktag=text.slice(is+1,i);ie=text.indexOf('</'+tag+'>',ie)if(ie<0)breakie+=3+tag.length}if(text.substr(is,7)=='<filter')fulldefs+=text.slice(is,ie)+'\n'elseglyphs[gl]=text.slice(is,ie)}}function set_g(){if(stv_g.started){stv_g.started=false;glout()output+="</g>\n"}if(stv_g.scale==1&&!stv_g.color)returnglout()output+='<g 'if(stv_g.scale!=1){if(stv_g.st<0)output+=voice_tb[stv_g.v].scale_strelse if(stv_g.v<0)output+=staff_tb[stv_g.st].scale_strelseoutput+='transform="translate(0,'+(posy-stv_g.dy).toFixed(1)+') scale('+stv_g.scale.toFixed(2)+')"'}if(stv_g.color){if(stv_g.scale!=1)output+=' ';output+='color="'+stv_g.color+'"'}output+=">\n";stv_g.started=true}function set_color(color){if(color==stv_g.color)return undefinedvar old_color=stv_g.color;stv_g.color=color;set_g()return old_color}function set_sscale(st){var new_scale,dyif(st!=stv_g.st&&stv_g.scale!=1)stv_g.scale=0;new_scale=st>=0?staff_tb[st].staffscale:1if(st>=0&&new_scale!=1)dy=staff_tb[st].yelsedy=posyif(new_scale==stv_g.scale&&dy==stv_g.dy)returnstv_g.scale=new_scale;stv_g.dy=dy;stv_g.st=st;stv_g.v=-1;set_g()}function set_scale(s){var new_dy,new_scale=s.p_v.scaleif(new_scale==1){set_sscale(s.st)return}new_dy=posyif(staff_tb[s.st].staffscale!=1){new_scale*=staff_tb[s.st].staffscale;new_dy=staff_tb[s.st].y}if(new_scale==stv_g.scale&&stv_g.dy==posy)returnstv_g.scale=new_scale;stv_g.dy=new_dy;stv_g.st=staff_tb[s.st].staffscale==1?-1:s.st;stv_g.v=s.v;set_g()}function set_dscale(st,no_scale){if(output){if(stv_g.started){stv_g.started=falseglout()output+="</g>\n"}if(stv_g.st<0){staff_tb[0].output+=output}else if(stv_g.scale==1){staff_tb[stv_g.st].output+=output}else{staff_tb[stv_g.st].sc_out+=output}output=""}if(st<0)stv_g.scale=1elsestv_g.scale=no_scale?1:staff_tb[st].staffscale;stv_g.st=st;stv_g.dy=0}function delayed_update(){var st,new_out,textfor(st=0;st<=nstaff;st++){if(staff_tb[st].sc_out){output+='<g '+staff_tb[st].scale_str+'>\n'+staff_tb[st].sc_out+'</g>\n';staff_tb[st].sc_out=""}if(!staff_tb[st].output)continueoutput+='<g transform="translate(0,'+(-staff_tb[st].y).toFixed(1)+')">\n'+staff_tb[st].output+'</g>\n';staff_tb[st].output=""}}function anno_out(s,t,f){if(s.istart==undefined)returnvar type=s.type,h=s.ymx-s.ymn+4,wl=s.wl||2,wr=s.wr||2if(s.grace)type=C.GRACEf(t||abc2svg.sym_name[type],s.istart,s.iend,s.x-wl-2,staff_tb[s.st].y+s.ymn+h-2,wl+wr+4,h,s)}function a_start(s,t){anno_out(s,t,user.anno_start)}function a_stop(s,t){anno_out(s,t,user.anno_stop)}function empty_function(){}var anno_start=empty_function,anno_stop=empty_functionfunction anno_put(){var swhile(1){s=anno_a.shift()if(!s)breakswitch(s.type){case C.CLEF:case C.METER:case C.KEY:case C.REST:if(s.type!=C.REST||s.rep_nb){set_sscale(s.st)break}case C.GRACE:case C.NOTE:case C.MREST:set_scale(s)break}anno_stop(s)}}function out_XYAB(str,x,y,a,b){x=sx(x);y=sy(y);output+=str.replace(/X|Y|A|B|F|G/g,function(c){switch(c){case'X':return x.toFixed(1)case'Y':return y.toFixed(1)case'A':return acase'B':return bcase'F':return a.toFixed(1)default:return b.toFixed(1)}})}function g_open(x,y,rot,sx,sy){glout()out_XYAB('<g transform="translate(X,Y',x,y);if(rot)output+=') rotate('+rot.toFixed(2)if(sx){if(sy)output+=') scale('+sx.toFixed(2)+', '+sy.toFixed(2)elseoutput+=') scale('+sx.toFixed(2)}output+=')">\n';stv_g.g++}function g_close(){glout()stv_g.g--;output+='</g>\n'}Abc.prototype.out_svg=function(str){output+=str}function sx(x){if(stv_g.g)return xreturn(x+posx)/stv_g.scale}Abc.prototype.sx=sxfunction sy(y){if(stv_g.g)return-yif(stv_g.scale==1)return posy-yif(stv_g.v>=0)return(stv_g.dy-y)/voice_tb[stv_g.v].scalereturn stv_g.dy-y}Abc.prototype.sy=sy;Abc.prototype.sh=function(h){if(stv_g.st<0)return h/stv_g.scalereturn h}Abc.prototype.ax=function(x){return x+posx}Abc.prototype.ay=function(y){if(stv_g.st<0)return posy-yreturn posy+(stv_g.dy-y)*stv_g.scale-stv_g.dy}Abc.prototype.ah=function(h){if(stv_g.st<0)return hreturn h*stv_g.scale}function out_sxsy(x,sep,y){x=sx(x);y=sy(y);output+=x.toFixed(1)+sep+y.toFixed(1)}Abc.prototype.out_sxsy=out_sxsyfunction xypath(x,y,fill){if(fill)out_XYAB('<path d="mX Y',x,y)elseout_XYAB('<path class="stroke" d="mX Y',x,y)}Abc.prototype.xypath=xypathfunction draw_all_hl(){var st,p_stfunction hlud(hla,d){var hl,hll,i,xp,dx2,x2,n=hla.lengthif(!n)returnfor(i=0;i<n;i++){hll=hla[i]if(!hll||!hll.length)continuexp=sx(hll[0][0])output+='<path class="stroke" stroke-width="1" d="M'+xp.toFixed(1)+' '+sy(p_st.y+d*i).toFixed(1)dx2=0while(1){hl=hll.shift()if(!hl)breakx2=sx(hl[0])output+='m'+(x2-xp+hl[1]-dx2).toFixed(2)+' 0h'+(-hl[1]+hl[2]).toFixed(2)xp=x2dx2=hl[2]}output+='"/>\n'}}for(st=0;st<=nstaff;st++){p_st=staff_tb[st]if(!p_st.hlu)continueset_sscale(st)hlud(p_st.hlu,6)hlud(p_st.hld,-6)}}var gla=[[],[],"",[],[],[]]function glout(){var e,v=[]if(gla[0].length){while(1){e=gla[0].shift()if(e==undefined)breakv.push(e.toFixed(1))}output+='<text x="'+v.join(',')v=[]while(1){e=gla[1].shift()if(e==undefined)breakv.push(e.toFixed(1))}output+='"\ny="'+v.join(',')output+='"\n>'+gla[2]+'</text>\n'gla[2]=""}if(!gla[3].length)returnoutput+='<path class="sW" d="'while(1){e=gla[3].shift()if(e==undefined)breakoutput+='M'+e.toFixed(1)+' '+gla[3].shift().toFixed(1)+'v'+gla[3].shift().toFixed(1)}output+='"/>\n'}function xygl(x,y,gl){if(glyphs[gl]){def_use(gl)out_XYAB('<use x="X" y="Y" xlink:href="#A"/>\n',x,y,gl)}else{var tgl=tgls[gl]if(tgl){x+=tgl.x*stv_g.scale;y-=tgl.yif(tgl.sc){out_XYAB('<text transform="translate(X,Y) scale(A)">B</text>\n',x,y,tgl.sc,tgl.c)}else{gla[0].push(sx(x))gla[1].push(sy(y))gla[2]+=tgl.c}}else{error(1,null,'no definition of $1',gl)}}}function out_acciac(x,y,dx,dy,up){if(up){x-=1;y+=4}else{x-=5;y-=4}out_XYAB('<path class="stroke" d="mX YlF G"/>\n',x,y,dx,-dy)}function out_brace(x,y,h){x+=posx-6;y=posy-y;h/=24;output+='<text transform="translate('+x.toFixed(1)+','+y.toFixed(1)+') scale(2.5,'+h.toFixed(2)+')">'+tgls.brace.c+'</text>\n'}function out_bracket(x,y,h){x+=posx-5;y=posy-y-3;h+=2;output+='<path d="m'+x.toFixed(1)+' '+y.toFixed(1)+'\n\ c10.5 1 12 -4.5 12 -3.5c0 1 -3.5 5.5 -8.5 5.5\n\ v'+h.toFixed(1)+'\n\ c5 0 8.5 4.5 8.5 5.5c0 1 -1.5 -4.5 -12 -3.5"/>\n'}function out_hyph(x,y,w){var n,a_y,d=25+((w/20)|0)*3if(w>15.)n=((w-15)/d)|0elsen=0;x+=(w-d*n-5)/2;out_XYAB('<path class="stroke" stroke-width="1.2"\n\ stroke-dasharray="5,A"\n\ d="mX YhB"/>\n',x,y+4,Math.round((d-5)/stv_g.scale),d*n+5)}function out_stem(x,y,h,grace,nflags,straight){var dx=grace?GSTEM_XOFF:3.5,slen=-hif(h<0)dx=-dx;x+=dx*stv_g.scaleif(stv_g.v>=0)slen/=voice_tb[stv_g.v].scale;gla[3].push(sx(x))gla[3].push(sy(y))gla[3].push(slen)if(!nflags)returny+=hif(h>0){if(!straight){if(!grace){xygl(x,y,"flu"+nflags)return}else{output+='<path d="'if(nflags==1){out_XYAB('MX Yc0.6 3.4 5.6 3.8 3 10\n\ 1.2 -4.4 -1.4 -7 -3 -7\n',x,y)}else{while(--nflags>=0){out_XYAB('MX Yc1 3.2 5.6 2.8 3.2 8\n\ 1.4 -4.8 -2.4 -5.4 -3.2 -5.2\n',x,y);y-=3.5}}}}else{output+='<path d="'if(!grace){while(--nflags>=0){out_XYAB('MX Yl7 3.2 0 3.2 -7 -3.2z\n',x,y);y-=5.4}}else{while(--nflags>=0){out_XYAB('MX Yl3 1.5 0 2 -3 -1.5z\n',x,y);y-=3}}}}else{if(!straight){if(!grace){xygl(x,y,"fld"+nflags)return}else{output+='<path d="'if(nflags==1){out_XYAB('MX Yc0.6 -3.4 5.6 -3.8 3 -10\n\ 1.2 4.4 -1.4 7 -3 7\n',x,y)}else{while(--nflags>=0){out_XYAB('MX Yc1 -3.2 5.6 -2.8 3.2 -8\n\ 1.4 4.8 -2.4 5.4 -3.2 5.2\n',x,y);y+=3.5}}}}else{output+='<path d="'if(!grace){while(--nflags>=0){out_XYAB('MX Yl7 -3.2 0 -3.2 -7 3.2z\n',x,y);y+=5.4}}}}output+='"/>\n'}function out_trem(x,y,ntrem){out_XYAB('<path d="mX Y\n\t',x-4.5,y)while(1){output+='l9 -3v3l-9 3z'if(--ntrem<=0)breakoutput+='m0 5.4'}output+='"/>\n'}function out_tubr(x,y,dx,dy,up){var h=up?-3:3;y+=h;dx/=stv_g.scale;output+='<path class="stroke" d="m';out_sxsy(x,' ',y);output+='v'+h.toFixed(1)+'l'+dx.toFixed(1)+' '+(-dy).toFixed(1)+'v'+(-h).toFixed(1)+'"/>\n'}function out_tubrn(x,y,dx,dy,up,str){var dxx,sw=str.length*10,h=up?-3:3;set_font("tuplet")xy_str(x+dx/2,y+dy/2-gene.curfont.size*.1,str,'c')dx/=stv_g.scaleif(!up)y+=6;output+='<path class="stroke" d="m';out_sxsy(x,' ',y);dxx=dx-sw+1if(dy>0)sw+=dy/8elsesw-=dy/8output+='v'+h.toFixed(1)+'m'+dx.toFixed(1)+' '+(-dy).toFixed(1)+'v'+(-h).toFixed(1)+'"/>\n'+'<path class="stroke" stroke-dasharray="'+(dxx/2).toFixed(1)+' '+sw.toFixed(1)+'" d="m';out_sxsy(x,' ',y-h);output+='l'+dx.toFixed(1)+' '+(-dy).toFixed(1)+'"/>\n'}function out_wln(x,y,w){out_XYAB('<path class="stroke" stroke-width="0.8" d="mX YhF"/>\n',x,y+1,w)}var deco_str_style={crdc:{dx:0,dy:5,style:'font:italic 14px text,serif',anchor:' text-anchor="middle"'},dacs:{dx:0,dy:3,style:'font:16px text,serif',anchor:' text-anchor="middle"'},pf:{dx:0,dy:5,style:'font:italic bold 16px text,serif'},'@':{dx:0,dy:5,style:'font:12px text,sans-serif'}}function out_deco_str(x,y,name,str){if(name=='fng'){out_XYAB('\<text x="X" y="Y" style="font-size:14px">A</text>\n',x-2,y,m_gl(str))return}var f,a_deco=deco_str_style[name]if(!a_deco){xygl(x,y,name)return}x+=a_deco.dx;y+=a_deco.dy;if(!a_deco.def){style+="\n."+name+" {"+a_deco.style+"}";a_deco.def=true}out_XYAB('<text x="X" y="Y" class="A"B>',x,y,name,a_deco.anchor||"");set_font("annotation");out_str(str);output+='</text>\n'}function out_arp(x,y,val){g_open(x,y,270);x=0;val=Math.ceil(val/6)while(--val>=0){xygl(x,6,"ltr");x+=6}g_close()}function out_cresc(x,y,val,defl){x+=val*stv_g.scaleval=-val;out_XYAB('<path class="stroke"\n\ d="mX YlF ',x,y,val)if(defl.nost)output+='-2.2m0 -3.6l'+(-val).toFixed(1)+' -2.2"/>\n'elseoutput+='-4l'+(-val).toFixed(1)+' -4"/>\n'}function out_dim(x,y,val,defl){out_XYAB('<path class="stroke"\n\ d="mX YlF ',x,y,val)if(defl.noen)output+='-2.2m0 -3.6l'+(-val).toFixed(1)+' -2.2"/>\n'elseoutput+='-4l'+(-val).toFixed(1)+' -4"/>\n'}function out_ltr(x,y,val){y+=4;val=Math.ceil(val/6)while(--val>=0){xygl(x,y,"ltr");x+=6}}Abc.prototype.out_lped=function(x,y,val,defl){if(!defl.nost)xygl(x,y,"ped");if(!defl.noen)xygl(x+val+6,y,"pedoff")}function out_8va(x,y,val,defl){if(val<18){val=18x-=4}if(!defl.nost){out_XYAB('<text x="X" y="Y" \style="font:italic bold 12px text,serif">8\<tspan dy="-4" style="font-size:10px">va</tspan></text>\n',x-8,y);x+=12;val-=12}y+=6;out_XYAB('<path class="stroke" stroke-dasharray="6,6" d="mX YhF"/>\n',x,y,val)if(!defl.noen)out_XYAB('<path class="stroke" d="mX Yv6"/>\n',x+val,y)}function out_8vb(x,y,val,defl){if(val<18){val=18x-=4}if(!defl.nost){out_XYAB('<text x="X" y="Y" \style="font:italic bold 12px text,serif">8\<tspan dy=".5" style="font-size:10px">vb</tspan></text>\n',x-8,y);x+=10val-=10}out_XYAB('<path class="stroke" stroke-dasharray="6,6" d="mX YhF"/>\n',x,y,val)if(!defl.noen)out_XYAB('<path class="stroke" d="mX Yv-6"/>\n',x+val,y)}function out_15ma(x,y,val,defl){if(val<25){val=25x-=6}if(!defl.nost){out_XYAB('<text x="X" y="Y" \style="font:italic bold 12px text,serif">15\<tspan dy="-4" style="font-size:10px">ma</tspan></text>\n',x-10,y);x+=20;val-=20}y+=6;out_XYAB('<path class="stroke" stroke-dasharray="6,6" d="mX YhF"/>\n',x,y,val)if(!defl.noen)out_XYAB('<path class="stroke" d="mX Yv6"/>\n',x+val,y)}function out_15mb(x,y,val,defl){if(val<24){val=24x-=5}if(!defl.nost){out_XYAB('<text x="X" y="Y" \style="font:italic bold 12px text,serif">15\<tspan dy=".5" style="font-size:10px">mb</tspan></text>\n',x-10,y);x+=18val-=18}out_XYAB('<path class="stroke" stroke-dasharray="6,6" d="mX YhF"/>\n',x,y,val)if(!defl.noen)out_XYAB('<path class="stroke" d="mX Yv-6"/>\n',x+val,y)}var deco_val_tb={arp:out_arp,cresc:out_cresc,dim:out_dim,ltr:out_ltr,lped:function(x,y,val,defl){self.out_lped(x,y,val,defl)},"8va":out_8va,"8vb":out_8vb,"15ma":out_15ma,"15mb":out_15mb}function out_deco_val(x,y,name,val,defl){if(deco_val_tb[name])deco_val_tb[name](x,y,val,defl)elseerror(1,null,"No function for decoration '$1'",name)}function out_glisq(x2,y2,de){var ar,a,len,de1=de.start,x1=de1.x,y1=de1.y+staff_tb[de1.st].y,dx=x2-x1,dy=self.sh(y1-y2)if(!stv_g.g)dx/=stv_g.scalear=Math.atan2(dy,dx)a=ar/Math.PI*180len=(dx-(de1.s.dots?13+de1.s.xmx:8)-8-(de.s.notes[0].shac||0))/ Math.cos(ar)g_open(x1,y1,a);x1=de1.s.dots?13+de1.s.xmx:8;len=len/6|0if(len<1)len=1while(--len>=0){xygl(x1,0,"ltr");x1+=6}g_close()}function out_gliss(x2,y2,de){var ar,a,len,de1=de.start,x1=de1.x,y1=de1.y+staff_tb[de1.st].y,dx=x2-x1,dy=self.sh(y1-y2)if(!stv_g.g)dx/=stv_g.scalear=Math.atan2(dy,dx)a=ar/Math.PI*180len=(dx-(de1.s.dots?13+de1.s.xmx:8)-8-(de.s.notes[0].shac||0))/ Math.cos(ar)g_open(x1,y1,a);xypath(de1.s.dots?13+de1.s.xmx:8,0)output+='h'+len.toFixed(1)+'" stroke-width="1"/>\n';g_close()}var deco_l_tb={glisq:out_glisq,gliss:out_gliss}function out_deco_long(x,y,de){var s,p_v,m,nt,i,name=de.dd.glyph,de1=de.startif(!deco_l_tb[name]){error(1,null,"No function for decoration '$1'",name)return}p_v=de.s.p_vif(de.defl.noen){s=p_v.s_nextwhile(s&&!s.dur)s=s.nextif(s){for(m=0;m<=s.nhd;m++){nt=s.notes[m]if(!nt.a_dd)continuefor(i=0;i<nt.a_dd.length;i++){if(nt.a_dd[i].name==de.dd.name){y=3*(nt.pit-18)+staff_tb[de.s.st].ybreak}}}}x+=8}else if(de.defl.nost){s=p_v.s_prevwhile(s&&!s.dur)s=s.previf(s){for(m=0;m<=s.nhd;m++){nt=s.notes[m]if(!nt.a_dd)continuefor(i=0;i<nt.a_dd.length;i++){if(nt.a_dd[i].name==de1.dd.name){de1.y=3*(nt.pit-18)break}}}}de1.x-=8}deco_l_tb[name](x,y,de)}function tempo_note(s,dur){var p,elts=identify_note(s,dur)switch(elts[0]){case C.OVAL:p="\ueca2"breakcase C.EMPTY:p="\ueca3"breakdefault:switch(elts[2]){case 2:p="\ueca9"breakcase 1:p="\ueca7"breakdefault:p="\ueca5"break}break}if(elts[1])p+='<tspan dx=".1em">\uecb7</tspan>'return p}function tempo_build(s){var i,j,bx,p,wh,dy,w=0,str=[]if(s.tempo_str)returnif(!cfmt.musicfont.used)get_font("music")set_font("tempo")if(s.tempo_str1){str.push(s.tempo_str1)w+=strwh(s.tempo_str1)[0]}if(s.tempo_notes){dy=' dy="-1"'for(i=0;i<s.tempo_notes.length;i++){p=tempo_note(s,s.tempo_notes[i])str.push('<tspan\nclass="'+font_class(cfmt.musicfont)+'" style="font-size:'+(gene.curfont.size*1.3).toFixed(1)+'px"'+dy+'>'+p+'</tspan>')j=p.length>1?2:1w+=j*gene.curfont.swfacdy=''}str.push('<tspan dy="1">=</tspan>')w+=cwidf('=')if(s.tempo_ca){str.push(s.tempo_ca)w+=strwh(s.tempo_ca)[0]j=s.tempo_ca.length+1}if(s.tempo){str.push(s.tempo)w+=strwh(s.tempo.toString())[0]}else{p=tempo_note(s,s.new_beat)str.push('<tspan\nclass="'+font_class(cfmt.musicfont)+'" style="font-size:'+(gene.curfont.size*1.3).toFixed(1)+'px" dy="-1">'+p+'</tspan>')j=p.length>1?2:1w+=j*gene.curfont.swfacdy='y'}}if(s.tempo_str2){if(dy)str.push('<tspan\n\tdy="1">'+s.tempo_str2+'</tspan>')elsestr.push(s.tempo_str2)w+=strwh(s.tempo_str2)[0]}s.tempo_str=str.join(' ')w+=cwidf(' ')*(str.length-1)s.tempo_wh=[w,13.0]}function writempo(s,x,y){var bhset_font("tempo")if(gene.curfont.box){gene.curfont.box=falsebh=gene.curfont.size+4}output+='<text class="'+font_class(gene.curfont)+'" x="'out_sxsy(x,'" y="',y+gene.curfont.size*.22)output+='">'+s.tempo_str+'</text>\n'if(bh){gene.curfont.box=trueoutput+='<rect class="stroke" x="'out_sxsy(x-2,'" y="',y+bh-1)output+='" width="'+(s.tempo_wh[0]+4).toFixed(1)+'" height="'+bh.toFixed(1)+'"/>\n'}s.invis=true}function vskip(h){posy+=h}function svg_flush(){if(multicol||!output||!user.img_out||posy==0)returnvar i,font,head='<svg xmlns="http://www.w3.org/2000/svg" version="1.1"\n\ xmlns:xlink="http://www.w3.org/1999/xlink"\n\ fill="currentColor" stroke-width=".7"',g=''glout()font=get_font("music")head+=' class="'+font_class(font)+' tune'+tunes.length+'"\n'posy*=cfmt.scaleif(user.imagesize!=undefined)head+=user.imagesizeelsehead+=' width="'+img.width.toFixed(0)+'px" height="'+posy.toFixed(0)+'px"'head+=' viewBox="0 0 '+img.width.toFixed(0)+' '+posy.toFixed(0)+'">\n'+fulldefsif(style||font_style){head+='<style>'+font_styleif(cfmt.fgcolor||cfmt.bgcolor){head+='\n.f'+font.fid+(cfmt.fullsvg||'')+'{'+(cfmt.fgcolor?('color:'+cfmt.fgcolor+';'):'')+(cfmt.bgcolor?('background-color:'+cfmt.bgcolor):'')+'}'}head+=style+'\n</style>\n'}if(defs)head+='<defs>'+defs+'\n</defs>\n'if(cfmt.scale!=1){head+='<g class="g" transform="scale('+cfmt.scale.toFixed(2)+')">\n';g='</g>\n'}if(psvg)psvg.ps_flush(true);if(blkdiv>0){user.img_out(blkdiv==1?'<div class="nobrk">':'<div class="nobrk newpage">')blkdiv=-1}user.img_out(head+output+g+"</svg>");output=""font_style=''if(cfmt.fullsvg){defined_glyph={}for(i=0;i<abc2svg.font_tb.length;i++)abc2svg.font_tb[i].used=false}else{style='';fulldefs=''}defs='';posy=0}function blk_flush(){svg_flush()if(blkdiv<0&&(!parse.state||cfmt.splittune)){user.img_out('</div>')blkdiv=0}}Abc.prototype.blk_flush=blk_flushvar par_sy,cur_sy,voice_tb,curvoice,staves_found,vover,tsfirstfunction voice_filter(){var optfunction vfilt(opts,opt){var i,sel=new RegExp(opt)if(sel.test(curvoice.id)||sel.test(curvoice.nm)){for(i=0;i<opts.length;i++)self.do_pscom(opts[i])}}if(parse.voice_opts)for(opt in parse.voice_opts){if(parse.voice_opts.hasOwnProperty(opt))vfilt(parse.voice_opts[opt],opt)}if(parse.tune_v_opts)for(opt in parse.tune_v_opts){if(parse.tune_v_opts.hasOwnProperty(opt))vfilt(parse.tune_v_opts[opt],opt)}}function sym_link(s){var tim=curvoice.timeif(!s.fname)set_ref(s)if(!curvoice.ignore){s.prev=curvoice.last_symif(curvoice.last_sym)curvoice.last_sym.next=selsecurvoice.sym=s}curvoice.last_sym=ss.v=curvoice.v;s.p_v=curvoice;s.st=curvoice.cst;s.time=timif(s.dur&&!s.grace)curvoice.time+=s.dur;parse.ufmt=trues.fmt=cfmts.pos=curvoice.posif(curvoice.second)s.second=trueif(curvoice.floating)s.floating=trueif(curvoice.eoln){s.soln=truecurvoice.eoln=false}}function sym_add(p_voice,type){var s={type:type,dur:0},s2,p_voice2=curvoice;curvoice=p_voice;sym_link(s);curvoice=p_voice2;s2=s.previf(!s2)s2=s.nextif(s2){s.fname=s2.fname;s.istart=s2.istart;s.iend=s2.iend}return s}var w_tb=new Uint8Array([6,2,8,6,0,3,4,9,9,0,9,5,0,1,0,0,0,0])function sort_all(){var s,s2,time,w,wmin,ir,fmt,v,p_voice,prev,fl,new_sy,nv=voice_tb.length,vtb=[],vn=[],sy=cur_syfunction b_chk(){var bt,s,s2,v,t,ir=0while(1){v=vn[ir++]if(v==undefined)breaks=vtb[v]if(!s||!s.bar_type||s.invis||s.time!=time)continueif(!bt){bt=s.bar_typeif(s.text&&bt=='|')t=s.textcontinue}if(s.bar_type!=bt)breakif(s.text&&!t&&bt=='|'){t=s.textbreak}}if(!fl){while(prev.type==C.GRACE&&vtb[prev.v]&&!vtb[prev.v].bar_type){vtb[prev.v]=prevprev=prev.ts_prevfl=1}}if(v==undefined)returnif(bt=="::"||bt==":|"||t){ir=0bt=t?'|':"::"while(1){v=vn[ir++]if(v==undefined)breaks=vtb[v]if(!s||s.invis||s.bar_type!=bt||(bt=='|'&&!s.text))continues2=clone(s)if(bt=="::"){s.bar_type=":|"s2.bar_type="|:"}else{delete s.textdelete s.rbstarts2.bar_type='['s2.invis=1s2.xsh=0}s2.next=s.nextif(s2.next)s2.next.prev=s2s2.prev=ss.next=s2}}else{error(1,s,"Different bars $1 and $2",(bt+(t||'')),(s.bar_type+(s.text||'')))}}for(v=0;v<nv;v++){s=voice_tb[v].symvtb[v]=sif(sy.voices[v]){vn[sy.voices[v].range]=vif(!prev&&s){fmt=s.fmtp_voice=voice_tb[v]prev={type:C.STAVES,fname:parse.fname,dur:0,v:v,p_v:p_voice,time:0,st:0,sy:sy,next:s,fmt:fmt,seqst:true}}}}if(!prev)returnp_voice.sym=tsfirst=s=previf(s.next)s.next.prev=selsep_voice.last_sym=ss=glovar.tempoif(s){s.v=v=p_voice.vs.p_v=p_voices.st=0s.time=0s.prev=prevs.next=prev.nextif(s.next)s.next.prev=selsep_voice.last_sym=ss.prev.next=ss.fmt=fmtglovar.tempo=nullvtb[v]=s}if(nv==1){s=tsfirsts.ts_next=s.nextwhile(1){s=s.nextif(!s)returnif(s.time!=s.prev.time||w_tb[s.prev.type]||s.type==C.GRACE&&s.prev.type==C.GRACE)s.seqst=1if(s.type==C.PART){s.prev.next=s.prev.ts_next=s.nextif(s.next){s.next.part=ss.next.prev=s.previf(s.soln)s.next.soln=1if(s.seqst)s.next.seqst=1}continue}s.ts_prev=s.prevs.ts_next=s.next}}while(1){if(new_sy){sy=new_sy;new_sy=null;vn.length=0for(v=0;v<nv;v++){if(!sy.voices[v])continuevn[sy.voices[v].range]=v}}wmin=time=10000000ir=0while(1){v=vn[ir++]if(v==undefined)breaks=vtb[v]if(!s||s.time>time)continuew=w_tb[s.type]if(s.type==C.GRACE&&s.next&&s.next.type==C.GRACE)w--if(s.time<time){time=s.time;wmin=w}else if(w<wmin){wmin=w}}if(wmin>127)breakif(wmin==6)b_chk()ir=0while(1){v=vn[ir++]if(v==undefined)breaks=vtb[v]if(!s||s.time!=time)continuew=w_tb[s.type]if(!w&&s.type==C.GRACE&&s.next&&s.next.type==C.GRACE)w--if(w!=wmin)continueif(!w&&s.type==C.PART){if(s.prev)s.prev.next=s.nextvtb[v]=s.nextif(s.next){s.next.part=ss.next.prev=s.previf(s.soln)s.next.soln=1}continue}if(s.type==C.STAVES)new_sy=s.syif(fl){fl=0;s.seqst=true}s.ts_prev=prevprev.ts_next=sprev=svtb[v]=s.next}if(wmin)fl=1}}function voice_adj(sys_chg){var p_voice,s,s2,v,slfunction set_feathered_beam(s1){var s,s2,t,d,b,i,a,d=s1.dur,n=1for(s=s1;s;s=s.next){if(s.beam_end||!s.next)breakn++}if(n<=1){delete s1.feathered_beamreturn}s2=s;b=d/2;a=d/(n-1);t=s1.timeif(s1.feathered_beam>0){for(s=s1,i=n-1;s!=s2;s=s.next,i--){d=((a*i)|0)+b;s.dur=d;s.time=t;t+=d}}else{for(s=s1,i=0;s!=s2;s=s.next,i++){d=((a*i)|0)+b;s.dur=d;s.time=t;t+=d}}s.dur=s.time+s.dur-t;s.time=t}if(curvoice&&curvoice.clone){parse.istart=parse.eoldo_cloning()}if(par_sy.one_v)fill_mr_ba(voice_tb[par_sy.top_voice])for(v=0;v<voice_tb.length;v++){p_voice=voice_tb[v]if(!sys_chg){delete p_voice.eolnwhile(1){sl=p_voice.sls.shift()if(!sl)breaks=sl.ssif(!s.sls)s.sls=[]sl.loc='o's.sls.push(sl)}}for(s=p_voice.sym;s;s=s.next){if(s.time>=staves_found)break}for(;s;s=s.next){if(w_tb[s.type]<5&&s.type!=C.STAVES&&s.type!=C.CLEF&&s.time&&(!s.prev||s.time>s.prev.time+s.prev.dur)){s2={type:C.BAR,bar_type:"[]",v:s.v,p_v:s.p_v,st:s.st,time:s.time,dur:0,next:s,prev:s.prev,fmt:s.fmt,invis:1}if(s.prev)s.prev.next=s2elsevoice_tb[s.v].sym=s2s.prev=s2}switch(s.type){case C.GRACE:if(!cfmt.graceword)continuefor(s2=s.next;s2;s2=s2.next){switch(s2.type){case C.SPACE:continuecase C.NOTE:if(!s2.a_ly)breaks.a_ly=s2.a_ly;s2.a_ly=nullbreak}break}continue}if(s.feathered_beam)set_feathered_beam(s)}}}function new_syst(init){var st,v,sy_staff,p_voice,sy_new={voices:[],staves:[],top_voice:0}if(init){cur_sy=par_sy=sy_newreturn}for(v=0;v<voice_tb.length;v++){if(par_sy.voices[v]){st=par_sy.voices[v].stsy_staff=par_sy.staves[st]p_voice=voice_tb[v]sy_staff.staffnonote=p_voice.staffnonoteif(p_voice.staffscale)sy_staff.staffscale=p_voice.staffscale}}for(st=0;st<par_sy.staves.length;st++){sy_new.staves[st]=clone(par_sy.staves[st]);sy_new.staves[st].flags=0}par_sy.next=sy_new;par_sy=sy_new}Abc.prototype.set_bar_num=function(){var s,s2,rep_tim,k,n,nu,txt,tim=0,bar_num=gene.nbar,bar_tim=0,ptim=0,wmeasure=voice_tb[cur_sy.top_voice].meter.wmeasurefunction check_meas(){var s3if(tim>ptim+wmeasure&&s.prev.type!=C.MREST)return 1for(s3=s.next;s3&&s3.time==s.time;s3=s3.next);for(;s3&&!s3.bar_type;s3=s3.next);return s3&&(s3.time-bar_tim)%wmeasure}for(s=tsfirst;;s=s.ts_next){if(!s)returnswitch(s.type){case C.METER:wmeasure=s.wmeasurecase C.CLEF:case C.KEY:case C.STBRK:continuecase C.BAR:if(s.bar_num)bar_num=s.bar_numbreak}break}for(s2=s.ts_next;s2;s2=s2.ts_next){if(s2.type==C.BAR&&s2.time){if(s2.time<wmeasure){s=s2bar_tim=s.time}break}}for(;s;s=s.ts_next){switch(s.type){case C.METER:if(s.time==bar_tim)breakif(wmeasure!=1)bar_num+=(s.time-bar_tim)/wmeasurebar_tim=s.timewmeasure=s.wmeasurebreakcase C.BAR:if(s.time<=tim)breaktim=s.timenu=1txt=""for(s2=s;s2;s2=s2.next){if(s2.time>tim||s2.dur)breakif(!s2.bar_type)continueif(s2.bar_type!='[')nu=0if(s2.text)txt=s2.text}if(s.bar_num){bar_num=s.bar_numptim=bar_tim=timcontinue}if(wmeasure==1){if(s.bar_dotted)continueif(txt){if(!cfmt.contbarnb){if(txt[0]=='1')rep_tim=bar_numelsebar_num=rep_tim}}if(!nu)s.bar_num=++bar_numcontinue}n=bar_num+(tim-bar_tim)/wmeasurek=n-(n|0)if(cfmt.checkbars&&k&&check_meas())error(0,s,"Bad measure duration")if(tim>ptim+wmeasure){n|=0k=0bar_tim=timbar_num=n}if(txt){if(txt[0]=='1'){if(!cfmt.contbarnb)rep_tim=tim-bar_timif(!nu)s.bar_num=n}else{if(!cfmt.contbarnb)bar_tim=tim-rep_timn=bar_num+(tim-bar_tim)/wmeasureif(n==(n|0))s.bar_num=n}}else{n|=0s.bar_num=n}if(!k)ptim=timbreak}}}function not2abc(pit,acc){var i,nn=''if(acc&&acc!=3){if(typeof acc!="object"){nn=['__','_','','^','^^'][acc+2]}else{i=acc[0]if(i>0){nn+='^'}else{nn+='_'i=-i}nn+=i+'/'+acc[1]}}nn+=ntb[(pit+75)%7]for(i=pit;i>=23;i-=7)nn+="'"for(i=pit;i<16;i+=7)nn+=","return nn}function get_map(text){if(!text)returnvar i,note,notes,map,tmp,ns,ty='',a=text.split(/\s+/)if(a.length<3){syntax(1,not_enough_p)return}ns=a[1]if(ns[0]=='*'||ns.indexOf("all")==0){ns='all'}else{if(ns.indexOf("octave,")==0||ns.indexOf("key,")==0){ty=ns[0]ns=ns.split(',')[1]ns=ns.replace(/[,']+/,'').toUpperCase()if(ns.indexOf("key,")==0)ns=ns.replace(/[=^_]+/,'')}tmp=new scanBuftmp.buffer=nsnote=parse_acc_pit(tmp)if(!note){syntax(1,"Bad note in %%map")return}ns=ty+not2abc(note.pit,note.acc)}notes=maps[a[0]]if(!notes)maps[a[0]]=notes={}map=notes[ns]if(!map)notes[ns]=map=[]a.shift()a.shift()if(!a.length)returna=info_split(a.join(' '))i=0if(a[0].indexOf('=')<0){if(a[0][0]!='*'){tmp=new scanBuf;tmp.buffer=a[0];map[1]=parse_acc_pit(tmp)}if(!a[1])returni++if(a[1].indexOf('=')<0){map[0]=a[1].split(',')i++}}for(;i<a.length;i++){switch(a[i]){case"heads=":if(!a[++i]){syntax(1,not_enough_p)break}map[0]=a[i].split(',')breakcase"print=":case"play=":case"print_notrp=":if(!a[++i]){syntax(1,not_enough_p)break}tmp=new scanBuf;tmp.buffer=a[i];note=parse_acc_pit(tmp)if(a[i-1][5]=='_')note.notrp=1if(a[i-1][1]=='r')map[1]=noteelsemap[3]=notebreakcase"color=":if(!a[++i]){syntax(1,not_enough_p)break}map[2]=a[i]break}}}function new_ctrl(s){var a,ty=(s.type+curvoice.time).toString()if(!parse.ctrl)parse.ctrl={}a=parse.ctrl[ty]if(a){if(a&1<<curvoice.v)return 1parse.ctrl[ty]=a|1<<curvoice.vreturn}parse.ctrl[ty]=1<<curvoice.vreturn 1}function get_transp(param){if(param[0]=='0')return 0if("123456789-+".indexOf(param[0])>=0){var val=parseInt(param)if(isNaN(val)||val<-36||val>36){syntax(1,errs.bad_transp)return}val+=36val=((val/12|0)-3)*40+abc2svg.isb40[val%12]if(param.slice(-1)=='b')val+=4return val}}Abc.prototype.do_pscom=function(text){var h1,val,s,cmd,param,n,k,bcmd=text.match(/[^\s]+/)if(!cmd)returncmd=cmd[0];if(curvoice&&curvoice.ignore){switch(cmd){case"staves":case"score":breakdefault:return}}param=text.replace(cmd,'').trim()if(param.slice(-5)==' lock'){fmt_lock[cmd]=true;param=param.slice(0,-5).trim()}else if(fmt_lock[cmd]){return}switch(cmd){case"clef":if(parse.state>=2){s=new_clef(param)if(s)get_clef(s)}returncase"deco":deco_add(param)returncase"linebreak":set_linebreak(param)returncase"map":get_map(param)returncase"maxsysstaffsep":case"sysstaffsep":if(parse.state==3){val=get_unit(param)if(isNaN(val)){syntax(1,errs.bad_val,"%%"+cmd)return}par_sy.voices[curvoice.v][cmd[0]=='m'?"maxsep":"sep"]=valreturn}breakcase"multicol":switch(param){case"start":case"new":case"end":breakdefault:syntax(1,"Unknown keyword '$1' in %%multicol",param)return}s={type:C.BLOCK,subtype:"mc_"+param,dur:0}if(parse.state>=2){curvoice=voice_tb[0]curvoice.eoln=1sym_link(s)return}set_ref(s)self.block_gen(s)returncase"ottava":if(parse.state!=3)returnn=parseInt(param)if(isNaN(n)||n<-2||n>2||(!n&&!curvoice.ottava)){syntax(1,errs.bad_val,"%%ottava")return}k=nif(n){curvoice.ottava=n}else{n=curvoice.ottavacurvoice.ottava=0}a_dcn.push(["15mb","8vb","","8va","15ma"][n+2]+(k?'(':')'))returncase"repbra":if(curvoice)curvoice.norepbra=!get_bool(param)returncase"repeat":if(parse.state!=3)returnif(!curvoice.last_sym){syntax(1,"%%repeat cannot start a tune")return}if(!param.length){n=1;k=1}else{b=param.split(/\s+/);n=parseInt(b[0]);k=parseInt(b[1])if(isNaN(n)||n<1||(curvoice.last_sym.type==C.BAR&&n>2)){syntax(1,"Incorrect 1st value in %%repeat")return}if(isNaN(k)){k=1}else{if(k<1){syntax(1,"Incorrect 2nd value in %%repeat")return}}}parse.repeat_n=curvoice.last_sym.type==C.BAR?n:-n;parse.repeat_k=kreturncase"sep":var h2,len,values,lwidth;set_page();lwidth=img.width-img.lm-img.rm;h1=h2=len=0if(param){values=param.split(/\s+/);h1=get_unit(values[0])if(values[1]){h2=get_unit(values[1])if(values[2])len=get_unit(values[2])}if(isNaN(h1)||isNaN(h2)||isNaN(len)){syntax(1,errs.bad_val,"%%sep")return}}if(h1<1)h1=14if(h2<1)h2=h1if(len<1)len=90if(parse.state>=2){s=new_block(cmd);s.x=(lwidth-len)/2/cfmt.scale;s.l=len/cfmt.scale;s.sk1=h1;s.sk2=h2return}vskip(h1);output+='<path class="stroke"\n\td="M';out_sxsy((lwidth-len)/2/cfmt.scale,' ',0);output+='h'+(len/cfmt.scale).toFixed(1)+'"/>\n';vskip(h2);blk_flush()returncase"setbarnb":val=parseInt(param)if(isNaN(val)||val<1){syntax(1,"Bad %%setbarnb value")break}glovar.new_nbar=valreturncase"staff":if(parse.state!=3)returnval=parseInt(param)if(isNaN(val)){syntax(1,"Bad %%staff value '$1'",param)return}var stif(param[0]=='+'||param[0]=='-')st=curvoice.cst+valelsest=val-1if(st<0||st>nstaff){syntax(1,"Bad %%staff number $1 (cur $2, max $3)",st,curvoice.cst,nstaff)return}delete curvoice.floating;curvoice.cst=streturncase"staffbreak":if(parse.state!=3)returns={type:C.STBRK,dur:0}if(param.slice(-1)=='f'){s.stbrk_forced=trueparam=param.replace(/\sf$/,'')}if(param){val=get_unit(param)if(isNaN(val)){syntax(1,errs.bad_val,"%%staffbreak")return}s.xmx=val}else{s.xmx=14}sym_link(s)returncase"tacet":if(param[0]=='"')param=param.slice(1,-1)case"stafflines":case"staffscale":case"staffnonote":set_v_param(cmd,param)returncase"staves":case"score":if(!parse.state)returnif(parse.scores&&parse.scores.length>0){text=parse.scores.shift();cmd=text.match(/([^\s]+)\s*(.*)/);param=cmd[2]cmd=cmd[1]}get_staves(cmd,param)returncase"center":case"text":k=cmd[0]=='c'?'c':cfmt.textoptionset_font("text")if(parse.state>=2){s=new_block("text")s.text=params.opt=ks.font=cfmt.textfontreturn}write_text(param,k)returncase"transpose":if(cfmt.sound)returnval=get_transp(param)if(val==undefined){val=get_interval(param)if(val==undefined)return}switch(parse.state){case 0:cfmt.transp=0case 1:cfmt.transp=(cfmt.transp||0)+valreturn}cfmt.transp=(cfmt.transp||0)+valkey_trans()returncase"tune":returncase"user":set_user(param)returncase"voicecolor":if(curvoice)curvoice.color=paramreturncase"vskip":val=get_unit(param)if(isNaN(val)){syntax(1,errs.bad_val,"%%vskip")return}if(val<0){syntax(1,"%%vskip cannot be negative")return}if(parse.state>=2){s=new_block(cmd);s.sk=valreturn}vskip(val);returncase"newpage":case"leftmargin":case"rightmargin":case"pagescale":case"pagewidth":case"printmargin":case"scale":case"staffwidth":if(parse.state>=2){s=new_block(cmd);s.param=paramreturn}if(cmd=="newpage"){blk_flush()if(user.page_format)blkdiv=2return}break}self.set_format(cmd,param)}Abc.prototype.do_begin_end=function(type,opt,text){var i,j,action,sswitch(type){case"js":js_inject(text)breakcase"ml":if(cfmt.pageheight){syntax(1,"Cannot have %%beginml with %%pageheight")break}if(parse.state>=2){s=new_block(type);s.text=text}else{blk_flush()if(user.img_out)user.img_out(text)}breakcase"svg":j=0while(1){i=text.indexOf('<style',j)if(i<0)breaki=text.indexOf('>',i)j=text.indexOf('</style>',i)if(j<0){syntax(1,"No </style> in %%beginsvg sequence")break}style+=text.slice(i+1,j).replace(/\s+$/,'')}j=0while(1){i=text.indexOf('<defs>\n',j)if(i<0)breakj=text.indexOf('</defs>',i)if(j<0){syntax(1,"No </defs> in %%beginsvg sequence")break}defs_add(text.slice(i+6,j))}breakcase"text":action=get_textopt(opt);if(!action)action=cfmt.textoptionset_font("text")if(text.indexOf('\\')>=0)text=cnv_escape(text)if(parse.state>1){s=new_block(type);s.text=texts.opt=actions.font=cfmt.textfontbreak}write_text(text,action)break}}function generate(){var s,v,p_voice;if(a_dcn.length){syntax(1,"Decoration without symbol")a_dcn=[]}if(parse.tp){syntax(1,"No end of tuplet")s=parse.tpsif(s)delete s.tpdelete parse.tp}if(vover){syntax(1,"No end of voice overlay");get_vover(vover.bar?'|':')')}voice_adj();sort_all()if(tsfirst){for(v=0;v<voice_tb.length;v++){if(!voice_tb[v].key)voice_tb[v].key=parse.ckey}if(user.anno_start)anno_start=a_startif(user.anno_stop)anno_stop=a_stopself.set_bar_num()if(info.P)tsfirst.parts=info.Pif(user.get_abcmodel)user.get_abcmodel(tsfirst,voice_tb,abc2svg.sym_name,info)if(user.img_out)self.output_music()}set_page()if(info.W)put_words(info.W)put_history()parse.state=0blk_flush()if(tsfirst){tunes.push([tsfirst,voice_tb,info,cfmt])tsfirst=null}}function key_trans(){var i,n,a_acc,b40,s=curvoice.ckey,ti=s.time||0if(s.k_bagpipe||s.k_drum)returnn=(curvoice.score|0)+(curvoice.shift|0)+(cfmt.transp|0)if((curvoice.tr_sco|0)==n)returnif(is_voice_sig()){curvoice.key=s}else if(curvoice.time!=ti){s=clone(s.orig||s)if(!curvoice.new)s.k_old_sf=curvoice.ckey.k_sfsym_link(s)}curvoice.ckey=sif(cfmt.transp&&curvoice.shift)syntax(0,"Mix of old and new transposition syntaxes");curvoice.tr_sco=nb40=(s.k_b40+200+n)%40i=abc2svg.b40k[b40]-b40if(i){curvoice.tr_sco+=ib40+=i}s.orig=clone(s)s.k_b40=b40if(!s.k_none)s.k_sf=abc2svg.b40sf[b40]if(!s.k_a_acc)returna_acc=[]for(i=0;i<s.k_a_acc.length;i++){b40=abc2svg.pab40(s.k_a_acc[i].pit,s.k_a_acc[i].acc)+da_acc[i]={pit:abc2svg.b40p(b40),acc:abc2svg.b40a(b40)||3}}s.k_a_acc=a_acc}function fill_mr_ba(p_v){var v,p_v2,mxt=0for(v=0;v<voice_tb.length;v++){if(voice_tb[v].time>mxt){p_v2=voice_tb[v]mxt=p_v2.time}}if(p_v.time>=mxt)returnvar p_v_sav=curvoice,dur=mxt-p_v.time,s={type:C.MREST,stem:0,multi:0,nhd:0,xmx:0,frm:1,dur:dur,dur_orig:dur,nmes:dur/p_v.wmeasure,notes:[{pit:18,dur:dur}],tacet:p_v.tacet},s2={type:C.BAR,bar_type:'|',dur:0,multi:0}if(p_v2.last_sym.bar_type)s2.bar_type=p_v2.last_sym.bar_typeglovar.mrest_p=1curvoice=p_vsym_link(s)sym_link(s2)curvoice=p_v_sav}function get_staves(cmd,parm){var s,p_voice,p_voice2,i,flags,v,vid,a_vf,st,range,nv=voice_tb.length,maxtime=0if(parm){a_vf=parse_staves(parm)if(!a_vf)return}else if(staves_found<0){syntax(1,errs.bad_val,'%%'+cmd)return}for(v=0;v<nv;v++){p_voice=voice_tb[v]if(p_voice.time>maxtime)maxtime=p_voice.time}if(!maxtime){par_sy.staves=[]par_sy.voices=[]}else{voice_adj(true)for(v=0;v<par_sy.voices.length;v++){if(par_sy.voices[v]){curvoice=voice_tb[v]break}}curvoice.time=maxtime;s={type:C.STAVES,dur:0}sym_link(s);par_sy.nstaff=nstaff;if(!parm){s.sy=clone(par_sy,1)par_sy.next=s.sypar_sy=s.systaves_found=maxtimefor(v=0;v<nv;v++)voice_tb[v].time=maxtimecurvoice=voice_tb[par_sy.top_voice]return}new_syst();s.sy=par_sy}staves_found=maxtimefor(v=0;v<nv;v++){p_voice=voice_tb[v]delete p_voice.seconddelete p_voice.floatingif(p_voice.ignore){p_voice.ignore=0s=p_voice.symif(s){while(s.next)s=s.next}p_voice.last_sym=s}}range=0for(i=0;i<a_vf.length;i++){vid=a_vf[i][0];p_voice=new_voice(vid);p_voice.time=maxtime;v=p_voice.va_vf[i][0]=p_voice;while(1){par_sy.voices[v]={range:range++}p_voice=p_voice.voice_downif(!p_voice)breakv=p_voice.v}}par_sy.top_voice=a_vf[0][0].vif(a_vf.length==1)par_sy.one_v=1if(cmd[1]=='t'){for(i=0;i<a_vf.length;i++){flags=a_vf[i][1]if(!(flags&(OPEN_BRACE|OPEN_BRACE2)))continueif((flags&(OPEN_BRACE|CLOSE_BRACE))==(OPEN_BRACE|CLOSE_BRACE)||(flags&(OPEN_BRACE2|CLOSE_BRACE2))==(OPEN_BRACE2|CLOSE_BRACE2))continueif(a_vf[i+1][1]!=0)continueif((flags&OPEN_PARENTH)||(a_vf[i+2][1]&OPEN_PARENTH))continueif(a_vf[i+2][1]&(CLOSE_BRACE|CLOSE_BRACE2)){a_vf[i+1][1]|=FL_VOICE}else if(a_vf[i+2][1]==0&&(a_vf[i+3][1]&(CLOSE_BRACE|CLOSE_BRACE2))){a_vf[i][1]|=OPEN_PARENTH;a_vf[i+1][1]|=CLOSE_PARENTH;a_vf[i+2][1]|=OPEN_PARENTH;a_vf[i+3][1]|=CLOSE_PARENTH}}}st=-1for(i=0;i<a_vf.length;i++){flags=a_vf[i][1]if((flags&(OPEN_PARENTH|CLOSE_PARENTH))==(OPEN_PARENTH|CLOSE_PARENTH)){flags&=~(OPEN_PARENTH|CLOSE_PARENTH);a_vf[i][1]=flags}p_voice=a_vf[i][0]if(flags&FL_VOICE){p_voice.floating=true;p_voice.second=true}else{st++;if(!par_sy.staves[st]){par_sy.staves[st]={stafflines:p_voice.stafflines||"|||||",staffscale:1}}par_sy.staves[st].flags=0}v=p_voice.v;p_voice.st=p_voice.cst=par_sy.voices[v].st=st;par_sy.staves[st].flags|=flagsif(flags&OPEN_PARENTH){p_voice2=p_voicewhile(i<a_vf.length-1){p_voice=a_vf[++i][0];v=p_voice.vif(a_vf[i][1]&MASTER_VOICE){p_voice2.second=truep_voice2=p_voice}else{p_voice.second=true}p_voice.st=p_voice.cst=par_sy.voices[v].st=stif(a_vf[i][1]&CLOSE_PARENTH)break}par_sy.staves[st].flags|=a_vf[i][1]}}if(st<0)st=0par_sy.nstaff=nstaff=stif(cmd[1]=='c'){for(st=0;st<nstaff;st++)par_sy.staves[st].flags^=STOP_BAR}nv=voice_tb.lengthst=0for(v=0;v<nv;v++){p_voice=voice_tb[v]if(par_sy.voices[v])st=p_voice.stelsep_voice.st=stif(!maxtime){for(s=p_voice.sym;s;s=s.next)s.st=st}if(!par_sy.voices[v])continuep_voice2=p_voice.voice_downwhile(p_voice2){i=p_voice2.vp_voice2.st=p_voice2.cst=par_sy.voices[i].st=stp_voice2=p_voice2.voice_down}par_sy.voices[v].second=p_voice.second;st=p_voice.stif(st>0&&p_voice.norepbra==undefined&&!(par_sy.staves[st-1].flags&STOP_BAR))p_voice.norepbra=true}curvoice=parse.state>=2?voice_tb[par_sy.top_voice]:null}function clone_voice(id){var v,p_voicefor(v=0;v<voice_tb.length;v++){p_voice=voice_tb[v]if(p_voice.id==id)return p_voice}p_voice=clone(curvoice);p_voice.v=voice_tb.length;p_voice.id=id;p_voice.sym=p_voice.last_sym=null;p_voice.key=clone(curvoice.key)p_voice.sls=[]delete p_voice.nmdelete p_voice.snmdelete p_voice.new_namedelete p_voice.lyric_restartdelete p_voice.lyric_contdelete p_voice.sym_restartdelete p_voice.sym_contdelete p_voice.have_lydelete p_voice.tie_svoice_tb.push(p_voice)return p_voice}function get_vover(type){var p_voice2,p_voice3,range,s,time,v,v2,v3,s2if(type=='|'||type==')'){if(!curvoice.last_note){syntax(1,errs.nonote_vo)if(vover){curvoice=vover.p_voicevover=null}return}curvoice.last_note.beam_end=trueif(!vover){syntax(1,"Erroneous end of voice overlay")return}if(curvoice.time!=vover.p_voice.time){if(!curvoice.ignore)syntax(1,"Wrong duration in voice overlay");if(curvoice.time>vover.p_voice.time)vover.p_voice.time=curvoice.time}curvoice.acc=[]p_voice2=vover.p_voices=curvoice.last_symif(s.type==C.SPACE&&p_voice2.last_sym.type!=C.SPACE){s.p_v=p_voice2s.v=s.p_v.vwhile(s.prev.type==C.SPACE){s=s.prevs.p_v=p_voice2s.v=s.p_v.v}s2=s.prevs2.next=nulls.prev=p_voice2.last_syms.prev.next=sp_voice2.last_sym=curvoice.last_symcurvoice.last_sym=s2}curvoice=p_voice2vover=nullreturn}if(type=='('){if(vover){syntax(1,"Voice overlay already started")return}vover={p_voice:curvoice,time:curvoice.time}return}if(!curvoice.last_note){syntax(1,errs.nonote_vo)return}curvoice.last_note.beam_end=true;p_voice2=curvoice.voice_downif(!p_voice2){p_voice2=clone_voice(curvoice.id+'o');curvoice.voice_down=p_voice2;p_voice2.time=0;p_voice2.second=true;p_voice2.last_note=nullv2=p_voice2.v;if(par_sy.voices[curvoice.v]){par_sy.voices[v2]={st:curvoice.st,second:true}range=par_sy.voices[curvoice.v].rangefor(v=0;v<par_sy.voices.length;v++){if(par_sy.voices[v]&&par_sy.voices[v].range>range)par_sy.voices[v].range++}par_sy.voices[v2].range=range+1}}p_voice2.ulen=curvoice.ulenp_voice2.dur_fact=curvoice.dur_factp_voice2.acc=[]if(!vover){time=p_voice2.timeif(curvoice.ignore)s=nullelsefor(s=curvoice.last_sym;;s=s.prev){if(s.type==C.BAR||s.time<=time)break}vover={bar:(s&&s.bar_type)?s.bar_type:'|',p_voice:curvoice,time:s?s.time:curvoice.time}}else{if(curvoice!=vover.p_voice&&curvoice.time!=vover.p_voice.time){syntax(1,"Wrong duration in voice overlay")if(curvoice.time>vover.p_voice.time)vover.p_voice.time=curvoice.time}}p_voice2.time=vover.time;curvoice=p_voice2}function is_voice_sig(){var sif(curvoice.time)return falseif(!curvoice.last_sym)return truefor(s=curvoice.last_sym;s;s=s.prev)if(w_tb[s.type])return falsereturn true}function get_clef(s){var s2,s3if(s.clef_type=='p'){s2=curvoice.ckeys2.k_drum=1s2.k_sf=0s2.k_b40=2s2.k_map=abc2svg.keys[7]if(!curvoice.key)curvoice.key=s2}if(!curvoice.time&&is_voice_sig()){curvoice.clef=ss.fmt=cfmtreturn}for(s2=curvoice.last_sym;s2&&s2.time==curvoice.time;s2=s2.prev){if(w_tb[s2.type])break}if(s2&&s2.time==curvoice.time&&s2.k_sf!=undefined){s3=s2s2=s2.prev}if(s2&&s2.time==curvoice.time&&s2.bar_type&&s2.bar_type[0]!=':')s3=s2if(s3){s2=curvoice.last_symcurvoice.last_sym=s3.prevsym_link(s)s.next=s3s3.prev=scurvoice.last_sym=s2if(s.soln){delete s.solncurvoice.eoln=true}}else{sym_link(s)}if(s.prev)s.clef_small=1}function get_key(parm){var v,p_voice,transp,sndtran,nt,a=new_key(parm),s_key=a[0],s=s_key,empty=s.k_sf==undefined&&!s.k_a_acca=a[1]if(empty)s.invis=1if(parse.state==1){parse.ckey=sif(empty){s_key.k_sf=0;s_key.k_none=trues_key.k_map=abc2svg.keys[7]}for(v=0;v<voice_tb.length;v++){p_voice=voice_tb[v];p_voice.ckey=clone(s_key)}if(a.length){memo_kv_parm('*',a)a=[]}if(!glovar.ulen)glovar.ulen=C.BLEN/8;goto_tune()}else if(!empty){s.k_old_sf=curvoice.ckey.k_sfcurvoice.ckey=ssym_link(s)if(curvoice.tr_sco)curvoice.tr_sco=0}if(!curvoice){if(!voice_tb.length){curvoice=new_voice("1")var def=1}else{curvoice=voice_tb[staves_found<0?0:par_sy.top_voice]}}p_voice=curvoice.cloneif(p_voice)curvoice.clone=nullget_voice(curvoice.id+' '+a.join(' '))if(p_voice)curvoice.clone=p_voiceif(def)curvoice.default=1}function new_voice(id){var v,p_v_sav,p_voice=voice_tb[0],n=voice_tb.lengthif(n==1&&p_voice.default){delete p_voice.defaultif(!p_voice.time){p_voice.id=idreturn p_voice}}for(v=0;v<n;v++){p_voice=voice_tb[v]if(p_voice.id==id)return p_voice}p_voice={v:v,id:id,time:0,new:true,pos:{},scale:1,ulen:glovar.ulen,dur_fact:1,meter:clone(glovar.meter),wmeasure:glovar.meter.wmeasure,staffnonote:1,clef:{type:C.CLEF,clef_auto:true,clef_type:"a",time:0},acc:[],sls:[],hy_st:0}voice_tb.push(p_voice);if(parse.state==3){p_voice.ckey=clone(parse.ckey)if(p_voice.ckey.k_bagpipe&&!p_voice.pos.stm){p_voice.pos=clone(p_voice.pos)p_voice.pos.stm&=~0x07p_voice.pos.stm|=C.SL_BELOW}}return p_voice}function init_tune(){nstaff=-1;voice_tb=[];curvoice=null;new_syst(true);staves_found=-1;gene={}a_de=[]cross={}}function do_cloning(){var i,clone=curvoice.clone,vs=clone.vs,a=clone.a,bol=clone.bol,eol=parse.eol,parse_sav=parse,file=parse.filedelete curvoice.cloneif(file[eol-1]=='[')eol--include++;for(i=0;i<vs.length;i++){parse=Object.create(parse_sav)parse.line=Object.create(parse_sav.line)get_voice(vs[i]+' '+a.join(' '))tosvg(parse.fname,file,bol,eol)}include--parse=parse_sav}function get_voice(parm){var v,vs,a=info_split(parm),vid=a.shift()if(!vid)returnif(curvoice&&curvoice.clone)do_cloning()if(vid.indexOf(',')>0)vs=vid.split(',')elsevs=[vid]if(parse.state<2){while(1){vid=vs.shift()if(!vid)breakif(a.length)memo_kv_parm(vid,a)if(vid!='*'&&parse.state==1)curvoice=new_voice(vid)}return}if(vid=='*'){syntax(1,"Cannot have V:* in tune body")return}curvoice=new_voice(vs[0])if(vs.length>1){vs.shift()curvoice.clone={vs:vs,a:a,bol:parse.iend}if(parse.file[curvoice.clone.bol-1]!=']')curvoice.clone.bol++}set_kv_parm(a)key_trans()v=curvoice.vif(curvoice.new){delete curvoice.newif(staves_found<0){curvoice.st=curvoice.cst=++nstaff;par_sy.nstaff=nstaff;par_sy.voices[v]={st:nstaff,range:v}par_sy.staves[nstaff]={stafflines:curvoice.stafflines||"|||||",staffscale:1}}else if(!par_sy.voices[v]){curvoice.ignore=1return}}if(!curvoice.filtered&&par_sy.voices[v]&&(parse.voice_opts||parse.tune_v_opts)){curvoice.filtered=true;voice_filter()}}function goto_tune(){var v,p_voiceset_page();write_heading();if(glovar.new_nbar){gene.nbar=glovar.new_nbarglovar.new_nbar=0}else{gene.nbar=1}parse.state=3for(v=0;v<voice_tb.length;v++){p_voice=voice_tb[v];p_voice.ulen=glovar.ulenif(parse.ckey.k_bagpipe&&!p_voice.pos.stm){p_voice.pos=clone(p_voice.pos)p_voice.pos.stm&=~0x07p_voice.pos.stm|=C.SL_BELOW}}if(staves_found<0){v=voice_tb.lengthpar_sy.nstaff=nstaff=v-1while(--v>=0){p_voice=voice_tb[v];delete p_voice.new;p_voice.st=p_voice.cst=v;par_sy.voices[v]={st:v,range:v}par_sy.staves[v]={stafflines:p_voice.stafflines||"|||||",staffscale:1}}}}function get_sym(p,cont){var s,c,i,j,dif(curvoice.ignore)returnif(cont){s=curvoice.sym_contif(!s){syntax(1,"+: symbol line without music")return}}else{if(curvoice.sym_restart){curvoice.sym_start=curvoice.sym_restart;curvoice.sym_restart=null}s=curvoice.sym_startif(!s)s=curvoice.symif(!s){syntax(1,"s: without music")return}}i=0while(1){while(p[i]==' '||p[i]=='\t')i++;c=p[i]if(!c)breakswitch(c){case'|':while(s&&s.type!=C.BAR)s=s.nextif(!s){syntax(1,"Not enough measure bars for symbol line")return}s=s.next;i++continuecase'!':case'"':j=++ii=p.indexOf(c,j)if(i<0){syntax(1,c=='!'?"No end of decoration":"No end of chord symbol/annotation");i=p.lengthcontinue}d=p.slice(j-1,i+1)breakcase'*':breakdefault:d=c.charCodeAt(0)if(d<128){d=char_tb[d]if(d.length>1&&(d[0]=='!'||d[0]=='"')){c=d[0]break}}syntax(1,errs.bad_char,c)break}while(s&&s.type!=C.NOTE)s=s.nextif(!s){syntax(1,"Too many elements in symbol line")return}switch(c){default:breakcase'!':a_dcn.push(d.slice(1,-1))deco_cnv(s,s.prev)breakcase'"':parse_gchord(d)if(a_gch)csan_add(s)break}s=s.next;i++}curvoice.sym_cont=s}function get_lyrics(text,cont){var s,word,p,i,j,ly,dfnt,ln,c,cfif(curvoice.ignore)returnif((curvoice.pos.voc&0x07)!=C.SL_HIDDEN)curvoice.have_ly=trueif(cont){s=curvoice.lyric_contif(!s){syntax(1,"+: lyric without music")return}dfnt=get_font("vocal")if(gene.deffont!=dfnt){if(gene.curfont==gene.deffont)gene.curfont=dfntgene.deffont=dfnt}}else{set_font("vocal")if(curvoice.lyric_restart){curvoice.lyric_start=s=curvoice.lyric_restart;curvoice.lyric_restart=null;curvoice.lyric_line=0}else{curvoice.lyric_line++;s=curvoice.lyric_start}if(!s)s=curvoice.symif(!s){syntax(1,"w: without music")return}}p=text;i=0cf=gene.curfontwhile(1){while(p[i]==' '||p[i]=='\t')i++if(!p[i])breakln=0j=parse.istart+i+2switch(p[i]){case'|':while(s&&s.type!=C.BAR)s=s.nextif(!s){syntax(1,"Not enough measure bars for lyric line")return}s=s.next;i++continuecase'-':case'_':word=p[i]ln=p[i]=='-'?2:3breakcase'*':word=""breakdefault:word="";while(1){if(!p[i])breakswitch(p[i]){case'_':case'*':case'|':i--case' ':case'\t':breakcase'~':word+=' 'i++continuecase'-':ln=1breakcase'\\':if(!p[++i])continueword+=p[i++]continuecase'$':word+=p[i++]c=p[i]if(c=='0')gene.curfont=gene.deffontelse if(c>='1'&&c<='9')gene.curfont=get_font("u"+c)default:word+=p[i++]continue}break}break}while(s&&s.type!=C.NOTE)s=s.nextif(!s){syntax(1,"Too many words in lyric line")return}if(word&&(s.pos.voc&0x07)!=C.SL_HIDDEN){ly={t:word,font:cf,istart:j,iend:j+word.length}if(ln)ly.ln=lnif(!s.a_ly)s.a_ly=[]s.a_ly[curvoice.lyric_line]=lycf=gene.curfont}s=s.next;i++}curvoice.lyric_cont=s}function ly_set(s){var i,j,ly,d,s1,s2,p,w,spw,xx,sz,shift,dw,s3=s,wx=0,wl=0,n=0,dx=0,a_ly=s.a_ly,align=0for(s2=s.ts_next;s2;s2=s2.ts_next){if(s2.shrink){dx+=s2.shrinkn++}if(s2.bar_type){dx+=3break}if(!s2.a_ly)continuei=s2.a_ly.lengthwhile(--i>=0){ly=s2.a_ly[i]if(!ly)continueif(!ly.ln||ly.ln<2)break}if(i>=0)break}for(i=0;i<a_ly.length;i++){ly=a_ly[i]if(!ly)continuegene.curfont=ly.fontly.t=p=str2svg(ly.t)if(ly.ln>=2){ly.shift=0continue}spw=cwid(' ')*ly.font.swfacw=p.wh[0]+spw*1.5if(s.type==C.GRACE){shift=s.wl}else if((p[0]>='0'&&p[0]<='9'&&p.length>2)||p[1]==':'||p[0]=='('||p[0]==')'){if(p[0]=='('){sz=spw}else{j=p.indexOf(' ')set_font(ly.font)if(j>0)sz=strwh(p.slice(0,j))[0]elsesz=w*.2}shift=(w-sz)*.4if(shift>14)shift=14shift+=szif(p[0]>='0'&&p[0]<='9'){if(shift>align)align=shift}}else{shift=w*.4if(shift>14)shift=14}ly.shift=shiftif(shift>wl)wl=shiftw-=shiftif(w>wx)wx=w}while(!s3.seqst)s3=s3.ts_previf(s3.ts_prev&&s3.ts_prev.bar_type)wl-=4if(s3.wl<wl){s3.shrink+=wl-s3.wls3.wl=wl}dx-=6if(dx<wx){dx=(wx-dx)/ns1=s.ts_nextwhile(1){if(s1.shrink){s1.shrink+=dxs3.wr+=dxs3=s1}if(s1==s2)breaks1=s1.ts_next}}if(align>0){for(i=0;i<a_ly.length;i++){ly=a_ly[i]if(ly&&ly.t[0]>='0'&&ly.t[0]<='9')ly.shift=align}}}function draw_lyric_line(p_voice,j,y){var p,lastx,w,s,s2,ly,lyl,ln,hyflag,lflag,x0,shiftif(p_voice.hy_st&(1<<j)){hyflag=true;p_voice.hy_st&=~(1<<j)}for(s=p_voice.sym;;s=s.next)if(s.type!=C.CLEF&&s.type!=C.KEY&&s.type!=C.METER)breaklastx=s.prev?s.prev.x:tsfirst.x;x0=0for(;s;s=s.next){if(s.a_ly)ly=s.a_ly[j]elsely=nullif(!ly){switch(s.type){case C.REST:case C.MREST:if(lflag){out_wln(lastx+3,y,x0-lastx);lflag=false;lastx=s.x+s.wr}}continue}if(ly.font!=gene.curfont)gene.curfont=ly.fontp=ly.t;ln=ly.ln||0w=p.wh[0]shift=ly.shiftif(hyflag){if(ln==3){ln=2}else if(ln<2){out_hyph(lastx,y,s.x-shift-lastx);hyflag=false;lastx=s.x+s.wr}}if(lflag&&ln!=3){out_wln(lastx+3,y,x0-lastx+3);lflag=false;lastx=s.x+s.wr}if(ln>=2){if(x0==0&&lastx>s.x-18)lastx=s.x-18if(ln==2)hyflag=trueelselflag=true;x0=s.x-shiftcontinue}x0=s.x-shift;if(ln)hyflag=trueif(user.anno_start||user.anno_stop){s2={p_v:s.p_v,st:s.st,istart:ly.istart,iend:ly.iend,ts_prev:s,ts_next:s.ts_next,x:x0,y:y,ymn:y,ymx:y+gene.curfont.size,wl:0,wr:w}anno_start(s2,'lyrics')}xy_str(x0,y,p)anno_stop(s2,'lyrics')lastx=x0+w}if(hyflag){hyflag=false;x0=realwidth-10if(x0<lastx+10)x0=lastx+10;out_hyph(lastx,y,x0-lastx)if(p_voice.s_next&&p_voice.s_next.fmt.hyphencont)p_voice.hy_st|=(1<<j)}for(p_voice.s_next;s;s=s.next){if(s.type==C.NOTE){if(!s.a_ly)breakly=s.a_ly[j]if(ly&&ly.ln==3){lflag=true;x0=realwidth-15if(x0<lastx+12)x0=lastx+12}break}}if(lflag){out_wln(lastx+3,y,x0-lastx+3);lflag=false}}function draw_lyrics(p_voice,nly,a_h,y,incr){var j,top,sc=staff_tb[p_voice.st].staffscale;set_font("vocal")if(incr>0){if(y>-tsfirst.fmt.vocalspace)y=-tsfirst.fmt.vocalspace;y*=scfor(j=0;j<nly;j++){y-=a_h[j]*1.1;draw_lyric_line(p_voice,j,y+a_h[j]*.22)}return y/sc}top=staff_tb[p_voice.st].topbar+tsfirst.fmt.vocalspaceif(y<top)y=top;y*=scfor(j=nly;--j>=0;){draw_lyric_line(p_voice,j,y+a_h[j]*.22)y+=a_h[j]*1.1}return y/sc}function draw_all_lyrics(){var p_voice,s,v,nly,i,x,y,w,a_ly,ly,lyst_tb=new Array(nstaff+1),nv=voice_tb.length,h_tb=new Array(nv),nly_tb=new Array(nv),above_tb=new Array(nv),rv_tb=new Array(nv),top=0,bot=0,st=-1for(v=0;v<nv;v++){p_voice=voice_tb[v]if(!p_voice.sym)continueif(p_voice.st!=st){top=0;bot=0;st=p_voice.st}nly=0if(p_voice.have_ly){if(!h_tb[v])h_tb[v]=[]for(s=p_voice.sym;s;s=s.next){a_ly=s.a_lyif(!a_ly)continuex=s.x;w=10for(i=0;i<a_ly.length;i++){ly=a_ly[i]if(ly){x-=ly.shift;w=ly.t.wh[0]break}}y=y_get(p_voice.st,1,x,w)if(top<y)top=y;y=y_get(p_voice.st,0,x,w)if(bot>y)bot=ywhile(nly<a_ly.length)h_tb[v][nly++]=0for(i=0;i<a_ly.length;i++){ly=a_ly[i]if(!ly)continueif(!h_tb[v][i]||ly.t.wh[1]>h_tb[v][i])h_tb[v][i]=ly.t.wh[1]}}}else{y=y_get(p_voice.st,1,0,realwidth)if(top<y)top=y;y=y_get(p_voice.st,0,0,realwidth)if(bot>y)bot=y}if(!lyst_tb[st])lyst_tb[st]={}lyst_tb[st].top=top;lyst_tb[st].bot=bot;nly_tb[v]=nlyif(nly==0)continueif(p_voice.pos.voc)above_tb[v]=(p_voice.pos.voc&0x07)==C.SL_ABOVEelse if(voice_tb[v+1]&&voice_tb[v+1].st==st&&voice_tb[v+1].have_ly)above_tb[v]=trueelseabove_tb[v]=falseif(above_tb[v])lyst_tb[st].a=trueelselyst_tb[st].b=true}i=0for(v=0;v<nv;v++){p_voice=voice_tb[v]if(!p_voice.sym)continueif(!p_voice.have_ly)continueif(above_tb[v]){rv_tb[i++]=vcontinue}st=p_voice.st;set_dscale(st,true)if(nly_tb[v]>0)lyst_tb[st].bot=draw_lyrics(p_voice,nly_tb[v],h_tb[v],lyst_tb[st].bot,1)}while(--i>=0){v=rv_tb[i];p_voice=voice_tb[v];st=p_voice.st;set_dscale(st,true);lyst_tb[st].top=draw_lyrics(p_voice,nly_tb[v],h_tb[v],lyst_tb[st].top,-1)}for(v=0;v<nv;v++){p_voice=voice_tb[v]if(!p_voice.sym)continuest=p_voice.st;if(lyst_tb[st].a){top=lyst_tb[st].top+2for(s=p_voice.sym;s;s=s.next){if(s.a_ly){y_set(st,1,s.x-2,10,top)}}}if(lyst_tb[st].b){bot=lyst_tb[st].bot-2if(nly_tb[p_voice.v]>0){for(s=p_voice.sym;s;s=s.next){if(s.a_ly){y_set(st,0,s.x-2,10,bot)}}}else{y_set(st,0,0,realwidth,bot)}}}}function parse_gchord(type){var c,text,gch,x_abs,y_abs,i,j,istart,iend,ann_font=get_font("annotation"),h_ann=ann_font.size,line=parse.linefunction get_float(){var txt=''while(1){c=text[i++]if("1234567890.-".indexOf(c)<0)return parseFloat(txt)txt+=c}}istart=parse.bol+line.indexif(type.length>1){text=type.slice(1,-1);iend=istart+1}else{i=++line.indexwhile(1){j=line.buffer.indexOf('"',i)if(j<0){syntax(1,"No end of chord symbol/annotation")return}if(line.buffer[j-1]!='\\'||line.buffer[j-2]=='\\')breaki=j+1}text=cnv_escape(line.buffer.slice(line.index,j))line.index=jiend=parse.bol+line.index+1}if(ann_font.pad)h_ann+=ann_font.padi=0;type='g'while(1){c=text[i]if(!c)breakgch={text:"",istart:istart,iend:iend,font:ann_font}switch(c){case'@':type=c;i++;x_abs=get_float()if(c!=','){syntax(1,"',' lacking in annotation '@x,y'");y_abs=0}else{y_abs=get_float()if(c!=' ')i--}gch.x=x_abs;gch.y=y_absbreakcase'^':gch.pos=C.SL_ABOVEcase'_':if(c=='_')gch.pos=C.SL_BELOWcase'<':case'>':i++;type=cbreakdefault:switch(type){case'g':gch.font=get_font("gchord")gch.pos=curvoice.pos.gch||C.SL_ABOVEbreakcase'^':gch.pos=C.SL_ABOVEbreakcase'_':gch.pos=C.SL_BELOWbreakcase'@':gch.x=x_abs;y_abs-=h_ann;gch.y=y_absbreak}break}gch.type=typewhile(1){c=text[i]if(!c)breakswitch(c){case'\\':c=text[++i]if(c=='n')breakgch.text+='\\'if(!c)breakdefault:gch.text+=c;i++continuecase'&':while(1){gch.text+=c;c=text[++i]switch(c){default:continuecase';':case undefined:case'\\':break}break}if(c==';'){i++;gch.text+=ccontinue}breakcase';':break}i++break}gch.otext=gch.textif(!a_gch)a_gch=[]a_gch.push(gch)}}var note_names="CDEFGAB",acc_name=["bb","b","","#","##"]function gch_tr1(p,tr){var i,o,n,a,ip,b40,csa=p.split('/')for(i=0;i<csa.length;i++){p=csa[i];o=p.search(/[A-G]/)if(o<0)continueip=o+1a=0while(p[ip]=='#'||p[ip]=='\u266f'){a++;ip++}while(p[ip]=='b'||p[ip]=='\u266d'){a--;ip++}n=note_names.indexOf(p[o])+16b40=(abc2svg.pab40(n,a)+tr+200)%40b40=abc2svg.b40k[b40]csa[i]=p.slice(0,o)+note_names[abc2svg.b40_p[b40]]+acc_name[abc2svg.b40_a[b40]+2]+p.slice(ip)}return csa.join('/')}function csan_add(s){var i,gchif(s.type==C.BAR){for(i=0;i<a_gch.length;i++){if(a_gch[i].type=='g'){error(1,s,"There cannot be chord symbols on measure bars")a_gch.splice(i)}}}if(curvoice.tr_sco){for(i=0;i<a_gch.length;i++){gch=a_gch[i]if(gch.type=='g')gch.text=gch_tr1(gch.text,curvoice.tr_sco)}}if(s.a_gch)s.a_gch=s.a_gch.concat(a_gch)elses.a_gch=a_gcha_gch=null}Abc.prototype.gch_build=function(s){var gch,wh,xspc,ix,y_left=0,y_right=0,GCHPRE=.4;for(ix=0;ix<s.a_gch.length;ix++){gch=s.a_gch[ix]if(gch.type=='g'){gch.text=gch.text.replace(/##|#|=|bb|b/g,function(x){switch(x){case'##':return"𝄪"case'#':return"\u266f"case'=':return"\u266e"case'b':return"\u266d"}return"𝄫"})}else{if(gch.type=='@'&&!user.anno_start&&!user.anno_stop){set_font(gch.font)gch.text=str2svg(gch.text)continue}}set_font(gch.font);gch.text=str2svg(gch.text)wh=gch.text.whswitch(gch.type){case'@':breakdefault:xspc=wh[0]*GCHPREif(xspc>8)xspc=8;gch.x=-xspc;breakcase'<':gch.x=-(wh[0]+6);y_left-=wh[1];gch.y=y_left+wh[1]/2breakcase'>':gch.x=6;y_right-=wh[1];gch.y=y_right+wh[1]/2break}}y_left/=2;y_right/=2for(ix=0;ix<s.a_gch.length;ix++){gch=s.a_gch[ix]switch(gch.type){case'<':gch.y-=y_leftbreakcase'>':gch.y-=y_rightbreak}}}Abc.prototype.draw_gchord=function(i,s,x,y){if(s.invis&&s.play)returnvar y2,an=s.a_gch[i],h=an.text.wh[1],pad=an.font.pad,w=an.text.wh[0]+pad*2,dy=h*.22if(an.font.figb){h*=2.4dy+=an.font.size*1.3}switch(an.type){case'_':y-=h+padbreakcase'^':y+=padbreakcase'<':case'>':if(an.type=='<'){if(s.notes[0].acc)x-=s.notes[0].shacx-=pad}else{if(s.xmx)x+=s.xmxif(s.dots)x+=1.5+3.5*s.dotsx+=pad}y+=(s.type==C.NOTE?(((s.notes[s.nhd].pit+s.notes[0].pit)>>1)-18)*3:12)-h/2breakdefault:if(y>=0)y+=padelsey-=h+padbreakcase'@':y+=(s.type==C.NOTE?(((s.notes[s.nhd].pit+s.notes[0].pit)>>1)-18)*3:12)-h/2if(y>0){y2=y+h+pad+2if(y2>staff_tb[s.st].ann_top)staff_tb[s.st].ann_top=y2}else{y2=y-2if(y2<staff_tb[s.st].ann_bot)staff_tb[s.st].ann_bot=y2}break}if(an.type!='@'){if(y>=0)y_set(s.st,1,x,w,y+h+pad+2)elsey_set(s.st,0,x,w,y-pad)}use_font(an.font)set_font(an.font)set_dscale(s.st)if(user.anno_start)user.anno_start("annot",an.istart,an.iend,x-2,y+h+2,w+4,h+4,s)xy_str(x,y+dy,an.text)if(user.anno_stop)user.anno_stop("annot",an.istart,an.iend,x-2,y+h+2,w+4,h+4,s)}function draw_all_chsy(){var s,san1,an,i,x,y,w,n_an=0,minmax=new Array(nstaff+1)function set_an_yu(j){var an,i,s,x,y,wfor(s=san1;s;s=s.ts_next){an=s.a_gchif(!an)continuei=an.length-j-1an=an[i]if(!an)continueif(an.pos==C.SL_ABOVE){x=s.x+an.xw=an.text.wh[0]if(w&&x+w>realwidth)x=realwidth-wy=y_get(s.st,1,x,w)+2if(an.type=='g'&&y<minmax[s.st].yup)y=minmax[s.st].yup}else if(an.pos==C.SL_BELOW||an.pos==C.SL_HIDDEN){continue}else{x=s.x+an.xy=an.y}self.draw_gchord(i,s,x,y)}}function set_an_yl(i){var an,x,y,wfor(var s=san1;s;s=s.ts_next){an=s.a_gchif(!an)continuean=an[i]if(!an||an.pos!=C.SL_BELOW)continuex=s.x+an.xw=an.text.wh[0]if(w&&x+w>realwidth)x=realwidth-wy=y_get(s.st,0,x,w)-2if(an.type=='g'&&y>minmax[s.st].ydn)y=minmax[s.st].ydnself.draw_gchord(i,s,x,y)}}for(i=0;i<=nstaff;i++)minmax[i]={ydn:staff_tb[i].botbar-3,yup:staff_tb[i].topbar+4}for(s=tsfirst;s;s=s.ts_next){an=s.a_gchif(!an)continueif(!san1)san1=si=an.lengthif(i>n_an)n_an=iwhile(--i>=0){if(an[i].type=='g'){an=an[i]x=s.x+an.xw=an.text.wh[0]if(w&&x+w>realwidth)x=realwidth-wif(an.pos==C.SL_ABOVE){y=y_get(s.st,true,x,w)+2if(y>minmax[s.st].yup)minmax[s.st].yup=y}else if(an.pos==C.SL_BELOW){y=y_get(s.st,false,x,w)-2if(y<minmax[s.st].ydn)minmax[s.st].ydn=y}break}}}if(!san1)returnset_dscale(-1)for(i=0;i<n_an;i++){set_an_yu(i)set_an_yl(i)}}init_tune()Abc.prototype.a_de=function(){return a_de}Abc.prototype.add_style=function(s){style+=s};Abc.prototype.cfmt=function(){return cfmt};Abc.prototype.clone=clone;Abc.prototype.deco_put=function(nm,s){a_dcn.push(nm)deco_cnv(s)}Abc.prototype.defs_add=defs_addAbc.prototype.dh_put=function(nm,s,nt){a_dcn.push(nm)dh_cnv(s,nt)}Abc.prototype.draw_meter=draw_meterAbc.prototype.draw_note=draw_note;Abc.prototype.errs=errs;Abc.prototype.font_class=font_class;Abc.prototype.gch_tr1=gch_tr1;Abc.prototype.get_bool=get_bool;Abc.prototype.get_cur_sy=function(){return cur_sy};Abc.prototype.get_curvoice=function(){return curvoice};Abc.prototype.get_delta_tb=function(){return delta_tb};Abc.prototype.get_decos=function(){return decos};Abc.prototype.get_font=get_font;Abc.prototype.get_font_style=function(){return font_style};Abc.prototype.get_glyphs=function(){return glyphs};Abc.prototype.get_img=function(){return img};Abc.prototype.get_maps=function(){return maps};Abc.prototype.get_multi=function(){return multicol};Abc.prototype.get_newpage=function(){if(block.newpage){block.newpage=false;return true}};Abc.prototype.get_posy=function(){return posy}Abc.prototype.get_staff_tb=function(){return staff_tb};Abc.prototype.get_top_v=function(){return par_sy.top_voice};Abc.prototype.get_tsfirst=function(){return tsfirst};Abc.prototype.get_unit=get_unit;Abc.prototype.get_voice_tb=function(){return voice_tb};Abc.prototype.glout=gloutAbc.prototype.info=function(){return info};Abc.prototype.new_block=new_block;Abc.prototype.out_arp=out_arp;Abc.prototype.out_deco_str=out_deco_str;Abc.prototype.out_deco_val=out_deco_val;Abc.prototype.out_ltr=out_ltr;Abc.prototype.param_set_font=param_set_font;Abc.prototype.parse=parse;Abc.prototype.psdeco=empty_function;Abc.prototype.psxygl=empty_function;Abc.prototype.set_cur_sy=function(sy){cur_sy=sy};Abc.prototype.set_dscale=set_dscale;Abc.prototype.set_font=set_font;Abc.prototype.set_a_gch=function(s,a){a_gch=a;csan_add(s)}Abc.prototype.set_hl=set_hlAbc.prototype.set_page=set_pageAbc.prototype.set_pagef=function(){blkdiv=1}Abc.prototype.set_realwidth=function(v){realwidth=v}Abc.prototype.set_scale=set_scale;Abc.prototype.set_sscale=set_sscaleAbc.prototype.set_tsfirst=function(s){tsfirst=s};Abc.prototype.set_v_param=set_v_param;Abc.prototype.strwh=strwh;Abc.prototype.stv_g=function(){return stv_g};Abc.prototype.svg_flush=svg_flush;Abc.prototype.syntax=syntax;Abc.prototype.tunes=tunesAbc.prototype.unlksym=unlksym;Abc.prototype.use_font=use_font;Abc.prototype.vskip=vskipAbc.prototype.xy_str=xy_str;Abc.prototype.xygl=xygl}var Abc=abc2svg.Abcif(typeof module=='object'&&typeof exports=='object'){exports.abc2svg=abc2svg;exports.Abc=Abc}if(!abc2svg.loadjs){abc2svg.loadjs=function(fn,onsuccess,onerror){if(onerror)onerror(fn)}}abc2svg.modules={ambitus:{},begingrid:{fn:'grid3'},beginps:{fn:'psvg'},break:{},capo:{},chordnames:{},clip:{},clairnote:{fn:'clair'},voicecombine:{fn:'combine'},diagram:{fn:'diag'},equalbars:{},gamelan:{},grid:{},grid2:{},jazzchord:{},jianpu:{},mdnn:{},MIDI:{},nns:{},pageheight:{fn:'page'},pedline:{},percmap:{fn:'perc'},roman:{},soloffs:{},sth:{},strtab:{},temperament:{fn:'temper'},tropt:{},nreq:0,load:function(file,relay,errmsg){function get_errmsg(){if(typeof user=='object'&&user.errmsg)return user.errmsgif(typeof abc2svg.printErr=='function')return abc2svg.printErrif(typeof alert=='function')return function(m){alert(m)}if(typeof console=='object')return console.logreturn function(){}}function load_end(){if(--abc2svg.modules.nreq==0)abc2svg.modules.cbf()}var m,i,fn,nreq_i=this.nreq,ls=file.match(/(^|\n)(%%|I:).+?\b/g)if(!ls)return truethis.cbf=relay||function(){}this.errmsg=errmsg||get_errmsg()for(i=0;i<ls.length;i++){fn=ls[i].replace(/\n?(%%|I:)/,'')m=abc2svg.modules[fn]if(!m||m.loaded)continuem.loaded=trueif(m.fn)fn=m.fnthis.nreq++abc2svg.loadjs(fn+"-1.js",load_end,function(){abc2svg.modules.errmsg('Error loading the module '+fn)load_end()})}return this.nreq==nreq_i}}abc2svg.version="v1.22.9-23-02f440d127";abc2svg.vdate="2023-08-30"
 |