12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- ;; Copyright (C) Scott G. Miller (2002). All Rights Reserved.
- ;; Made an R7RS library by Taylan Ulrich Bayırlı/Kammer, Copyright (C) 2014.
- ;; Permission is hereby granted, free of charge, to any person obtaining a copy
- ;; of this software and associated documentation files (the "Software"), to deal
- ;; in the Software without restriction, including without limitation the rights
- ;; to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- ;; copies of the Software, and to permit persons to whom the Software is
- ;; furnished to do so, subject to the following conditions:
- ;; The above copyright notice and this permission notice shall be included in
- ;; all copies or substantial portions of the Software.
- ;; THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- ;; IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- ;; FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- ;; AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- ;; LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- ;; OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- ;; SOFTWARE.
- (define-library (srfi 28)
- (export format)
- (import
- (scheme base)
- (scheme write))
- (begin
- (define format
- (lambda (format-string . objects)
- (let ((buffer (open-output-string)))
- (let loop ((format-list (string->list format-string))
- (objects objects))
- (cond ((null? format-list) (get-output-string buffer))
- ((char=? (car format-list) #\~)
- (if (null? (cdr format-list))
- (error 'format "Incomplete escape sequence")
- (case (cadr format-list)
- ((#\a)
- (if (null? objects)
- (error 'format "No value for escape sequence")
- (begin
- (display (car objects) buffer)
- (loop (cddr format-list) (cdr objects)))))
- ((#\s)
- (if (null? objects)
- (error 'format "No value for escape sequence")
- (begin
- (write (car objects) buffer)
- (loop (cddr format-list) (cdr objects)))))
- ((#\%)
- (newline buffer)
- (loop (cddr format-list) objects))
- ((#\~)
- (write-char #\~ buffer)
- (loop (cddr format-list) objects))
- (else
- (error 'format "Unrecognized escape sequence")))))
- (else (write-char (car format-list) buffer)
- (loop (cdr format-list) objects)))))))))
|