1
Fork 0
mirror of https://git.savannah.gnu.org/git/guile.git synced 2025-06-16 16:50:21 +02:00

Add `(srfi srfi-88)'.

This commit is contained in:
Ludovic Courtès 2008-04-26 19:34:37 +02:00
parent e9680652d6
commit efbc70de56
10 changed files with 188 additions and 7 deletions

View file

@ -1,3 +1,8 @@
2008-04-26 Ludovic Courtès <ludo@gnu.org>
* Makefile.am (srfi_DATA): Add `srfi-88.scm'.
* srfi-88.scm: New file.
2008-03-12 Ludovic Courtès <ludo@gnu.org>
* srfi-37.scm (args-fold)[short-option]: Set ARGS to `(cdr

View file

@ -1,6 +1,6 @@
## Process this file with Automake to create Makefile.in
##
## Copyright (C) 2001, 2002, 2004, 2005, 2006, 2007 Free Software Foundation, Inc.
## Copyright (C) 2001, 2002, 2004, 2005, 2006, 2007, 2008 Free Software Foundation, Inc.
##
## This file is part of GUILE.
##
@ -78,7 +78,8 @@ srfi_DATA = srfi-1.scm \
srfi-37.scm \
srfi-39.scm \
srfi-60.scm \
srfi-69.scm
srfi-69.scm \
srfi-88.scm
EXTRA_DIST = $(srfi_DATA)
TAGS_FILES = $(srfi_DATA)

50
srfi/srfi-88.scm Normal file
View file

@ -0,0 +1,50 @@
;;; srfi-88.scm --- Keyword Objects
;; Copyright (C) 2008 Free Software Foundation, Inc.
;;
;; 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 2.1 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
;;; Author: Ludovic Courtès <ludo@gnu.org>
;;; Commentary:
;; This is a convenience module providing SRFI-88 "keyword object". All it
;; does is setup the right reader option and export keyword-related
;; convenience procedures.
;;; Code:
(define-module (srfi srfi-88)
#:re-export (keyword?)
#:export (keyword->string string->keyword))
(cond-expand-provide (current-module) '(srfi-88))
(read-set! keywords 'postfix)
(define (keyword->string k)
"Return the name of @var{k} as a string."
(symbol->string (keyword->symbol k)))
(define (string->keyword s)
"Return the keyword object whose name is @var{s}."
(symbol->keyword (string->symbol s)))
;;; Local Variables:
;;; coding: latin-1
;;; End:
;;; srfi-88.scm ends here