Fix 'define-public' from (ice-9 curried-definitions).
[bpt/guile.git] / module / ice-9 / curried-definitions.scm
CommitLineData
0ac084bf 1;;; Copyright (C) 2010, 2013 Free Software Foundation, Inc.
9225df3c
AW
2;;;
3;;;; This library is free software; you can redistribute it and/or
4;;;; modify it under the terms of the GNU Lesser General Public
5;;;; License as published by the Free Software Foundation; either
6;;;; version 3 of the License, or (at your option) any later version.
7;;;;
8;;;; This library is distributed in the hope that it will be useful,
9;;;; but WITHOUT ANY WARRANTY; without even the implied warranty of
10;;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11;;;; Lesser General Public License for more details.
12;;;;
13;;;; You should have received a copy of the GNU Lesser General Public
14;;;; License along with this library; if not, write to the Free Software
15;;;; Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16
17(define-module (ice-9 curried-definitions)
18 #:replace ((cdefine . define)
4aaceda2
IP
19 (cdefine* . define*)
20 define-public))
9225df3c
AW
21
22(define-syntax cdefine
23 (syntax-rules ()
9225df3c 24 ((_ (head . rest) body body* ...)
0ac084bf 25 (cdefine head
e39d0b76 26 (lambda rest body body* ...)))
0ac084bf
MW
27 ((_ name val)
28 (define name val))))
9225df3c
AW
29
30(define-syntax cdefine*
31 (syntax-rules ()
9225df3c 32 ((_ (head . rest) body body* ...)
0ac084bf 33 (cdefine* head
e39d0b76 34 (lambda* rest body body* ...)))
0ac084bf
MW
35 ((_ name val)
36 (define* name val))))
4aaceda2
IP
37
38(define-syntax define-public
39 (syntax-rules ()
0ac084bf
MW
40 ((_ (head . rest) body body* ...)
41 (define-public head
42 (lambda rest body body* ...)))
4aaceda2
IP
43 ((_ name val)
44 (begin
45 (define name val)
46 (export name)))))