#! /bin/sh # -*-scheme-*- exec ${MES-bin/mes} --no-auto-compile -L ${0%/*} -L module -C module -e '(tests peg)' -s "$0" "$@" !# ;;; -*-scheme-*- ;;; GNU Mes --- Maxwell Equations of Software ;;; Copyright © 2016 Jan (janneke) Nieuwenhuizen ;;; ;;; This file is part of GNU Mes. ;;; ;;; GNU Mes is free software; you can redistribute it and/or modify it ;;; under the terms of the GNU General Public License as published by ;;; the Free Software Foundation; either version 3 of the License, or (at ;;; your option) any later version. ;;; ;;; GNU Mes 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 General Public License for more details. ;;; ;;; You should have received a copy of the GNU General Public License ;;; along with GNU Mes. If not, see . (define-module (tests peg) #:use-module (mes mes-0) #:use-module (mes test)) (cond-expand (mes (mes-use-module (mes peg)) (mes-use-module (mes test))) (guile-2.2 (use-modules (ice-9 peg))) (guile (use-modules (ice-9 syncase)) (display "guile 2.0: no PEG\n" (current-error-port)) (exit 0))) (pass-if "first dummy" #t) (pass-if-not "second dummy" #f) (define *etc-passwd* "root:x:0:0:root:/root:/bin/bash daemon:x:1:1:daemon:/usr/sbin:/bin/sh bin:x:2:2:bin:/bin:/bin/sh sys:x:3:3:sys:/dev:/bin/sh nobody:x:65534:65534:nobody:/nonexistent:/bin/sh messagebus:x:103:107::/var/run/dbus:/bin/false") (define-peg-string-patterns "string-passwd <- entry* !. entry <-- (! NL .)* NL* NL < '\n'") (pass-if-equal "peg-tree" (map (lambda (x) (list 'entry x)) (string-split *etc-passwd* #\newline)) (peg:tree (match-pattern string-passwd *etc-passwd*))) (define-peg-pattern passwd body (and (* entry) (not-followed-by peg-any))) (define-peg-pattern entry all (and (* (and (not-followed-by NL) peg-any)) (* NL))) (define-peg-pattern NL none "\n") (define-peg-pattern passwd body (peg "entry* !.")) (pass-if-equal "peg-tree" (map (lambda (x) (list 'entry x)) (string-split *etc-passwd* #\newline)) (peg:tree (match-pattern passwd *etc-passwd*))) (result 'report)