intern arbitrary constants
[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 19 (cdefine* . define*)
b072b8e6
IP
20 define-public
21 define*-public))
9225df3c
AW
22
23(define-syntax cdefine
24 (syntax-rules ()
9225df3c 25 ((_ (head . rest) body body* ...)
0ac084bf 26 (cdefine head
e39d0b76 27 (lambda rest body body* ...)))
0ac084bf
MW
28 ((_ name val)
29 (define name val))))
9225df3c
AW
30
31(define-syntax cdefine*
32 (syntax-rules ()
9225df3c 33 ((_ (head . rest) body body* ...)
0ac084bf 34 (cdefine* head
e39d0b76 35 (lambda* rest body body* ...)))
0ac084bf
MW
36 ((_ name val)
37 (define* name val))))
4aaceda2
IP
38
39(define-syntax define-public
40 (syntax-rules ()
0ac084bf
MW
41 ((_ (head . rest) body body* ...)
42 (define-public head
43 (lambda rest body body* ...)))
4aaceda2
IP
44 ((_ name val)
45 (begin
46 (define name val)
47 (export name)))))
b072b8e6
IP
48
49(define-syntax define*-public
50 (syntax-rules ()
51 ((_ (head . rest) body body* ...)
52 (define*-public head
53 (lambda* rest body body* ...)))
54 ((_ name val)
55 (begin
56 (define* name val)
57 (export name)))))