mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-04-30 11:50:28 +02:00
* test-suite/Makefile.am: * test-suite/tests/brainfuck.test: Add a brainfuck test. * module/system/base/compile.scm: Also export read-and-compile. * module/language/tree-il/spec.scm (join): Fix the joiner in the 0-expression case. * module/language/tree-il/primitives.scm (+): Recognize (+ x -1) as 1-. * module/language/brainfuck/parse.scm (read-brainfuck): Return EOF if we actually received EOF, and there were no expressions read. * module/language/brainfuck/compile-tree-il.scm (compile-body): Fix the compiler for the new format of "lambda" in tree-il.
51 lines
2.1 KiB
Scheme
51 lines
2.1 KiB
Scheme
;;;; test brainfuck compilation -*- scheme -*-
|
|
;;;;
|
|
;;;; This library is free software; you can redistribute it and/or
|
|
;;;; modify it under the terms of the GNU Lesser General Public
|
|
;;;; License as published by the Free Software Foundation; either
|
|
;;;; version 3 of the License, or (at your option) any later version.
|
|
;;;;
|
|
;;;; This library is distributed in the hope that it will be useful,
|
|
;;;; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
;;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
;;;; Lesser General Public License for more details.
|
|
;;;;
|
|
;;;; You should have received a copy of the GNU Lesser General Public
|
|
;;;; License along with this library; if not, write to the Free Software
|
|
;;;; Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
(define-module (test-suite tests brainfuck)
|
|
#:use-module (test-suite lib)
|
|
#:use-module (system base compile))
|
|
|
|
;; This program taken from Wikipedia's brainfuck introduction page.
|
|
(define prog "
|
|
+++ +++ +++ + initialize counter (cell #0) to 10
|
|
[ use loop to set the next four cells to 70/100/30/10
|
|
> +++ +++ + add 7 to cell #1
|
|
> +++ +++ +++ + add 10 to cell #2
|
|
> +++ add 3 to cell #3
|
|
> + add 1 to cell #4
|
|
<<< < - decrement counter (cell #0)
|
|
]
|
|
>++ . print 'H'
|
|
>+. print 'e'
|
|
+++ +++ +. print 'l'
|
|
. print 'l'
|
|
+++ . print 'o'
|
|
>++ . print ' '
|
|
<<+ +++ +++ +++ +++ ++. print 'W'
|
|
>. print 'o'
|
|
+++ . print 'r'
|
|
--- --- . print 'l'
|
|
--- --- --. print 'd'
|
|
>+. print '!'")
|
|
|
|
(pass-if
|
|
(equal? (with-output-to-string
|
|
(lambda ()
|
|
(call-with-input-string
|
|
prog
|
|
(lambda (port)
|
|
(read-and-compile port #:from 'brainfuck #:to 'value)))))
|
|
"Hello World!"))
|