add take-while to state parser
parent
99c3cd9517
commit
f994654af3
|
@ -18,6 +18,9 @@ TUPLE: state-parser sequence n ;
|
||||||
: current ( state -- char/f )
|
: current ( state -- char/f )
|
||||||
[ n>> ] keep state-parser-nth ; inline
|
[ n>> ] keep state-parser-nth ; inline
|
||||||
|
|
||||||
|
: previous ( state -- char/f )
|
||||||
|
[ n>> 1 - ] keep state-parser-nth ; inline
|
||||||
|
|
||||||
: peek-next ( state -- char/f )
|
: peek-next ( state -- char/f )
|
||||||
[ n>> 1 + ] keep state-parser-nth ; inline
|
[ n>> 1 + ] keep state-parser-nth ; inline
|
||||||
|
|
||||||
|
@ -27,9 +30,6 @@ TUPLE: state-parser sequence n ;
|
||||||
: get+increment ( state -- char/f )
|
: get+increment ( state -- char/f )
|
||||||
[ current ] [ next drop ] bi ; inline
|
[ current ] [ next drop ] bi ; inline
|
||||||
|
|
||||||
: state-parse ( sequence quot -- )
|
|
||||||
[ <state-parser> ] dip call ; inline
|
|
||||||
|
|
||||||
:: skip-until ( state quot: ( obj -- ? ) -- )
|
:: skip-until ( state quot: ( obj -- ? ) -- )
|
||||||
state current [
|
state current [
|
||||||
quot call [ state next quot skip-until ] unless
|
quot call [ state next quot skip-until ] unless
|
||||||
|
@ -46,6 +46,9 @@ TUPLE: state-parser sequence n ;
|
||||||
[ drop [ n>> ] [ sequence>> ] bi ] 2tri subseq
|
[ drop [ n>> ] [ sequence>> ] bi ] 2tri subseq
|
||||||
] if ; inline
|
] if ; inline
|
||||||
|
|
||||||
|
: take-while ( state quot: ( obj -- ? ) -- sequence/f )
|
||||||
|
[ not ] compose take-until ; inline
|
||||||
|
|
||||||
:: take-until-sequence ( state-parser sequence -- sequence' )
|
:: take-until-sequence ( state-parser sequence -- sequence' )
|
||||||
sequence length <growing-circular> :> growing
|
sequence length <growing-circular> :> growing
|
||||||
state-parser
|
state-parser
|
||||||
|
@ -66,6 +69,5 @@ TUPLE: state-parser sequence n ;
|
||||||
: take-until-object ( state obj -- sequence )
|
: take-until-object ( state obj -- sequence )
|
||||||
'[ _ = ] take-until ;
|
'[ _ = ] take-until ;
|
||||||
|
|
||||||
: take-stuff ( state delimiter -- sequence )
|
: state-parse ( sequence quot -- )
|
||||||
|
[ <state-parser> ] dip call ; inline
|
||||||
;
|
|
||||||
|
|
Loading…
Reference in New Issue