make the browse-directory-list plugin work again, i.e. rewrite it
using select-list
This commit is contained in:
parent
eb5fff8905
commit
93c6d96922
|
@ -1,345 +1,141 @@
|
||||||
;;This addition provides a directory-tree-browsing-functionality.
|
|
||||||
;;This means:
|
|
||||||
;;When using it you hand over a list of strings, that shall be
|
|
||||||
;;interpreted as paths and a string that represents the path, relative to
|
|
||||||
;;which the path-list is given.
|
|
||||||
;;In the result-window of the NUIT a file-browsing screen is shown
|
|
||||||
;;which you can browse in using arrow-keys and enter. You can also
|
|
||||||
;;select some items and paste them into the upper window.
|
|
||||||
|
|
||||||
;;If there are paths to files handed over that do not exist, they will not be
|
|
||||||
;;displayed in the browser!
|
|
||||||
|
|
||||||
;;If the given path does not exist you will not be able to navigate!
|
|
||||||
|
|
||||||
(define key-m 109)
|
(define key-m 109)
|
||||||
(define key-u 117)
|
(define key-u 117)
|
||||||
|
(define key-return 10)
|
||||||
|
|
||||||
(define-record-type browse-dir-list-res-obj browse-dir-list-res-obj
|
(define-record-type filelist-state :filelist-state
|
||||||
(make-browse-dir-list-res-obj pos-y
|
(make-filelist-state files select-list working-dir initial-dir)
|
||||||
pos-x
|
filelist-state?
|
||||||
file-list
|
(files filelist-state-files)
|
||||||
result-text
|
(select-list filelist-state-select-list)
|
||||||
working-directory
|
(working-dir filelist-state-working-dir)
|
||||||
width
|
(initial-dir filelist-state-initial-dir))
|
||||||
initial-wd
|
|
||||||
marked-items
|
|
||||||
res-marked-items
|
|
||||||
c-x-pressed)
|
|
||||||
browse-dir-list-res-obj?
|
|
||||||
(pos-y browse-dir-list-res-obj-pos-y)
|
|
||||||
(pos-x browse-dir-list-res-obj-pos-x)
|
|
||||||
(file-list browse-dir-list-res-obj-file-list)
|
|
||||||
(result-text browse-dir-list-res-obj-result-text)
|
|
||||||
(working-directory browse-dir-list-res-obj-working-directory)
|
|
||||||
(width browse-dir-list-res-obj-width)
|
|
||||||
(initial-wd browse-dir-list-res-obj-initial-wd)
|
|
||||||
(marked-items browse-dir-list-res-obj-marked-items)
|
|
||||||
(res-marked-items browse-dir-list-res-obj-res-marked-items)
|
|
||||||
(c-x-pressed browse-dir-list-res-obj-c-x-pressed))
|
|
||||||
|
|
||||||
(define (layout-dir-list files wdir width)
|
(define-record-discloser :filelist-state
|
||||||
(let ((marked-files (mark-special-files wdir files)))
|
(lambda (r)
|
||||||
(append
|
`(filelist-state ,(filelist-state-working-dir r)
|
||||||
(list
|
,(filelist-state-files r))))
|
||||||
(if (<= (string-length wdir) (- width 25))
|
|
||||||
(string-append "Paths relative to " wdir " :")
|
|
||||||
(let ((dir-string (substring wdir
|
|
||||||
(- (string-length wdir)
|
|
||||||
(- width 25))
|
|
||||||
(string-length wdir))))
|
|
||||||
(string-append "Paths relative to ..."
|
|
||||||
dir-string))))
|
|
||||||
marked-files)))
|
|
||||||
|
|
||||||
(define (mark-special-files dir files)
|
(define (add-marks-to-special-file fs-object)
|
||||||
(map (lambda (file)
|
(let ((name (fs-object-name fs-object))
|
||||||
(let ((complete-name (string-append dir "/" file)))
|
(info (fs-object-info fs-object)))
|
||||||
(cond
|
|
||||||
((file-directory? complete-name)
|
|
||||||
(string-append " " file "/"))
|
|
||||||
((file-executable? complete-name)
|
|
||||||
(string-append "*" file))
|
|
||||||
((file-symlink? complete-name)
|
|
||||||
(string-append "@" file))
|
|
||||||
(else
|
|
||||||
(string-append " " file)))))
|
|
||||||
files))
|
|
||||||
|
|
||||||
;;selection->descend
|
|
||||||
(define selected-browse-dir-list
|
|
||||||
(lambda (model)
|
|
||||||
(let ((ln (browse-dir-list-res-obj-pos-y model))
|
|
||||||
(wd (browse-dir-list-res-obj-working-directory model)))
|
|
||||||
(if (not (file-exists? wd))
|
|
||||||
model
|
|
||||||
(begin (chdir wd)
|
|
||||||
(if (or (>= ln (+ (length
|
|
||||||
(browse-dir-list-res-obj-result-text model)) 1))
|
|
||||||
(<= ln 1))
|
|
||||||
model
|
|
||||||
(if (= ln 2)
|
|
||||||
(if (not (equal? "/" (cwd)))
|
|
||||||
(begin
|
|
||||||
(chdir "..")
|
|
||||||
(let* ((new-result (directory-files))
|
|
||||||
(width (browse-dir-list-res-obj-width model))
|
|
||||||
(new-text (layout-dir-list
|
|
||||||
new-result (cwd) width))
|
|
||||||
(new-model (make-browse-dir-list-res-obj
|
|
||||||
2
|
|
||||||
1
|
|
||||||
new-result
|
|
||||||
new-text
|
|
||||||
(cwd)
|
|
||||||
width
|
|
||||||
(browse-dir-list-res-obj-initial-wd
|
|
||||||
model)
|
|
||||||
(browse-dir-list-res-obj-marked-items
|
|
||||||
model)
|
|
||||||
(browse-dir-list-res-obj-res-marked-items
|
|
||||||
model)
|
|
||||||
(browse-dir-list-res-obj-c-x-pressed
|
|
||||||
model))))
|
|
||||||
new-model))
|
|
||||||
model)
|
|
||||||
(let* ((text (browse-dir-list-res-obj-result-text model))
|
|
||||||
(ent (list-ref text (- ln 1)))
|
|
||||||
(len (string-length ent))
|
|
||||||
(last-char (substring ent (- len 1) len))
|
|
||||||
(rest (substring ent 1 (- len 1))))
|
|
||||||
(if (equal? last-char "/")
|
|
||||||
(begin
|
|
||||||
(chdir wd)
|
|
||||||
(chdir rest)
|
|
||||||
(let* ((new-result (directory-files))
|
|
||||||
(width (browse-dir-list-res-obj-width model))
|
|
||||||
(new-text (layout-dir-list
|
|
||||||
new-result (cwd) width))
|
|
||||||
(new-model (make-browse-dir-list-res-obj
|
|
||||||
2
|
|
||||||
1
|
|
||||||
new-result
|
|
||||||
new-text
|
|
||||||
(cwd)
|
|
||||||
width
|
|
||||||
(browse-dir-list-res-obj-initial-wd
|
|
||||||
model)
|
|
||||||
(browse-dir-list-res-obj-marked-items
|
|
||||||
model)
|
|
||||||
(browse-dir-list-res-obj-res-marked-items
|
|
||||||
model)
|
|
||||||
(browse-dir-list-res-obj-c-x-pressed model))))
|
|
||||||
new-model))
|
|
||||||
model)))))))))
|
|
||||||
|
|
||||||
(define (init-with-list-of-files files dir width)
|
|
||||||
(make-browse-dir-list-res-obj
|
|
||||||
2 1
|
|
||||||
files (layout-dir-list files dir width) dir
|
|
||||||
width (cwd) '() '() #f))
|
|
||||||
|
|
||||||
(define browse-dir-list-receiver
|
|
||||||
(lambda (message)
|
|
||||||
(debug-message "browse-dir-list-receiver " message)
|
|
||||||
(cond
|
(cond
|
||||||
|
((file-info-directory? info)
|
||||||
|
(string-append " " name "/"))
|
||||||
|
((file-info-executable? info)
|
||||||
|
(string-append "*" name))
|
||||||
|
((file-info-symlink? info)
|
||||||
|
(string-append "@" name))
|
||||||
|
(else
|
||||||
|
(string-append " " name)))))
|
||||||
|
|
||||||
((init-with-result-message? message)
|
;; leave one line for the heading
|
||||||
(let ((fs-objects (init-with-result-message-result message)))
|
(define (calculate-number-of-lines result-buffer)
|
||||||
(init-with-list-of-files
|
(- (result-buffer-num-lines result-buffer)
|
||||||
(map fs-object-name fs-objects) (cwd)
|
1))
|
||||||
(result-buffer-num-cols
|
|
||||||
(init-with-result-message-buffer message)))))
|
|
||||||
|
|
||||||
((next-command-message? message)
|
(define (layout-fsobject fsobject)
|
||||||
(init-with-list-of-files (directory-files) (cwd)))
|
(add-marks-to-special-file fsobject))
|
||||||
|
|
||||||
((print-message? message)
|
(define (make-file-select-list fsobjects num-lines)
|
||||||
(let* ((model (message-result-object message))
|
(make-select-list
|
||||||
(pos-y (browse-dir-list-res-obj-pos-y model))
|
(cons (make-unmarked-element 'parent-dir #f " ..")
|
||||||
(pos-x (browse-dir-list-res-obj-pos-x model))
|
(map (lambda (fs-object)
|
||||||
(text (browse-dir-list-res-obj-result-text model))
|
(make-unmarked-element
|
||||||
(marked-pos (get-marked-positions-3
|
fs-object #t (layout-fsobject fs-object)))
|
||||||
(browse-dir-list-res-obj-file-list model)
|
fsobjects))
|
||||||
(browse-dir-list-res-obj-marked-items model))))
|
num-lines))
|
||||||
(debug-message "browse-dir-list-receiver "
|
|
||||||
"pos-y " pos-y " pos-x " pos-x
|
|
||||||
" marked-pos " marked-pos)
|
|
||||||
(make-simple-result-buffer-printer
|
|
||||||
pos-y pos-x text (list pos-y) marked-pos)))
|
|
||||||
|
|
||||||
((key-pressed-message? message)
|
;;; lacks some coolness
|
||||||
(let* ((model (message-result-object message))
|
(define (abbrev-path path length)
|
||||||
(key (key-pressed-message-key message))
|
(if (< (string-length path) length)
|
||||||
(c-x-pressed (browse-dir-list-res-obj-c-x-pressed model)))
|
path
|
||||||
|
(string-copy path
|
||||||
|
(- (string-length path) length))))
|
||||||
|
|
||||||
(cond
|
(define header-line-path
|
||||||
|
"Paths relative to ")
|
||||||
|
|
||||||
;; user pressed 'm' --- mark current entry
|
(define (make-header-line state width)
|
||||||
((= key key-m)
|
(let ((dir (filelist-state-working-dir state)))
|
||||||
(let* ((marked-items (browse-dir-list-res-obj-marked-items model))
|
(string-append
|
||||||
(res-marked-items (browse-dir-list-res-obj-res-marked-items
|
header-line-path
|
||||||
model))
|
(if dir
|
||||||
(actual-pos (browse-dir-list-res-obj-pos-y model))
|
(abbrev-path
|
||||||
(all-items (browse-dir-list-res-obj-file-list model)))
|
dir (- width (string-length header-line-path)))
|
||||||
(if (<= actual-pos 2)
|
"<unknown>"))))
|
||||||
model
|
|
||||||
(let* ((actual-item (list-ref all-items (- actual-pos 3)))
|
|
||||||
(actual-res-item
|
|
||||||
(if (not (string=? (cwd) "/"))
|
|
||||||
(string-append (cwd) "/" actual-item)
|
|
||||||
(string-append "/" actual-item))))
|
|
||||||
(if (member actual-res-item marked-items)
|
|
||||||
model
|
|
||||||
(let* ((new-res-marked-items (append res-marked-items
|
|
||||||
(list
|
|
||||||
actual-res-item)))
|
|
||||||
(new-marked-items (append marked-items
|
|
||||||
(list actual-item)))
|
|
||||||
(new-model (make-browse-dir-list-res-obj
|
|
||||||
(browse-dir-list-res-obj-pos-y model)
|
|
||||||
(browse-dir-list-res-obj-pos-x model)
|
|
||||||
(browse-dir-list-res-obj-file-list
|
|
||||||
model)
|
|
||||||
(browse-dir-list-res-obj-result-text
|
|
||||||
model)
|
|
||||||
(browse-dir-list-res-obj-working-directory
|
|
||||||
model)
|
|
||||||
(browse-dir-list-res-obj-width model)
|
|
||||||
(browse-dir-list-res-obj-initial-wd
|
|
||||||
model)
|
|
||||||
new-marked-items
|
|
||||||
new-res-marked-items
|
|
||||||
#f)))
|
|
||||||
new-model))))))
|
|
||||||
|
|
||||||
;; user pressed 'u' --- unmark current entry
|
(define (paint-browser state)
|
||||||
((= key key-u)
|
(lambda (win result-buffer have-focus?)
|
||||||
(let* ((marked-items (browse-dir-list-res-obj-marked-items model))
|
(wattron win (A-BOLD))
|
||||||
(res-marked-items (browse-dir-list-res-obj-res-marked-items
|
(mvwaddstr win 0 0
|
||||||
model))
|
(make-header-line
|
||||||
(actual-pos (browse-dir-list-res-obj-pos-y model))
|
state (result-buffer-num-cols result-buffer)))
|
||||||
(all-items (browse-dir-list-res-obj-file-list model)))
|
(wattrset win (A-NORMAL))
|
||||||
(if (<= actual-pos 2)
|
((paint-selection-list-at
|
||||||
model
|
(filelist-state-select-list state) 1 2)
|
||||||
(let* ((actual-item (list-ref all-items (- actual-pos 3)))
|
win result-buffer have-focus?)))
|
||||||
(actual-res-item (string-append (cwd) "/" actual-item))
|
|
||||||
(rest (member actual-item marked-items))
|
|
||||||
(res-rest (member actual-res-item res-marked-items)))
|
|
||||||
(if (not res-rest)
|
|
||||||
model
|
|
||||||
(let* ((after-item (length rest))
|
|
||||||
(all-items (length marked-items))
|
|
||||||
(before-item (sublist marked-items
|
|
||||||
0
|
|
||||||
(- all-items
|
|
||||||
after-item )))
|
|
||||||
(new-marked-items (append before-item
|
|
||||||
(list-tail rest 1)))
|
|
||||||
(after-res-item (length res-rest))
|
|
||||||
(all-res-items (length res-marked-items))
|
|
||||||
(before-res-item (sublist res-marked-items
|
|
||||||
0
|
|
||||||
(- all-res-items
|
|
||||||
after-res-item)))
|
|
||||||
(new-res-marked-items (append before-res-item
|
|
||||||
(list-tail res-rest
|
|
||||||
1)))
|
|
||||||
(new-model (make-browse-dir-list-res-obj
|
|
||||||
(browse-dir-list-res-obj-pos-y model)
|
|
||||||
(browse-dir-list-res-obj-pos-x model)
|
|
||||||
(browse-dir-list-res-obj-file-list
|
|
||||||
model)
|
|
||||||
(browse-dir-list-res-obj-result-text
|
|
||||||
model)
|
|
||||||
(browse-dir-list-res-obj-working-directory
|
|
||||||
model)
|
|
||||||
(browse-dir-list-res-obj-width model)
|
|
||||||
(browse-dir-list-res-obj-initial-wd
|
|
||||||
model)
|
|
||||||
new-marked-items
|
|
||||||
new-res-marked-items
|
|
||||||
#f)))
|
|
||||||
new-model))))))
|
|
||||||
|
|
||||||
((= key key-up)
|
(define (make-browser-for-dir dir num-lines)
|
||||||
(let ((posy (browse-dir-list-res-obj-pos-y model)))
|
(with-cwd dir
|
||||||
(if (<= posy 2)
|
(let ((fs-objects (directory-files)))
|
||||||
model
|
(make-filelist-state
|
||||||
(let* ((new-posy (- posy 1))
|
fs-objects (make-file-select-list fs-objects num-lines)
|
||||||
(new-model (make-browse-dir-list-res-obj
|
(cwd) (cwd)))))
|
||||||
new-posy
|
|
||||||
(browse-dir-list-res-obj-pos-x model)
|
|
||||||
(browse-dir-list-res-obj-file-list model)
|
|
||||||
(browse-dir-list-res-obj-result-text model)
|
|
||||||
(browse-dir-list-res-obj-working-directory
|
|
||||||
model)
|
|
||||||
(browse-dir-list-res-obj-width model)
|
|
||||||
(browse-dir-list-res-obj-initial-wd model)
|
|
||||||
(browse-dir-list-res-obj-marked-items model)
|
|
||||||
(browse-dir-list-res-obj-res-marked-items
|
|
||||||
model)
|
|
||||||
#f)))
|
|
||||||
new-model))))
|
|
||||||
|
|
||||||
((= key key-down)
|
(define (handle-return-key state selected-entry num-lines)
|
||||||
(let ((posy (browse-dir-list-res-obj-pos-y model))
|
(cond
|
||||||
(num-lines (length
|
((eq? selected-entry 'parent-dir)
|
||||||
(browse-dir-list-res-obj-result-text model))))
|
(let* ((maybe-parent
|
||||||
(if (>= posy num-lines)
|
(file-name-directory (filelist-state-working-dir state)))
|
||||||
model
|
(parent (if (string=? maybe-parent "") "/" maybe-parent)))
|
||||||
(let* ((new-posy (+ posy 1))
|
(make-browser-for-dir parent num-lines)))
|
||||||
(new-model (make-browse-dir-list-res-obj
|
(else
|
||||||
new-posy
|
(let ((fi (fs-object-info selected-entry)))
|
||||||
(browse-dir-list-res-obj-pos-x model)
|
(if (file-info-directory? fi)
|
||||||
(browse-dir-list-res-obj-file-list model)
|
(make-browser-for-dir (fs-object-complete-path selected-entry)
|
||||||
(browse-dir-list-res-obj-result-text model)
|
num-lines)
|
||||||
(browse-dir-list-res-obj-working-directory
|
state)))))
|
||||||
model)
|
|
||||||
(browse-dir-list-res-obj-width model)
|
|
||||||
(browse-dir-list-res-obj-initial-wd model)
|
|
||||||
(browse-dir-list-res-obj-marked-items model)
|
|
||||||
(browse-dir-list-res-obj-res-marked-items
|
|
||||||
model)
|
|
||||||
#f)))
|
|
||||||
new-model))))
|
|
||||||
|
|
||||||
((= key 10)
|
(define (handle-key-press message)
|
||||||
(selected-browse-dir-list model))
|
(let* ((state (message-result-object message))
|
||||||
|
(select-list (filelist-state-select-list state))
|
||||||
|
(key (key-pressed-message-key message)))
|
||||||
|
(cond
|
||||||
|
((= key key-return)
|
||||||
|
(handle-return-key
|
||||||
|
state (select-list-selected-entry select-list)
|
||||||
|
(calculate-number-of-lines
|
||||||
|
(key-pressed-message-result-buffer message))))
|
||||||
|
(else
|
||||||
|
(make-filelist-state
|
||||||
|
(filelist-state-files state)
|
||||||
|
(select-list-handle-key-press
|
||||||
|
(filelist-state-select-list state) message)
|
||||||
|
(filelist-state-working-dir state)
|
||||||
|
(filelist-state-initial-dir state))))))
|
||||||
|
|
||||||
;; user pressed C-x
|
(define (filelist-browser message)
|
||||||
((= key 24)
|
(cond
|
||||||
(make-browse-dir-list-res-obj
|
|
||||||
(browse-dir-list-res-obj-pos-y model)
|
|
||||||
(browse-dir-list-res-obj-pos-x model)
|
|
||||||
(browse-dir-list-res-obj-file-list model)
|
|
||||||
(browse-dir-list-res-obj-result-text model)
|
|
||||||
(browse-dir-list-res-obj-working-directory
|
|
||||||
model)
|
|
||||||
(browse-dir-list-res-obj-width model)
|
|
||||||
(browse-dir-list-res-obj-initial-wd model)
|
|
||||||
(browse-dir-list-res-obj-marked-items model)
|
|
||||||
(browse-dir-list-res-obj-res-marked-items
|
|
||||||
model)
|
|
||||||
(not c-x-pressed)))
|
|
||||||
|
|
||||||
(else model))))
|
((init-with-result-message? message)
|
||||||
|
(let ((fsobjects (init-with-result-message-result message))
|
||||||
|
(num-lines (calculate-number-of-lines
|
||||||
|
(init-with-result-message-buffer message))))
|
||||||
|
(make-browser-for-dir (cwd) num-lines)))
|
||||||
|
|
||||||
|
((print-message? message)
|
||||||
|
(paint-browser (message-result-object message)))
|
||||||
|
|
||||||
((restore-message? message)
|
((key-pressed-message? message)
|
||||||
(let* ((model (message-result-object message))
|
(handle-key-press message))
|
||||||
(initial-wd (browse-dir-list-res-obj-initial-wd model)))
|
|
||||||
(chdir initial-wd)))
|
|
||||||
|
|
||||||
((selection-message? message)
|
(else
|
||||||
(let* ((model (message-result-object message))
|
(values))))
|
||||||
(marked-items (browse-dir-list-res-obj-res-marked-items model)))
|
|
||||||
(string-append "'" (exp->string marked-items)))))))
|
|
||||||
|
|
||||||
(define (list-of-fs-objects? thing)
|
(define (list-of-fs-objects? thing)
|
||||||
(and (proper-list? thing)
|
(and (proper-list? thing)
|
||||||
(every fs-object? thing)))
|
(every fs-object? thing)))
|
||||||
|
|
||||||
(register-plugin!
|
(register-plugin!
|
||||||
(make-view-plugin browse-dir-list-receiver
|
(make-view-plugin filelist-browser
|
||||||
list-of-fs-objects?))
|
list-of-fs-objects?))
|
||||||
|
|
|
@ -1,9 +1,26 @@
|
||||||
(define-record-type fs-object :fs-object
|
(define-record-type fs-object :fs-object
|
||||||
(make-fs-object name path)
|
(really-make-fs-object name path info)
|
||||||
fs-object?
|
fs-object?
|
||||||
(name fs-object-name)
|
(name fs-object-name)
|
||||||
(path fs-object-path))
|
(path fs-object-path)
|
||||||
|
(info fs-object-info))
|
||||||
|
|
||||||
|
(define (make-fs-object name path)
|
||||||
|
(really-make-fs-object
|
||||||
|
name path
|
||||||
|
(file-info (combine-path path name))))
|
||||||
|
|
||||||
(define-record-discloser :fs-object
|
(define-record-discloser :fs-object
|
||||||
(lambda (r)
|
(lambda (r)
|
||||||
`(fs-object ,(fs-object-name r))))
|
`(fs-object ,(fs-object-name r))))
|
||||||
|
|
||||||
|
(define (combine-path parent name)
|
||||||
|
(if (string=? parent "")
|
||||||
|
name
|
||||||
|
(string-append parent
|
||||||
|
"/"
|
||||||
|
name)))
|
||||||
|
|
||||||
|
(define (fs-object-complete-path fs-object)
|
||||||
|
(combine-path (fs-object-path fs-object)
|
||||||
|
(fs-object-name fs-object)))
|
||||||
|
|
|
@ -79,11 +79,15 @@
|
||||||
|
|
||||||
(define-structure dirlist-view-plugin
|
(define-structure dirlist-view-plugin
|
||||||
(export)
|
(export)
|
||||||
(open scheme-with-scsh
|
(open (modify nuit-eval (hide string-copy))
|
||||||
define-record-types
|
define-record-types
|
||||||
|
srfi-1
|
||||||
|
(subset srfi-13 (string-copy))
|
||||||
|
signals
|
||||||
|
|
||||||
layout
|
layout
|
||||||
fs-object
|
fs-object
|
||||||
srfi-1
|
select-list
|
||||||
plugin
|
plugin
|
||||||
ncurses
|
ncurses
|
||||||
tty-debug)
|
tty-debug)
|
||||||
|
@ -103,10 +107,13 @@
|
||||||
(export make-fs-object
|
(export make-fs-object
|
||||||
fs-object?
|
fs-object?
|
||||||
fs-object-name
|
fs-object-name
|
||||||
fs-object-path))
|
fs-object-path
|
||||||
|
fs-object-info
|
||||||
|
fs-object-complete-path))
|
||||||
|
|
||||||
(define-structure fs-object fs-object-interface
|
(define-structure fs-object fs-object-interface
|
||||||
(open scheme
|
(open scheme
|
||||||
|
(subset scsh (file-info))
|
||||||
define-record-types)
|
define-record-types)
|
||||||
(files fs-object))
|
(files fs-object))
|
||||||
|
|
||||||
|
@ -115,6 +122,11 @@
|
||||||
(define-interface select-list-interface
|
(define-interface select-list-interface
|
||||||
(export make-select-list
|
(export make-select-list
|
||||||
select-list?
|
select-list?
|
||||||
|
|
||||||
|
make-unmarked-element
|
||||||
|
make-marked-element
|
||||||
|
element?
|
||||||
|
|
||||||
select-list-handle-key-press
|
select-list-handle-key-press
|
||||||
unmark-current-line
|
unmark-current-line
|
||||||
mark-current-line
|
mark-current-line
|
||||||
|
@ -129,7 +141,7 @@
|
||||||
(open scheme
|
(open scheme
|
||||||
srfi-1
|
srfi-1
|
||||||
define-record-types
|
define-record-types
|
||||||
let-opt
|
signals
|
||||||
|
|
||||||
tty-debug
|
tty-debug
|
||||||
plugin
|
plugin
|
||||||
|
|
Loading…
Reference in New Issue