Minimal syntactic fluids support.
[mes.git] / tests / fluids.test
1 #! /bin/sh
2 # -*-scheme-*-
3 echo ' ()' | cat $(dirname $0)/../module/mes/base-0.mes $0 /dev/stdin | $(dirname $0)/../scripts/mes $MES_FLAGS "$@"
4 #paredit:||
5 exit $?
6 !#
7
8 ;;; -*-scheme-*-
9
10 ;;; Mes --- Maxwell Equations of Software
11 ;;; Copyright © 2016 Jan Nieuwenhuizen <janneke@gnu.org>
12 ;;;
13 ;;; This file is part of Mes.
14 ;;;
15 ;;; Mes is free software; you can redistribute it and/or modify it
16 ;;; under the terms of the GNU General Public License as published by
17 ;;; the Free Software Foundation; either version 3 of the License, or (at
18 ;;; your option) any later version.
19 ;;;
20 ;;; Mes is distributed in the hope that it will be useful, but
21 ;;; WITHOUT ANY WARRANTY; without even the implied warranty of
22 ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
23 ;;; GNU General Public License for more details.
24 ;;;
25 ;;; You should have received a copy of the GNU General Public License
26 ;;; along with Mes.  If not, see <http://www.gnu.org/licenses/>.
27
28 (mes-use-module (mes fluids))
29 (mes-use-module (mes test))
30
31 (define a (make-fluid))
32 (define b (make-fluid))
33 (define c #f)
34
35 (pass-if "fluid?" (fluid? a))
36 (pass-if-not "fluid? not" (fluid? c))
37 (pass-if-not "fluid-ref"
38              (fluid-ref a))
39
40 (pass-if "with-fluid*"
41   (with-fluid* a #t (lambda () (fluid-ref a))))
42
43 (pass-if-not "with-fluid* reset"
44              (begin
45                (with-fluid* a #t (lambda () (fluid-ref a)))
46                (fluid-ref a)))
47
48 ;; (pass-if-equal "with fluids*"
49 ;;     0 (with-fluids* (list a b) '(0 1)
50 ;;                     (lambda () (fluid-ref a))))
51
52 ;; (pass-if-equal "with-fluids"
53 ;;     0 (with-fluids ((a 1)
54 ;;                     (a 2)
55 ;;                     (a 3))
56 ;;         (begin (fluid-set! a 0))
57 ;;         (begin (fluid-ref a))))
58
59 ;; (pass-if-equal "with-fluids"
60 ;;     #f (begin
61 ;;          (with-fluids ((a 1)
62 ;;                        (a 2)
63 ;;                        (a 3))
64 ;;            (begin (fluid-set! a 0))
65 ;;            (begin (display "X:") (display (fluid-ref a)) (newline)))
66 ;;          (fluid-ref a)))
67
68 (result 'report)