mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-06-30 06:50:31 +02:00
add utils to turn value history on and off, and to clear it
* module/ice-9/history.scm (enable-value-history!) (disable-value-history!, clear-value-history!): New exports.
This commit is contained in:
parent
a85f90f5ac
commit
a38dd31ffc
1 changed files with 26 additions and 4 deletions
|
@ -1,4 +1,4 @@
|
||||||
;;;; Copyright (C) 2000, 2001, 2004, 2006 Free Software Foundation, Inc.
|
;;;; Copyright (C) 2000, 2001, 2004, 2006, 2010 Free Software Foundation, Inc.
|
||||||
;;;;
|
;;;;
|
||||||
;;;; This library is free software; you can redistribute it and/or
|
;;;; This library is free software; you can redistribute it and/or
|
||||||
;;;; modify it under the terms of the GNU Lesser General Public
|
;;;; modify it under the terms of the GNU Lesser General Public
|
||||||
|
@ -17,10 +17,14 @@
|
||||||
|
|
||||||
;;;; A simple value history support
|
;;;; A simple value history support
|
||||||
|
|
||||||
(define-module (ice-9 history))
|
(define-module (ice-9 history)
|
||||||
|
#:export (enable-value-history! disable-value-history!
|
||||||
|
clear-value-history!))
|
||||||
|
|
||||||
(process-define-module '((value-history)))
|
(process-define-module '((value-history)))
|
||||||
|
|
||||||
|
(define value-history-enabled? #f)
|
||||||
|
|
||||||
(define (use-value-history x)
|
(define (use-value-history x)
|
||||||
(module-use! (current-module)
|
(module-use! (current-module)
|
||||||
(resolve-interface '(value-history))))
|
(resolve-interface '(value-history))))
|
||||||
|
@ -37,5 +41,23 @@
|
||||||
(module-export! history (list s))
|
(module-export! history (list s))
|
||||||
(set! count c))))))
|
(set! count c))))))
|
||||||
|
|
||||||
(add-hook! before-eval-hook use-value-history)
|
(define (enable-value-history!)
|
||||||
(add-hook! before-print-hook save-value-history)
|
(if (not value-history-enabled?)
|
||||||
|
(begin
|
||||||
|
(add-hook! before-eval-hook use-value-history)
|
||||||
|
(add-hook! before-print-hook save-value-history)
|
||||||
|
(set! value-history-enabled? #t))))
|
||||||
|
|
||||||
|
(define (disable-value-history!)
|
||||||
|
(if value-history-enabled?
|
||||||
|
(begin
|
||||||
|
(remove-hook! before-eval-hook use-value-history)
|
||||||
|
(remove-hook! before-print-hook save-value-history)
|
||||||
|
(set! value-history-enabled? #f))))
|
||||||
|
|
||||||
|
(define (clear-value-history!)
|
||||||
|
(let ((history (resolve-module '(value-history))))
|
||||||
|
(hash-clear! (module-obarray history))
|
||||||
|
(hash-clear! (module-obarray (module-public-interface history)))))
|
||||||
|
|
||||||
|
(enable-value-history!)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue