mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-04-29 19:30:36 +02:00
Taken from r51 of <http://lalr-scm.googlecode.com/svn/trunk>. * module/Makefile.am (SYSTEM_BASE_SOURCES): Add `system/base/lalr.scm'. (NOCOMP_SOURCES): Add `system/base/lalr.upstream.scm'. * module/system/base/lalr.scm, module/system/base/lalr.upstream.scm: New files. * test-suite/Makefile.am (LALR_TESTS, LALR_EXTRA, TESTS, TESTS_ENVIRONMENT): New variables. (EXTRA_DIST): Add $(LALR_EXTRA). * test-suite/lalr/common-test.scm, test-suite/lalr/glr-test.scm, test-suite/lalr/test-glr-associativity.scm, test-suite/lalr/test-glr-basics-01.scm, test-suite/lalr/test-glr-basics-02.scm, test-suite/lalr/test-glr-basics-03.scm, test-suite/lalr/test-glr-basics-04.scm, test-suite/lalr/test-glr-basics-05.scm, test-suite/lalr/test-glr-script-expression.scm, test-suite/lalr/test-glr-single-expressions.scm, test-suite/lalr/test-lr-associativity-01.scm, test-suite/lalr/test-lr-associativity-02.scm, test-suite/lalr/test-lr-associativity-03.scm, test-suite/lalr/test-lr-associativity-04.scm, test-suite/lalr/test-lr-basics-01.scm, test-suite/lalr/test-lr-basics-02.scm, test-suite/lalr/test-lr-basics-03.scm, test-suite/lalr/test-lr-basics-04.scm, test-suite/lalr/test-lr-basics-05.scm, test-suite/lalr/test-lr-error-recovery-01.scm, test-suite/lalr/test-lr-error-recovery-02.scm, test-suite/lalr/test-lr-no-clause.scm, test-suite/lalr/test-lr-script-expression.scm, test-suite/lalr/test-lr-single-expressions.scm: New files.
51 lines
1.4 KiB
Scheme
51 lines
1.4 KiB
Scheme
;;; test-lr-error-recovery-02.scm --
|
|
;;
|
|
;;Test error recovery policy when the synchronisation terminal has the
|
|
;;same category of the lookahead that raises the error.
|
|
;;
|
|
|
|
(load "common-test.scm")
|
|
|
|
(define (doit . tokens)
|
|
(let ((parser (lalr-parser (expect: 0)
|
|
(A B C)
|
|
(alphas (alpha) : $1
|
|
(alphas alpha) : $2)
|
|
(alpha (A B) : (list $1 $2)
|
|
(C) : $1
|
|
(error C) : 'error-form))))
|
|
(parser (make-lexer tokens) error-handler)))
|
|
|
|
;;; --------------------------------------------------------------------
|
|
;;; No error, just grammar tests.
|
|
|
|
(check
|
|
(doit (make-lexical-token 'A #f 1)
|
|
(make-lexical-token 'B #f 2))
|
|
=> '(1 2))
|
|
|
|
(check
|
|
(doit (make-lexical-token 'C #f 3))
|
|
=> '3)
|
|
|
|
;;; --------------------------------------------------------------------
|
|
;;; Successful error recovery.
|
|
|
|
(check
|
|
;;Error, recovery, end-of-input.
|
|
(let ((r (doit (make-lexical-token 'A #f 1)
|
|
(make-lexical-token 'C #f 3))))
|
|
(cons r *error*))
|
|
=> '(error-form (error-handler "Syntax error: unexpected token : " . C)))
|
|
|
|
(check
|
|
;;Error, recovery, correct parse of "A B".
|
|
(let ((r (doit (make-lexical-token 'A #f 1)
|
|
(make-lexical-token 'C #f 3)
|
|
(make-lexical-token 'A #f 1)
|
|
(make-lexical-token 'B #f 2))))
|
|
(cons r *error*))
|
|
=> '((1 2)
|
|
(error-handler "Syntax error: unexpected token : " . C)))
|
|
|
|
;;; end of file
|