28.sld 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. ;; Copyright (C) Scott G. Miller (2002). All Rights Reserved.
  2. ;; Made an R7RS library by Taylan Ulrich Bayırlı/Kammer, Copyright (C) 2014.
  3. ;; Permission is hereby granted, free of charge, to any person obtaining a copy
  4. ;; of this software and associated documentation files (the "Software"), to deal
  5. ;; in the Software without restriction, including without limitation the rights
  6. ;; to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  7. ;; copies of the Software, and to permit persons to whom the Software is
  8. ;; furnished to do so, subject to the following conditions:
  9. ;; The above copyright notice and this permission notice shall be included in
  10. ;; all copies or substantial portions of the Software.
  11. ;; THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  12. ;; IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  13. ;; FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  14. ;; AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  15. ;; LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  16. ;; OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  17. ;; SOFTWARE.
  18. (define-library (srfi 28)
  19. (export format)
  20. (import
  21. (scheme base)
  22. (scheme write))
  23. (begin
  24. (define format
  25. (lambda (format-string . objects)
  26. (let ((buffer (open-output-string)))
  27. (let loop ((format-list (string->list format-string))
  28. (objects objects))
  29. (cond ((null? format-list) (get-output-string buffer))
  30. ((char=? (car format-list) #\~)
  31. (if (null? (cdr format-list))
  32. (error 'format "Incomplete escape sequence")
  33. (case (cadr format-list)
  34. ((#\a)
  35. (if (null? objects)
  36. (error 'format "No value for escape sequence")
  37. (begin
  38. (display (car objects) buffer)
  39. (loop (cddr format-list) (cdr objects)))))
  40. ((#\s)
  41. (if (null? objects)
  42. (error 'format "No value for escape sequence")
  43. (begin
  44. (write (car objects) buffer)
  45. (loop (cddr format-list) (cdr objects)))))
  46. ((#\%)
  47. (newline buffer)
  48. (loop (cddr format-list) objects))
  49. ((#\~)
  50. (write-char #\~ buffer)
  51. (loop (cddr format-list) objects))
  52. (else
  53. (error 'format "Unrecognized escape sequence")))))
  54. (else (write-char (car format-list) buffer)
  55. (loop (cdr format-list) objects)))))))))