Fix a few bugs in fsobjects-viewer

This commit is contained in:
mainzelm 2005-05-31 14:54:48 +00:00
parent 0cb71508ef
commit ddf1ca752b
2 changed files with 43 additions and 53 deletions

View File

@ -65,11 +65,6 @@
(paint-selection-list-at select-list 1 2 win (paint-selection-list-at select-list 1 2 win
buffer have-focus?)) buffer have-focus?))
(define (make-browser-for-dir instance dir)
(let ((new-instance (make-fsobjects-viewer)))
(send new-instance 'init-browser-for-dir
dir (send instance 'get-buffer))))
(define (find-common-parent paths) (define (find-common-parent paths)
(if (null? paths) (if (null? paths)
"" ""
@ -99,7 +94,7 @@
(let* ((maybe-parent (let* ((maybe-parent
(file-name-directory (send instance 'get-working-dir))) (file-name-directory (send instance 'get-working-dir)))
(parent (if (string=? maybe-parent "") "/" maybe-parent))) (parent (if (string=? maybe-parent "") "/" maybe-parent)))
(make-browser-for-dir instance parent))) (make-browser-for-dir parent (send instance 'get-buffer))))
(else (else
(let ((fi (fs-object-info selected-entry))) (let ((fi (fs-object-info selected-entry)))
(if (and fi (file-info-directory? fi)) (if (and fi (file-info-directory? fi))
@ -109,8 +104,8 @@
(display packet) (display packet)
(newline) (newline)
instance)) instance))
(make-browser-for-dir instance (make-browser-for-dir (fs-object-complete-path selected-entry)
(fs-object-complete-path selected-entry))) (send instance 'get-buffer)))
instance))))) instance)))))
(define (handle-key-press instance key) (define (handle-key-press instance key)
@ -126,31 +121,25 @@
(select-list-handle-key-press select-list key)) (select-list-handle-key-press select-list key))
instance)))) instance))))
(define (make-fsobjects-viewer fs-objects buffer) (define (make-browser-for-dir dir buffer)
(let* ((fs-objects fs-objects) (with-cwd dir
(make-fsobjects-viewer (directory-files)
buffer
(cwd))))
(define (make-fsobjects-viewer fs-objects buffer . maybe-parent)
(let-optionals maybe-parent
((working-dir (find-common-parent
(map fs-object-path fs-objects))))
(let ((fs-objects fs-objects)
(buffer buffer) (buffer buffer)
(working-dir (find-common-parent
(map fs-object-path fs-objects)))
(select-list (select-list
(make-file-select-list fs-objects (make-file-select-list fs-objects
working-dir working-dir
(result-buffer-num-lines buffer)))) (- (result-buffer-num-lines buffer) 2))))
(lambda (message) (lambda (message)
(cond (cond
((eq? message 'init-browser-for-dir)
(lambda (self new-dir new-buffer)
(with-cwd new-dir
(let ((new-fs-objects (directory-files)))
(set! buffer new-buffer)
(set! fs-objects new-fs-objects)
(set! working-dir new-dir)
(set! select-list
(make-file-select-list
fs-objects (cwd) (result-buffer-num-lines new-buffer)))
self))))
((eq? message 'paint) ((eq? message 'paint)
(lambda (self . args) (lambda (self . args)
(apply paint-browser (apply paint-browser
@ -177,7 +166,7 @@
working-dir)) working-dir))
(else (else
(error "fsobjects-viewer unknown message" message)))))) (error "fsobjects-viewer unknown message" message))))))))
(define (list-of-fs-objects? thing) (define (list-of-fs-objects? thing)
(and (proper-list? thing) (and (proper-list? thing)

View File

@ -107,6 +107,7 @@
srfi-1 srfi-1
(subset srfi-13 (string-copy string-drop string-prefix-length)) (subset srfi-13 (string-copy string-drop string-prefix-length))
signals signals
let-opt
objects objects
layout layout