make format-datum return void on empty input

This commit is contained in:
Matthew Butterick 2016-08-03 10:44:33 -07:00
parent 9cee43af40
commit 48c17bd852

View File

@ -3,12 +3,14 @@
(provide (all-defined-out))
;; read "foo bar" the same way as "(foo bar)"
;; other "bar" is dropped, which is too astonishing
;; otherwise "bar" is dropped, which is too astonishing
(define (string->datum str)
(let ([result (read (open-input-string (format "(~a)" str)))])
(if (= (length result) 1)
(car result)
result)))
(if (positive? (string-length str))
(let ([result (read (open-input-string (format "(~a)" str)))])
(if (= (length result) 1)
(car result)
result))
(void)))
#;(define-syntax format-datum
(λ(stx)