From 1b4fd3440c3e170c41d69a3fa66900b749006041 Mon Sep 17 00:00:00 2001 From: Fang Date: Tue, 1 Aug 2017 12:21:18 -0700 Subject: [PATCH] Parse indent in ++snap directly instead of feeding spaces to span-level parsers --- gen/cram.hoon | 53 ++++++++++++++++++++++++++++++++------------------- 1 file changed, 33 insertions(+), 20 deletions(-) diff --git a/gen/cram.hoon b/gen/cram.hoon index 0bb63f014..0cbffe7a7 100644 --- a/gen/cram.hoon +++ b/gen/cram.hoon @@ -489,21 +489,37 @@ :: :: no unterminated lines ?~ los ~&(%unterminated-line [~ +>(err `naz)]) - ?: =(`@`10 i.los) + ?. =(`@`10 i.los) + ?: (gth col q.naz) + ?. (~(has in ^~((silt " -+>!"))) i.los) + ~&(expected-indent+[col naz los] [~ +>(err `naz)]) + $(los t.los, q.naz +(q.naz)) :: - :: consume newline - :_ +>(los t.los, naz [+(p.naz) 1]) - :: - :: trim trailing spaces - |- ^- tape - ?: ?=({$' ' *} nap) - $(nap t.nap) - (flop nap) + :: save byte and repeat + $(los t.los, q.naz +(q.naz), nap [i.los nap]) :: - :: save byte and repeat - $(los t.los, q.naz +(q.naz), nap [i.los nap]) + :: consume newline + :_ +>(los t.los, naz [+(p.naz) 1]) + :: + :: trim trailing spaces + |- ^- tape + ?: ?=({$' ' *} nap) + $(nap t.nap) + (flop nap) + :: + ++ skip :: discard line + |- ^+ + + :: + :: no unterminated lines + ?~ los ~&(%unterminated-line +(err `naz)) + ?. =(`@`10 i.los) + :: + :: eat byte and repeat + $(los t.los) + :: + :: consume newline + +(los t.los, naz [+(p.naz) 1]) :: - ++ skip +:snap :: discard line ++ look :: inspect line ^- (unit trig) (wonk (look:parse naz los)) @@ -521,7 +537,7 @@ |= tape ^- mars :: :: each line is text data with its newline - ;/((weld (slag (add 4 (dec col)) +<) "\0a")) + ;/((weld (slag 4 +<) "\0a")) :: :: if block is verse ?: ?=($poem p.cur) @@ -535,7 +551,7 @@ :: each line is a paragraph :- [%p ~] :_ ~ - ;/((weld (slag (dec col) +<) "\0a")) + ;/("{+<}\0a") :: :: yex: block recomposed, with newlines =/ yex/tape (join '\0a' (flop q.u.lub)) @@ -634,14 +650,14 @@ =/ dif (sub col.pic col) =/ erp [p.naz col.pic] :: - :: nap: take first line - =^ nap +>.$ snap - :: :: execute appropriate paragraph form =< line:abet:apex |% :: ++ abet :: accept line + :: + :: nap: take first line + =^ nap +>.$ snap ..$(lub `[naz nap ~]) :: ++ apex ^+ . :: by column offset @@ -672,9 +688,6 @@ :: indent by 2 =. col (add 2 col) :: - :: erase marker - =. nap =+((dec col) (runt [- ' '] (slag - nap))) - :: (push typ) :: ++ lent :: list entry