Artifact
feb68b25d4eb4962522a23ad53052b1503f1f9f9:
- File
srfi/s61/cond.sls
— part of check-in
[80c8c83034]
at
2016-07-07 18:11:39
on branch trunk
— initial import
(user:
ovenpasta@pizzahack.eu
size: 1126)
;; Copyright (c) 2009 Derick Eddington. All rights reserved.
;; Licensed under an MIT-style license. My license is in the file
;; named LICENSE from the original collection this file is distributed
;; with. If this file is redistributed with some other collection, my
;; license must also be included.
#!r6rs
(library (srfi s61 cond)
(export
(rename (general-cond cond)))
(import
(rnrs))
(define-syntax general-cond
(lambda (stx)
(syntax-case stx ()
[(_ clauses ...)
(with-syntax ([(ours ...)
(map (lambda (c)
(syntax-case c (=>)
[(generator guard => receiver)
#'((let-values ([vals generator])
(and (apply guard vals)
vals))
=> (lambda (vals)
(apply receiver vals)))]
[_ c]))
#'(clauses ...))])
#'(cond ours ...))])))
)