:: :::: /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)) --