mirror of
https://github.com/urbit/shrub.git
synced 2024-12-15 21:03:10 +03:00
1220 lines
33 KiB
Plaintext
1220 lines
33 KiB
Plaintext
:: 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=/==18%%/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 {<u.had>}")
|
|
=> [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 {<u.had>}")
|
|
(lose "close {<u.tal>}")
|
|
::
|
|
++ 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 {<p.a>}")
|
|
%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: {<p.a>}
|
|
:: :/([(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 {<u.had>}")
|
|
=> [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 {<u.had>}")
|
|
(lose "close {<u.tal>}")
|
|
::
|
|
++ 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 <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)))
|
|
==
|
|
::
|
|
--
|
|
-- --
|
|
==
|