Parse indent in ++snap directly instead of feeding spaces to span-level parsers

This commit is contained in:
Fang 2017-08-01 12:21:18 -07:00
parent 4cb1d46618
commit 1b4fd3440c

View File

@ -489,21 +489,37 @@
:: ::
:: no unterminated lines :: no unterminated lines
?~ los ~&(%unterminated-line [~ +>(err `naz)]) ?~ 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 :: save byte and repeat
:_ +>(los t.los, naz [+(p.naz) 1]) $(los t.los, q.naz +(q.naz), nap [i.los nap])
::
:: trim trailing spaces
|- ^- tape
?: ?=({$' ' *} nap)
$(nap t.nap)
(flop nap)
:: ::
:: save byte and repeat :: consume newline
$(los t.los, q.naz +(q.naz), nap [i.los nap]) :_ +>(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 ++ look :: inspect line
^- (unit trig) ^- (unit trig)
(wonk (look:parse naz los)) (wonk (look:parse naz los))
@ -521,7 +537,7 @@
|= tape ^- mars |= tape ^- mars
:: ::
:: each line is text data with its newline :: each line is text data with its newline
;/((weld (slag (add 4 (dec col)) +<) "\0a")) ;/((weld (slag 4 +<) "\0a"))
:: ::
:: if block is verse :: if block is verse
?: ?=($poem p.cur) ?: ?=($poem p.cur)
@ -535,7 +551,7 @@
:: each line is a paragraph :: each line is a paragraph
:- [%p ~] :- [%p ~]
:_ ~ :_ ~
;/((weld (slag (dec col) +<) "\0a")) ;/("{+<}\0a")
:: ::
:: yex: block recomposed, with newlines :: yex: block recomposed, with newlines
=/ yex/tape (join '\0a' (flop q.u.lub)) =/ yex/tape (join '\0a' (flop q.u.lub))
@ -634,14 +650,14 @@
=/ dif (sub col.pic col) =/ dif (sub col.pic col)
=/ erp [p.naz col.pic] =/ erp [p.naz col.pic]
:: ::
:: nap: take first line
=^ nap +>.$ snap
::
:: execute appropriate paragraph form :: execute appropriate paragraph form
=< line:abet:apex =< line:abet:apex
|% |%
:: ::
++ abet :: accept line ++ abet :: accept line
::
:: nap: take first line
=^ nap +>.$ snap
..$(lub `[naz nap ~]) ..$(lub `[naz nap ~])
:: ::
++ apex ^+ . :: by column offset ++ apex ^+ . :: by column offset
@ -672,9 +688,6 @@
:: indent by 2 :: indent by 2
=. col (add 2 col) =. col (add 2 col)
:: ::
:: erase marker
=. nap =+((dec col) (runt [- ' '] (slag - nap)))
::
(push typ) (push typ)
:: ::
++ lent :: list entry ++ lent :: list entry