From: Mark Wooding Date: Wed, 1 Jul 2020 18:38:17 +0000 (+0100) Subject: dot/lisp-init.lisp: Get CLisp to save and restore its REPL history. X-Git-Url: https://git.distorted.org.uk/~mdw/profile/commitdiff_plain/0630988acc7864483d8f6ed96f0ff1971ddb4db6 dot/lisp-init.lisp: Get CLisp to save and restore its REPL history. This is much more painful than it ought to be, but it seems to work. --- diff --git a/dot/lisp-init.lisp b/dot/lisp-init.lisp index 3cdcd5e..da50a6f 100644 --- a/dot/lisp-init.lisp +++ b/dot/lisp-init.lisp @@ -41,6 +41,31 @@ #+clisp (setf custom:*parse-namestring-ansi* t) +;; CLisp history. +#+(and clisp readline) +(progn + (export '(*history-file* *history-size*)) + (defvar *history-file* (format nil "~A/.clisp-history" (ext:getenv "HOME")) + "File to preserve the REPL history.") + (defvar *history-size* 1000) + (unless (and (probe-file *history-file*) nil) + (let (old-umask stream) + ;; Ugh. There's no proper open(2) veneer. Play with umask(2) to avoid + ;; a window in which an adversary can open the file. + (unwind-protect + (setf old-umask (os:umask #o077) + stream (open *history-file* + :direction :output + :if-exists :overwrite + :if-does-not-exist :create)) + (when stream (close stream)) + (when old-umask (os:umask old-umask))))) + (readline:read-history *history-file*) + (if *history-size* (readline:stifle-history *history-size*) + (readline:unstifle-history)) + (push (lambda () (readline:write-history *history-file*)) + custom:*fini-hooks*)) + ;; Shebang. (set-dispatch-macro-character #\# #\!