shrub/pkg/arvo/lib/frontmatter.hoon
2019-07-16 15:59:39 -07:00

36 lines
867 B
Plaintext

::
:::: /hoon/frontmatter/lib
::
/? 310
::
=, format
|%
++ atr-lines
|= atr/(map cord cord)
%+ turn (sort ~(tap by atr) |=({{a/@ @} {b/@ @}} (aor a b)))
|= {k/cord v/cord}
(rap 3 k ': ' v ~)
::
++ atr-key ;~(sfix (star ;~(less col prn)) col ace)
++ print
|= {atr/(map cord cord) src/wain}
?~ atr src
['---' (welp (atr-lines atr) '---' src)]
++ parse
=| atr/(map cord cord)
|= wan/wain ^+ [atr mud='']
?~ wan [~ '']
?^ (rush i.wan (star ace))
$(wan t.wan)
?. =('---' i.wan) [~ (of-wain wan)]
|- ^+ [atr mud='']
?~ t.wan ~|(%unclosed-metadata !!)
?: =('---' i.t.wan) [atr (of-wain t.t.wan)]
?^ (rush i.t.wan (star ace))
$(wan t.wan)
=- $(wan t.wan, atr (~(put by atr) (crip key) (crip val)))
~| malformed-attribute+i.t.wan
^- {key/tape ^ val/tape}
+>:(atr-key 1^1 (trip i.t.wan))
--