83 lines
2.1 KiB
Scheme
83 lines
2.1 KiB
Scheme
|
;;; -*-Scheme-*-
|
||
|
;;;
|
||
|
;;; An interactive command loop for testing the GNU gdbm extension.
|
||
|
;;; Contributed by Martin Stut.
|
||
|
|
||
|
|
||
|
(require 'gdbm.o)
|
||
|
|
||
|
(let ((gf (gdbm-open 'test.gdbm 1024 'create)) (last "nothing"))
|
||
|
(if (not gf)
|
||
|
(error 'gdbm-open "cannot open test.gdbm"))
|
||
|
(format #t "Type ? for help~%")
|
||
|
(let loop ((op (read-char)))
|
||
|
(newline)
|
||
|
(if (not (char=? op #\newline))
|
||
|
(read-string)) ; flush rest of line
|
||
|
(case op
|
||
|
((#\? #\h)
|
||
|
(format #t "c -- count items~%")
|
||
|
(format #t "d -- delete item~%")
|
||
|
(format #t "f -- fetch item~%")
|
||
|
(format #t "s -- store item~%")
|
||
|
(format #t "n -- next key~%")
|
||
|
(format #t "1 -- first key~%")
|
||
|
(format #t "2 -- next key of last n, 1, or 2~%")
|
||
|
(format #t "r -- reorganize~%")
|
||
|
(format #t "q -- quit~%"))
|
||
|
(#\c
|
||
|
(do ((i 0 (1+ i))
|
||
|
(x (gdbm-firstkey gf) (gdbm-nextkey gf x)))
|
||
|
((not x) (format #t "Number of entries: ~s~%" i))))
|
||
|
(#\d
|
||
|
(display "Key: ")
|
||
|
(if (gdbm-delete gf (read-string))
|
||
|
(format #t "Deleted.~%")
|
||
|
(format #t "Doesn't exist.~%")))
|
||
|
(#\f
|
||
|
(display "Key: ")
|
||
|
((lambda (d)
|
||
|
(if d
|
||
|
(format #t "Data: ~s~%" d)
|
||
|
(format #t "Doesn't exist.~%")))
|
||
|
(gdbm-fetch gf (read-string))))
|
||
|
(#\s
|
||
|
(display "Key: ")
|
||
|
((lambda (k)
|
||
|
(display "Data: ")
|
||
|
(if (= 1 (gdbm-store gf k (read-string) 'insert))
|
||
|
(format #t "Already there.~%")
|
||
|
(format #t "Inserted.~%")))
|
||
|
(read-string)))
|
||
|
(#\n
|
||
|
(display "Key: ")
|
||
|
((lambda (r)
|
||
|
(if r
|
||
|
(begin
|
||
|
(format #t "Next: ~s Data: ~s~%" r (gdbm-fetch gf r))
|
||
|
(set! last r))
|
||
|
(print #f)))
|
||
|
(gdbm-nextkey gf (read-string))))
|
||
|
(#\1
|
||
|
((lambda (r)
|
||
|
(if r
|
||
|
(begin
|
||
|
(format #t "First: ~s Data: ~s~%" r (gdbm-fetch gf r))
|
||
|
(set! last r))
|
||
|
(print #f)))
|
||
|
(gdbm-firstkey gf)))
|
||
|
(#\2
|
||
|
((lambda (r)
|
||
|
(if r
|
||
|
(begin
|
||
|
(format #t "Next: ~s Data: ~s~%" r (gdbm-fetch gf r))
|
||
|
(set! last r))
|
||
|
(print #f)))
|
||
|
(gdbm-nextkey gf last)))
|
||
|
(#\r
|
||
|
(gdbm-reorganize gf)
|
||
|
(format #t "Reorganized.~%"))
|
||
|
(#\q
|
||
|
(exit)))
|
||
|
(loop (read-char))))
|