:: Core markdown parser, exposed as ++parse !: :::: :: =+ =~ |% ++ loca |*(a=_,* ,[p=@u q=a]) ++ stack (list (loca tops)) -- |% ++ htm-enty :: XX belongs in zuse ~+ =- |= tub=nail ^- (like ,@t) %. tub :: export context =+(poxa enty(ent mapping)) ^- mapping=(map span ,@tF) =+ pax=/==1%%/html5-entities/json :: XX %%/ =+ maf=%.(pax ;~(biff file (soft ,@) poja (om so):jo)) ?^ maf u.maf ~& no-enty/pax (mo amp/'&' quot/'"' apos/'\'' lt/'<' gt/'>' ~) :: fallback :: ++ skem-symb (star ;~(pose dot alp)) ++ skem-set ~+ ^- (set cord) :: URI schemes :: (sa `wain`/http/https/javascript) =- (sa `wain`(rash - (more gah (cook crip skem-symb)))) ''' coap doi javascript aaa aaas about acap cap cid crid data dav dict dns file ftp geo go gopher h323 http https iax icap im imap info ipp iris iris.beep iris.xpc iris.xpcs iris.lwz ldap mailto mid msrp msrps mtqp mupdate news nfs ni nih nntp opaquelocktoken pop pres rtsp service session shttp sieve sip sips sms snmp soap.beep soap.beeps tag tel telnet tftp thismessage tn3270 tip tv urn vemmi ws wss xcon xcon-userid xmlrpc.beep xmlrpc.beeps xmpp z39.50r z39.50s adiumxtra afp afs aim apt attachment aw beshare bitcoin bolo callto chrome chrome-extension content cvs com-eventbrite-attendee dlna-playsingle dlna-playcontainer dtn dvb ed2k facetime feed finger fish gg git gizmoproject gtalk hcp icon ipn irc irc6 ircs itms jar jms keyparc lastfm ldaps magnet maps market message mms ms-help msnim mumble mvn notes oid palm paparazzi platform proxy psyc query res resource rmi rsync rtmp secondlife sftp sgn skype smb soldat spotify ssh steam svn teamspeak things udp unreal ut2004 ventrilo view-source webcal wtai wyciwyg xfire xri ymsgr ''' :: ++ uri-skem (sear (flit |=(a=tape (~(has in skem-set) (cass a)))) skem-symb) -- :: :::: :: !: |% ++ nal (just `@`10) ++ end (full (easy ~)) ++ eol ;~(pose (cold ~ nal) end) ::++ match |=(a=rege (curr scan (ra a))) :: ++ tab |= tub=nail ^- (like cord) ?. ?=([%9 *] q.tub) (fail tub) =+ sto=+((~(inv fe 1) (dec q.p.tub))) :: virt spaces produced =+ neu=(weld (reap sto ' ') t.q.tub) (next tub(q neu)) :: ++ whif |*(a=_rule ;~(sfix a (star ace))) ++ ahed |*(a=_rule ;~(simu a (easy ~))) ++ opts |*(a=_rule ;~((bend) (easy ~) a)) ++ lots |*([a=@u b=_rule] ;~(pfix (stun [a a] b) (star b))) ++ leas |*(a=_rule ;~(pfix ;~(less (stun 4^4 ace) (stun 0^3 ace)) a)) ++ pech |* a=_[rule rule] |= tub=nail ^- (like (each ,_(wonk (-.a)) ,_(wonk (+.a)))) %. tub ;~(pose (stag %& -.a) (stag %| +.a)) :: ++ lite :: literal matched |* a=_rule |= tub=nail ^- (like tape) =+ vex=(a tub) ?~ q.vex vex =+ tap=q.q.u.q.vex =- vex(p.u.q -) |- ^+ "" ?: =(tap q.tub) ~ ?~ q.tub !! [i.q.tub $(q.tub t.q.tub)] :: ++ enrule :: XX |* a=$+(tape *) |= tub=nail ^- (like a) [[0 0] ~ (a q.tub) [0 0] ~] :: ++ vary :: XX types :: |= a=tape :: ?~ a !! :: XX cast to _(b) :: |* b=_|=(_rule rule) :: ?~ t.a (b (just i.a)) :: ;~(pose (b (just i.a)) $(a t.a)) :: -- == =~ :: :::: :: !: |% :: ++ into-inner |= [a=marl b=manx] ?~ c.b b(c a) $(b i.c.b) :: ++ flat |= a=marl ^- tape ?~ a ~ %- weld :_ $(a t.a) ^- tape ?~ n.g.i.a ?>(?=(_:/(**) i.a) v.i.a.g.i.a) ?+ n.g.i.a $(a c.i.a) %img %- zing ^- wall %+ murn a.g.i.a |= [a=mane b=tape] ^- (unit tape) ?+ a ~ %alt [~ b] == == :: ++ sang :: tight item children |= a=down ^- marl ?~ a ~ %- weld :_ $(a t.a) ?. ?=(%para -.i.a) (sing i.a ~) (sung p.i.a) :: ++ sing :: elem to manx => |% ++ first-word |= a=tape =. a (trip (crip a)) :: XX valid tapes ^- (unit tape) =. a q.q:(need q:((star ace) [1 1] a)) =+ vex=((plus ;~(less ace prn)) [1 1] a) ?~ q.vex ~ (some (wonk vex)) -- =+ [tig=| had=*(unit mane)] |= lum=down |^ ^- marl =+ a=apex ?~ q.a p.a (weld p.a $(lum q.a)) :: ++ apex ^- [p=marl q=_lum] ?~ lum ?~ had [~ ~] (lose "unclosed {}") => [ele=i.lum .(lum t.lum)] ?. ?=(%html -.ele) (push (reso ele) ~) =+ tex=(trip (role p.ele)) =^ mar tex [p q.q]:(need q:(many:poxa 1^1 tex)) ?^ mar (push mar) =^ hed lum (chomp tex head:poxa) ?^ hed =+ max=`marx`u.hed (push(lum q) [max p] ~):[apex(had `n.max) .] =^ tal lum (chomp tex tail:poxa) ?~ tal (push ;lost:"{tex}" ~) ?: =(had tal) [~ lum] ?^ had =. lum [ele lum] (lose "unclosed {}") (lose "close {}") :: ++ lose |=(a=tape [[;lost:"{a}"]~ lum]) ++ chomp |* [tap=tape fel=_rule] ^- [(unit ,_(wonk *fel)) _lum] =+ vex=(fel 1^1 tap) ?~ q.vex [~ lum] :- [~ (wonk vex)] ?~(q.q.u.q.vex lum [[%html (crip q.q.u.q.vex) ~] lum]) :: ++ push |= a=marl ^+ apex ?~ a apex [[b p] q]:[b=i.a (push t.a)] :: ++ reso |= a=elem ?^ -.a =. tig ?.(?=(%list -.p.a) tig p.p.a) ?: &(tig ?=(%item -.p.a)) [/li (sang q.a)] %+ into-inner ^$(lum q.a) ?- -.p.a %bloq ;blockquote; %item ;li; %list ?@ q.p.a ;ul; ?: =(1 p.q.p.a) ;ol; =+ num=(pojo (jone p.q.p.a)) ;ol(start num); == ?- -.a :: :/("unimplemented {}") %html !! :: handled earlier XX do type stuff %para [/p (sung p.a)] %head [/(add %h0 (lsh 3 1 p.a)) (sung q.a)] %hrul ;hr; :: %html ::=+ tex=(role (turn p.a crip)) ::=+ (poxa tex) ::?^ - u.- ::=+ (rush tex (star ;~(pose gah comt:poxa))) ::?^ - :/(~) ::;lost: {} :: :/([(role (turn p.a crip))]~) :: XX haaaaaaack %defn :/(~) %code =+ lan=?~(p.a ~ (first-word r.u.p.a)) =+ tex=(trip (role q.a)) ?~ lan ;pre:code:"{tex}" ;pre:code(class "language-{u.lan}"):"{tex}" == -- :: ++ sung |= lim=kids =+ had=*(unit mane) |^ ^- marl =+ a=apex ?~ q.a p.a (weld p.a $(lim q.a)) :: ++ apex ^- [p=marl q=_lim] ?~ lim ?~ had [~ ~] (lose "unclosed {}") => [ele=i.lim .(lim t.lim)] ?. ?=(%htmt -.ele) (push (reso ele) ~) =+ tex=(trip p.ele) =^ emo lim (chomp tex empt:poxa) ?^ emo =+ man=`manx`u.emo (push man ~) =^ hed lim (chomp tex head:poxa) ?^ hed =+ max=`marx`u.hed (push(lim q) [max p] ~):[apex(had `n.max) .] =^ tal lim (chomp tex tail:poxa) ?~ tal (push ;lost:"{tex}" ~) ?: =(had tal) [~ lim] ?^ had =. lim [ele lim] (lose "unclosed {}") (lose "close {}") :: ++ lose |=(a=tape [[;lost:"{a}"]~ lim]) ++ chomp |* [tap=tape fel=_rule] ^- [(unit ,_(wonk *fel)) _lim] =+ vex=(fel 1^1 tap) ?~ q.vex [~ lim] :- [~ (wonk vex)] ?~(q.q.u.q.vex lim [[%htmt (crip q.q.u.q.vex)] lim]) :: ++ push |= a=marl ^+ apex ?~ a apex [[b p] q]:[b=i.a (push t.a)] :: ++ reso |= b=inline ^- manx ?@ -.b ?- -.b %$ =.(p.b (trip (crip p.b)) :/(p.b)) :: XX valid tapes %line ;br; %code ;code:"{p.b}" %htmt !! ::p.b :: handled earlier :: XX do type stuff == ?: ?=(%blot -.p.b) =+ res=`manx`;img(src p.p.b, alt (flat (turn q.b ..$))); :: ;img@"{p.p.b}"; ?~ q.p.b res res(a.g (welp a.g.res title/u.q.p.b ~)) ?: ?=([[%emph ?] [[%emph ?] *] ~] b) [/strong (sung q.i.q.b)] %+ into-inner (sung q.b) ?- p.b [%emph ?] ?.(p.p.b ;em; ;strong;) [%delt ~] ;del; [%link ^] ?~ q.p.b ;a/"{p.p.b}"; ;a/"{p.p.b}"(title u.q.p.b); == -- -- :: :::: :: |% ++ strip |= [a=$+(nail edge) b=tape] ^- tape =+ q:(a 1^1 b) ?~(- b q.q.u.-) :: ++ inli :: inline parsers =+ [bug=| rec="" nol=|] |_ ref=(map cord ,[p=tape q=(unit tape)]) ++ unesc |= a=tape (scan a (star ;~(pose nore(rec ~) nal))) :: XX :: ++ esc ;~ pfix bas (mask "!\"#$%&'()*+,-./:;<=>?@[\\]^_`\{|}~") == ++ spec (mask rec) ++ norc ~+ ;~(pose esc ;~(less spec prn)) ++ nore ~+ ;~(pose htm-enty norc) :: ++ trim-sp |= a=tape ^- tape %+ strip (star gah) (flop (strip (star gah) (flop a))) :: ++ child =< |= tub=nail ^- (like inline) %. tub :: expose parsers %+ cook |=(a=inline ~?(bug a a)) ;~(pose code line link blot:link htmt) |% ++ fens |= a=tape %+ knee *tape |. ~+ |= tub=nail ^- (like tape) =+ vex=((plus tec) tub) ?~ q.vex (plug (codc tub) ^^$) ?: =(a p.u.q.vex) vex(p.u.q ~) =+ neu=|=(b=tape (weld `tape`p.u.q.vex b)) ((cook neu ^^$) q.u.q.vex) :: ++ codc ;~(pose (cold ' ' (plus gah)) prn) ++ code =- ;~(pose - (stag %$ (plus tec))) %+ stag %code %+ cook trim-sp |= tub=nail ?. ?=([%'`' ^] q.tub) (fail tub) =+ vex=((plus tec) tub) (pfix vex (fens (wonk vex))) :: ++ madn |= a=mane ^- ? => |=(b=span ?=(^ (rush b ;~(plug alf (star aln))))) ?@ a (. a) &((. -.a) (. +.a)) :: ++ htmt %+ stag %htmt =- (cook crip (lite -)) :: XX %- sear :_ ;~(pose empt:poxa (pech [head tail]:poxa)) %- flit |= a=$&([marx ~] $%([%& marx] [%| p=mane])) ?- -.a ^ (madn n.a) & (madn n.a) | (madn p.a) == :: ++ line %+ cold [%line ~] ;~(plug ;~(pose (lots 2 ace) bas) nal) :: ++ empty |= a=inline ^- ? ?& ?=(%$ -.a) ?=(~ (strip (star ;~(pose ace nal)) p.a)) == :: ++ link ::=+(blot=fail |=(nail (fail +<))) =< =- |=(tub=nail (pra tub)) :: expose parsers ?: nol pra=auto ::;~(pose auto pexp) =- pra=;~(pose auto (cook - apex)) |=([a=kids b=[tape (unit tape)]] [[%link b] a]) |% ++ apex =+ ^- rob=$+(nail (like ,[kids $|(cord [tape (unit tape)])])) ;~(plug text(nol &) labe) :: |= tub=nail ^- (like (pair kids ,[tape (unit tape)])) :: (fail tub) =+ vex=(rob tub) ?~ q.vex vex =- ?~(rez vex(q ~) vex(+.p.u.q u.rez)) ^- rez=(unit ,[tape (unit tape)]) =+ [~ atr]=(wonk vex) ?^ atr `atr ?. ?=(~ atr) (~(get by ref) atr) =+ vux=(text:href tub) ?~ q.vux ~ (~(get by ref) (wonk vux)) :: ++ text =. rec ['[' ']' rec] (ifix sel^ser many) :: ++ titl (opts ;~(pfix (plus gah) titl:href)) ++ labe =+ wra=[;~(plug pel .) ;~(plug . per)]:(star gah) ;~ pose (ifix wra ;~(plug dest:href titl)) ;~(pfix (star gah) text:href) (easy '') == :: ++ blot %- cook :_ ;~(pfix zap [.(rob ;~(plug text labe))]:apex) |=([a=kids b=[tape (unit tape)]] [[%blot b] a]) :: ++ mail %+ cook |=(_[a="" b='' c="" d=*wall] :(welp a b^c (zing d))) ;~ plug (plus ;~(less (mask "\"\\ (),:;<>@[]") prn)) pat (plus alp) (star ;~(plug dot (plus alp))) == :: ++ auto %+ ifix gal^gar ;~ pose (cook |=(a=tape [link/["mailto:{a}" ~] ~[`a]]) mail) :: =+ cha=;~(pose htm-enty ;~(less (mask "<> ") prn)) %+ cook |= a=_["" ""] [link/[(weld a) ~] ~[`(weld a)]] ;~(plug uri-skem col (star cha)) == :: ++ pexp :: XX non-link nested %- cook :_ (ifix sel^ser many) |=(a=kids (reso:many "[" (welp a `"]" ~))) -- -- :: ++ href =< |= tub=nail %. tub :: expose parsers ;~ plug ;~(sfix text col (star gah)) (sear (flit |=(tape ?=(^ +<))) dest) ;~(sfix (opts ;~(pfix (plus gah) titl)) (star ace) eol) == |% ++ dest ;~ pose (ifix gal^gar (star ;~(pose esc nore(rec "<>")))) (pexp nore(rec " ")) == ++ pexp |* cha=_rule =+ chu=;~(less pel per cha) |- :: XX Chesterton fence %+ knee *tape |. ~+ ;~ pose ;~(plug chu ^$) ;~(plug pel (cook welp ;~(plug (star chu) per ^$))) (easy ~) == ++ text =- (ifix sel^ser (cook cass (star -))) ;~ pose (cook |=(a=char (cat 3 '\\' a)) esc) (cold ' ' (plus gah)) ;~(less sel ser prn) == ++ titl %. ~[soq^soq doq^doq pel^per] |* a=(pole ,_[rule rule]) ?~ a fail ;~ pose (ifix -.a (star ;~(pose esc htm-enty ;~(less ->.a prn)))) $(a +.a) == -- ++ consol |= a=kids ^- kids ?~ a ~ ?+ -.i.a [i.a $(a t.a)] %$ ?~ t.a a ?: ?=(_-.i.a -.i.t.a) $(a t.a(p.i (weld p.i.a p.i.t.a))) [i.a $(a t.a)] == ++ pars :: XX => |% ++ nufh ,[tape kids] ++ fens ?(%'*' %'_') ++ nuft ,[nufh ?(tape [tape ?(%| fens)])] ++ reso |= a=nufh ^- kids ?~ -.a +.a [[%$ -.a] +.a] :: ++ veld |= [a=$|(char inline) _[b c]=*nuft] ^- nuft :_ c ?@ a [[a -.b] +.b] ?~ -.a [(weld p.a -.b) +.b] [~ a (reso b)] :: ++ rend |= nuf=nufh %. (reso nuf) |= a=kids ^- tape ?~ a ~ %- weld :_ $(a t.a) ?@ -.i.a ?+ -.i.a ~ p.i.a == =+ [p q]=i.a ?+ -.p "[{(trip -.p)}]<{$(a q)}>" %emph "({$(a q)})" == -- |= tap=tape ^- kids =. tap (trim-sp tap) =+ vex=(many 1^1 tap) ?~ q.vex ~ =+ [a ~ b]=u.q.vex ?~(b a (welp a [`b]~)) :: ++ many => pars :: XX |= tub=nail ^- (like kids) =- [[0 0] ~ (reso -<) [0 0] ;;(tape ->)] :: XX =+ [ins=`?(fens ~)`~ bof=| noz=|] ?~ q.tub [`~ ~] =+ [p=*char [i t]=[i t]:q.tub] :: prev current next =< ?<(&(?=([* @] +) !?=(~ +>)) .) :: XX do type stuff |^ ^- nuft ?: ?=(?(%'*' %'_') i) dlim =+ elm=(;~(pose child ;~(pfix (star ace) nal) nore) [1 1] i t) ?~ q.elm done(t [i t]) :: XX next? =+ [a ~ b]=u.q.elm ~? bug [a b] (push(t b) a) :: ++ next (push i) ++ push :: continue with head |= a=$|(char inline) ^- nuft ~? ?@(a | bug) fon/a ?~ t (veld a done) =: noz & i i ::?+(i i fens p) == (veld a ^$(+< [i t])) :: ++ done [[~ ~] ?~(ins t [t %|])] :: ++ pull :: consume chunk ^- nuft ?> ?=(fens i) :: XX do type stuff =: bof ?~(ins | |(bof !=(ins i))) ins i noz | == ?~ t (veld i done) $(+<+ t) :: ++ flome |= a=_+:*nuft ^- [(unit ?(%| fens)) tape] ?. ?=([* ?(%| fens)] a) [~ a] [[~ +.a] -.a] :: ++ empa |= a=nufh ^- inline [[%emph |] (reso a)] :: ++ ends |= [a=tape b=tape] ?: &(?=(^ b) =(i i.b)) $(b t.b) ?: &(?=(^ a) =(i i.a)) $(a t.a) ?> ?=(fens i) :: XX do type stuff ?& |(?=(~ b) !=(' ' i.b)) |(=('*' i) [?=(~ q)]:(aln 1^1 a)) == :: ++ dlim ^- nuft ~? bug [&3 &2] =+ clo=&(noz !=(~ ins) (ends t p ~)) :: can close delim ?: &(clo =(ins i)) :: correct close [`~ t] ?: &(bof !=(ins i)) :: outer close ?> ?=(fens i) :: XX do type stuff [`~ t i] ?~ t (veld i done) ?. (ends [p]~ t) next =+ [a tak]=pull => .(t `_""`t) :: XX do type stuff =^ b t (flome tak) ?~ b (push (empa a)) ~? > bug clot/[a i t] ?: =(i u.b) (push (empa a)) ?~ ins :: outermost [a(- [i -.a]) t] ::(veld i a t) [a(- [i -.a]) t u.b] ::(veld i a t u.b) -- :: -- -- :: :::: :: !: |% ++ nesting $% [%bloq *] :: Used for fishing [%item *] [%list [%item ~]] == ++ accepting ?(%para %code) ++ list-nest :: can add list item? =+ sam=[?>(?=(%list -.p..) p..)]:(tops [%list ~]~) :: XX do type stuff |= [a=_sam b=_sam] ^- ? .= ?@(q.a q.a q.q.a) :: by checking delimiter characters ?@(q.b q.b q.q.b) :: =- =((cha p.a) (cha p.b)) :: ^= cha :: |= a=_sam :: ?@(q.a q.a q.q.a) :: ++ closes-code =+ sam=[?>(?=(%code -) p..)]:(node [%code ~]) :: XX do type stuff |= [a=_sam b=_sam] ?~ a ?=(~ b) ?~ b | ?^ r.u.b | ?& =(p.u.a p.u.b) (gte q.u.b q.u.a) == :: ++ blank |= a=tape ^- ? ?~ a & &(=(' ' i.a) $(a t.a)) :: ++ dehax :: strip trailing hax =+ nobas=;~(sfix (plus hax) ;~(pose ace end)) |= a=tape %- flop :(strip nobas (star ace) (flop a)) :: ++ scab |* [a=tape b=_rule] (wonk (b [1 1] a)) :: ++ donp |% ++ blok :~ %article %aside %blockquote %body %button %canvas %caption %col %colgroup %dd %div %dl %dt %embed %fieldset %figcaption %figure %footer %footer %form %h1 %h2 %h3 %h4 %h5 %h6 %header %hgroup %hr %iframe %li %map %object %ol %output %p %pre %progress %script %section %style %table %tbody %td %textarea %tfoot %th %thead %tr %ul %video == ++ htm-head =+ blu=(flit ~(has in (sa `wain`blok))) =+ blo=(sear blu (cook cass (star aln))) %+ stag %html ;~ plug gal ;~ pose ;~(plug blo ;~(pose fas gar gah)) ;~(plug fas blo ;~(pose gar gah)) (mask "?!") == == ++ leaf (leas ;~(pose head hrul fcode)) :: any node ++ head %+ cook |=(a=tape [%head (lent a) ~]) ;~(sfix (stun 1^6 hax) ;~(pose ace (ahed eol))) ++ hrul %+ cold [%hrul ~] %. ~[tar hep cab] :: (vary "*-_") |* a=(pole ,_rule) ?~ a fail ;~(pose ;~(plug (lots 3 (whif -.a)) (ahed eol)) $(a +.a)) :: ++ limar :: list marker %+ stag %list %- leas %+ stag & =- ;~(sfix - ;~(pose (ahed eol) ;~(sfix ace ;~(pose (leas) (easy))))) ;~ pose (mask "*+-") ;~(plug dem (mask ".)")) == :: ++ line ;~(sfix (star prn) eol) :: ++ blomar %+ cold [%bloq ~] %- leas ;~ pose ;~(plug gar ace) gar == ++ setext %- leas ;~(sfix ;~(pose (cold 2 (plus hep)) (cold 1 (plus tis))) (star ace)) ++ icode (cold `node`[%code ~ ~] (stun 4^4 ace)) ++ fcode %. ~['`' '~'] :: (vary "`~") |* a=(pole char) ?~ a fail =- ;~(pose fel $(a +.a)) ^= fel %- cook :_ ;~ plug (lots 3 (just -.a)) (star ;~(less tec prn)) (ahed eol) == |= [b=(list) c=tape ~] ^+ [?>(?=(%code -) .)]:*node :: XX do type stuff [%code `[-.a (add 3 (lent b)) c] ~] -- :: ++ normalize |= a=down ^- down %+ turn a |= b=elem ?^ -.b b(q (turn q.b ..$)) =- ?+(-.b b %para b(p (- p.b)), %head b(q (- q.b))) |= c=kids ^- kids ?~ c ~ ?: ?& ?=(^ t.c) ?=(%$ -.i.c) ?=(%$ -.i.t.c) == $(c t.c(p.i (weld p.i.c p.i.t.c))) :_ $(c t.c) ?@ -.i.c i.c =* d q.i.c ?~ d i.c ?. ?& ?=([* ~] d) ?=([%emph %|] -.i.c) ?=([%emph %|] -.i.d) == i.c(q $(c d)) [[%emph %&] $(c q.i.d)] :: ++ test |=(a=cord =-([- (sing -)] (rash a parseb))) ++ parseb =>(parse .(bug &)) ++ parse =+ [bug=| bugi=|] |= tub=nail =. q.tub %+ scan q.tub :: tab hackery :: XX per line (star ;~(pose prn tab nal)) =| $: $: top=down :: finished toplevel elements [sap=@u nod=node] :: spacing, currrent leaf block cur=stack :: stack of nested current blocks == [bun=_| hat=_|] :: prev blank? halt? ref=(map cord ,[p=tape q=(unit tape)]) :: link references == |^ ^- (like ,_top) ?. hat $:eat-line ?^ cur $:pop => cull =- [p.tub `[- tub]] (flop (turn top (proc-inline [-(bug bugi)]:[~(pars inli ref) .]))) :: ++ self . :: ++ halt .(hat &) :: ++ debu [&2 &2.-]:&2 :: ++ proc-inline :: parse inline kids |= pac=_pars:inli :: cache |= a=elem ?^ -.a a(q (flop (turn q.a ..$))) ?+ -.a a %code ?~ p.a a a(r.u.p (unesc:inli r.u.p.a)) %para ?> ?=([[%$ *] ~] p.a) :: XX do type stuff a(p (pac p.i.p.a)) %head ?~ q.a a ?> ?=([[%$ *] ~] q.a) :: XX do type stuff a(q (pac p.i.q.a)) == :: ++ snack :: advance by parser |* a=_rule ^- [(unit ,_(wonk (a))) nail] =+ vex=(a tub) ?~ q.vex [~ tub] [`p q]:u.q.vex :: ++ snake :: advance with trace |* fel=_rule =- (snack (here - fel)) |*([[[@ a=@u] [@ b=@u]] c=*] [p=(sub b a) q=c]) :: :: ++ pop :: resolve container ^+ self => cull ?~ cur self =- => .(cur t.cur, q.p.tub p.i.cur) ?~ cur self(top [hed top]) self(q.q.i.cur [hed q.q.i.cur]) ^- hed=tops =+ cub=q.i.cur ?+ -.p.cub cub %list %_ cub p.p p.p.cub :: XX set this upon parsing blank-headed block == == :: ++ bye :: resolution arms |% ++ leaf :: resolve node ^+ self =^ nol nod [nod [%defn ~]] ?: ?=(%defn -.nol) self ~? > bug clod/[nol tub] ?~ cur self(top [nol top]) self(q.q.i.cur [nol q.q.i.cur]) :: ++ pop-til :: unwind stack |= a=stack ^+ self ?~ cur self ?: =(a cur) self $(self pop) :: ++ top-list =+ laz=cur |- ?~ cur laz =. laz ?:(?=(%list -.p.q.i.cur) cur laz) $(cur t.cur) :: ++ top-bloq =+ laz=cur |- ?~ cur laz =. laz ?:(?=(%bloq -.p.q.i.cur) cur laz) $(cur t.cur) -- :: ++ cull :: resolve node block =< leaf:bye ^+ self =. sap 0 ?+ -.nod self %html self(p.nod (flop p.nod)) %code =< self(q.nod (flop q.nod)) |- ?^ p.nod . ?~ q.nod . ?: (blank (trip i.q.nod)) $(q.nod t.q.nod) . %para ?~ p.nod self(nod [%defn ~]) =+ olt=tub =. q.tub =- (trip (role -)) %+ turn ;;((list ,[%$ p=tape]) (flop p.nod)) :: XX do type stuff |=([@ a=tape] (crip a)) |- ^+ self =^ ren tub (snack (leas href):inli) ?^ ren ?: (~(has by ref) -.u.ren) $ $(ref (~(put by ref) u.ren)) =. q.tub (strip (star gah) q.tub) ?~ q.tub self(nod [%defn ~], tub olt) self(nod [%para [%$ q.tub]~], tub olt) == :: ++ push :: open block |= nit=(loca ,_p:*tops) ^+ +> =. self cull =+ toz=[q.nit ~] ?. ?=([%list ^] q.nit) (shove p.nit toz) =. self (shove p.nit toz) (shove p.nit [%item ~]~) :: ++ shove |= a=(loca tops) ^+ +> ?~ cur +>(cur [a cur]) :: =* cub q.i.cur ?. ?=(nesting [-.p.q.i.cur -.q.a]) $(+> pop) +>(cur [a cur]) :: ++ pump :: push leaf block |= a=$&([p=node q=@u] node) ^+ +> =+ nex=cull ?@ -.a nex(nod a) nex(nod p.a, sap q.a) :: ++ match :: check top element |= a=elem ^- ? ?~ cur | =(-.a -.q.i.cur) :: :: ++ collapse :: skim elems off top |= a=(list (pair ,@ tops)) ^+ +> ?~ a +> :: ?: ?=([[@ *] ~] a) +> ~? bug yank/[i.a blos] ?> (match q.i.a) :: ~& [%no-match a cur] :: !! $(a t.a, +> pop) :: ++ offset ^- @u ?~ cur 0 ?: ?=(%bloq -.p.q.i.cur) p.i.cur offset(cur t.cur) :: ++ delist (pop-til top-list):bye ++ debloq |= ruc=_(flop cur) ^+ self ?~ ruc self ?. ?=(%bloq -.p.q.i.ruc) $(ruc t.ruc) (collapse (flop ruc)) :: ++ nil-li ?& ?=(%defn -.nod) ?=(^ cur) ?=([[%item ~] ~] q.i.cur) == ++ widen ^+ cur :: list loosening =< ?~ cur ~ ?. ?=(%item -.p.q.i.cur) (. cur) [i.cur (. t.cur)] |= a=_cur ^+ a ~? > bug naro/[debu nil-li a cur] ?~ a a ?: ?=([[%item ~] ~] q.i.a) a ?. ?=(%list -.p.q.i.a) [i.a $(a t.a)] a(p.p.q.i |) :: ++ blos :: extract elem list (flop (turn cur |*([@ a=tops] a))) :: ++ eat-line :: high-level line nom ^+ . ~? >> bug line/curlin :: => [bup=bun sepa:eat] :: ?: bun:+ + :: blank line nommed :: =< .(bun |) :: =. bun bup ~? bug line-stat/[debu cur] ?: ?=(%html -.nod) =+ sep=(sepa:eat) ?: bun.sep sep span:eat.+ => [ruc .]=olds:eat ?: &(?=(~ ruc) ?=([%code ^ *] nod)) code:eat =+ sep=(sepa:eat ruc) ?: bun.sep ~? bug nilli/[debu nil-li nod cur]:sep =. bun.sep ?^(ruc & ?^(cur | !nil-li:sep)) :: XX Chesterton fence sep =< .(bun |) =~ [ruc=ruc sep(bun bun)] (lazy:eat ruc) news:eat node:eat span:eat :: ~? bug seated/[nod blos] . == :: ++ curlin (scab q.tub (star prn)) ++ eat |% ++ sepa :: consume blank line |= ruc=_(flop cur) ^+ self ?: ?=([%code ^ *] nod) :: ignore in blocks self =^ buf tub (snack ;~(sfix (star ace) nal)) ?~ buf self(bun |) ~? bug seat/cur =. self ?: bun delist =. bun & (debloq ruc) ?+ -.nod self %para cull %html cull %code =- self(q.nod -) ?~ q.nod q.nod [(crip (slag 4 u.buf)) q.nod] == :: ++ horz :: horizontal rule ^+ self =^ neu tub (snack (leas hrul:donp)) ?~ neu self (pump u.neu) :: ++ olds :: previous nest levels =+ [ruc=(flop cur) ovs=0] |- ^+ [ruc self] ?: =(~ q.tub) [~ halt] ?~ ruc [ruc self] ~? bug heat/[debu q.i.ruc cur] ?- -.p.q.i.ruc %bloq =^ neu tub (snack blomar:donp) ?^ neu $(ruc t.ruc, ovs p.i.ruc) [ruc self] %list ?~ t.ruc !! :: $(t.ruc [p.i.ruc [%item ~] ~]~) :: XX why this ?> ?=(%item -.p.q.i.t.ruc) ~? bug leat/[p.i.t.ruc debu] =^ den tub (snack (stun [p p]:i.t.ruc ace)) ?^ den $(ruc t.t.ruc) ?. =(self horz) [ruc self] :: XX efficiency ?: ?=([%code ^ *] nod) [~ self] :: XX correct? =^ neu tub (snake limar:donp) ?~ neu [ruc self] => .(q.u.neu ^+(p.q.i.ruc q.u.neu)) :: XX do type stuff ?. (list-nest p.q.i.ruc q.u.neu) =. self (collapse (flop ruc)) [~ (push u.neu)] =. self (collapse (flop t.ruc)) [~ (push p.u.neu [%item ~])] %item !! == :: ++ aces |=(a=@u ^+(tub +:(snack (stun 0^a ace)))) :: nom optional leading :: ++ lazy :: errant prev bloqs |= ruc=(list (pair ,@ tops)) ^+ self ~? bug laze/[debu ruc] ?. ?=(%para -.nod) (collapse (flop ruc)) ?: |([?=(^ -)]:lead [?=(^ -)]:(snack leaf:donp)) :: XX efficiency (collapse (flop ruc)) :: =. tub +:(snack (star ace)) self ::self(tub (aces p.i.cur)) :: XX correct? :: =< (collapse (flop ruc)) :: |- ^+ . :: ?~ ruc ..$ :: ?. ?=([%bloq ~] -.q.i.ruc) :: ..$ :: $(ruc t.ruc) :: ++ lead :: enter into tops %- snake => donp ;~(plug ;~(pose blomar limar)) :: ++ news :: enter nest levels |- ^+ self ?. =(self horz) self :: XX efficiency =^ neu tub lead ?~ neu self =. bun | :: don't wide new lists $(self (push u.neu)) :: ++ node :: consume leaf node ^+ self ~? bug neat/curlin ::=. self ?.(bun self cull) ?^ [q]:((leas htm-head):donp tub) :: XX efficiency (pump [%html ~]) =+ ^= hez %+ stag %heas ?. ?=([%para [%$ *] ~] nod) fail ;~(plug setext:donp (cold p.nod (ahed eol))) =+ ico=?:(?=(%para -.nod) fail icode:donp) =+ saf=q.p.+:(snack (star ace)) :: XX efficiency =^ neu tub (snack ;~(pose hez ico leaf:donp)) ~? bug feat/[bun saf blos neu] =. cur ?.(bun cur widen) ?~ neu =. tub +:(snack (star ace)) ?. ?=(%para -.nod) cull self ?+ -.u.neu (pump u.neu) %heas self(nod u.neu(- %head)) :: replace extant para %code ?^ p.u.neu (pump u.neu (dec saf)) ?: ?=([%code ~ *] nod) self (pump u.neu) == :: ++ code ^+ self ?> ?=([%code ^ *] nod) :: XX do type stuff ~? bug ceas/[sap] =. tub (aces sap) =+ [neu tup]=(snack ;~(sfix (leas fcode):donp eol)) ?: &(?=(^ neu) (closes-code p.nod p.u.neu)) =. q.nod q.nod cull(tub tup) =^ buf tub (snack ;~(sfix (star ace) nal)) ?^ buf self(q.nod [(crip u.buf) q.nod]) span :: ++ span :: raw text ^+ self ?: =(~ q.tub) halt =^ lin tub (snack line:donp) ?~ lin halt ~? bug adva/u.lin |- ?~ u.lin ?+ -.nod cull %code self %html self(p.nod ['' p.nod]) == ?+ -.nod (pump para/~[`u.lin]) %para self(p.nod :_(p.nod `u.lin)) %head ?^ q.nod $(self cull) self(q.nod [`(dehax u.lin)]~) %code self(q.nod :_(q.nod (crip u.lin))) %html self(p.nod :_(p.nod (crip u.lin))) == :: -- -- -- ==