racket/collects/web-server/lang/file-box.ss
Jay McCarthy aed865f2b0 Updating docs and timer.ss
svn: r6492
2007-06-06 00:26:12 +00:00

29 lines
957 B
Scheme

(module file-box mzscheme
(require (lib "serialize.ss")
(lib "contract.ss"))
(define-serializable-struct internal-file-box (path))
(define file-box? internal-file-box?)
(define (file-box path default)
(define fb (make-internal-file-box path))
(unless (file-box-set? fb)
(file-box-set! fb default))
fb)
(define (file-box-set? fb)
(with-handlers ([exn? (lambda _ #f)])
(file-unbox fb)
#t))
(define (file-unbox fb)
(deserialize (call-with-input-file (internal-file-box-path fb) read)))
(define (file-box-set! fb v)
(with-output-to-file (internal-file-box-path fb) (lambda () (write (serialize v))) 'replace))
(provide/contract
[file-box? (any/c . -> . boolean?)]
[file-box (path? serializable? . -> . file-box?)]
[file-unbox (file-box? . -> . serializable?)]
[file-box-set? (file-box? . -> . boolean?)]
[file-box-set! (file-box? serializable? . -> . void)]))