GNU bug report logs -
#55673
[PATCH] cache: Catch valid integer for 'last-expiry-cleanup'.
Previous Next
Reported by: zimoun <zimon.toutoune <at> gmail.com>
Date: Fri, 27 May 2022 08:26:01 UTC
Severity: normal
Tags: patch
Done: Ludovic Courtès <ludo <at> gnu.org>
Bug is archived. No further changes may be made.
Full log
View this message in rfc822 format
[Message part 1 (text/plain, inline)]
zimoun schreef op vr 27-05-2022 om 10:25 [+0200]:
> (catch 'system-error
> (lambda ()
> - (call-with-input-file expiry-file read))
> + (match (call-with-input-file expiry-file read)
> + ((? integer? date) date)
> + (_ 0)))
It might be possible to end up wit hsomething more bogus on some file
system, it's possible to end up with something even more boguse (e.g.,
"unterminated-string), which 'read' doesn't understand. I suggest
using 'get-string-all' + 'number->string'.
For completeness, a comment like
;; Handle the 'write' below being interrupted before the write
;; could complete (e.g. with C-c) and handle file system crashes
;; causing empty files or corrupted contents.
and a regression test in tets/cache.scm would be nice.
Also, I'd switch the catch and the (match ...) because 'read' and
integer? shouldn't raise any 'system-error'.
Greetings,
Maxime.
[signature.asc (application/pgp-signature, inline)]
This bug report was last modified 2 years and 352 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.