! Copyright (C) 2007 Daniel Ehrenberg ! See http://factorcode.org/license.txt for BSD license. USING: namespaces make parser lexer kernel sequences words quotations math accessors ; IN: multiline > ; : (parse-here) ( -- ) next-line-text [ dup ";" = [ drop lexer get next-line ] [ % "\n" % (parse-here) ] if ] [ ";" unexpected-eof ] if* ; PRIVATE> : parse-here ( -- str ) [ (parse-here) ] "" make but-last lexer get next-line ; : STRING: CREATE-WORD parse-here 1quotation (( -- string )) define-inline ; parsing > [ 2dup start [ rot dupd [ swap subseq % ] 2dip length + ] [ rot tail % "\n" % 0 lexer get next-line swap (parse-multiline-string) ] if* ] [ nip unexpected-eof ] if* ; PRIVATE> : parse-multiline-string ( end-text -- str ) [ lexer get [ swap (parse-multiline-string) ] change-column drop ] "" make rest ; : <" "\">" parse-multiline-string parsed ; parsing : /* "*/" parse-multiline-string drop ; parsing