srfi-28.scm 2.8 KB

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