Fixes for the changes in nuit-engine

This commit is contained in:
mainzelm 2005-05-31 13:15:31 +00:00
parent c405bc02c5
commit 246660a299
3 changed files with 70 additions and 157 deletions

View File

@ -1,26 +1,5 @@
(define-record-type inspector-state :inspector-state
(make-inspector-state val stack header num-cols num-lines selection-list)
inspector-state?
(val inspector-state-val)
(stack inspector-state-stack)
(header inspector-state-header)
(num-cols inspector-state-num-cols)
(num-lines inspector-state-num-lines)
(selection-list inspector-state-selection-list))
(define footer-length 0) (define footer-length 0)
(define (make-initial-inspector-state focus-obj num-cols num-lines)
(let ((header (make-header focus-obj num-cols)))
(make-inspector-state focus-obj
'()
header
num-cols
num-lines
(make-inspector-selection-list num-cols
(- num-lines (length header))
focus-obj))))
(define (make-inspector-selection-list num-cols num-lines focus-obj) (define (make-inspector-selection-list num-cols num-lines focus-obj)
(let ((menu (prepare-menu focus-obj))) (let ((menu (prepare-menu focus-obj)))
(make-select-list (make-select-list
@ -36,7 +15,6 @@
"Press cont-down key to see more" "Press cont-down key to see more"
""))) "")))
(define (layout-menu-entry num-cols entry) (define (layout-menu-entry num-cols entry)
(let ((head (format #f "[~a]" (or (car entry) "")))) (let ((head (format #f "[~a]" (or (car entry) ""))))
(string-append head (val-to-string (cdr entry) (string-append head (val-to-string (cdr entry)
@ -51,58 +29,6 @@
(let ((str (get-output-string out))) (let ((str (get-output-string out)))
(substring str 0 (min (string-length str) max-length))))) (substring str 0 (min (string-length str) max-length)))))
(define (inspector-state-exchange-selection-list old-state sl)
(make-inspector-state (inspector-state-val old-state)
(inspector-state-stack old-state)
(inspector-state-header old-state)
(inspector-state-num-cols old-state)
(inspector-state-num-lines old-state)
sl))
(define (inspector-state-exchange-header-msg old-state msg)
(make-inspector-state (inspector-state-val old-state)
(inspector-state-stack old-state)
(cons (car (inspector-state-header old-state))
(list msg))
(inspector-state-num-cols old-state)
(inspector-state-num-lines old-state)
(inspector-state-selection-list old-state)))
(define (inspector-state-push-value state val)
(let* ((num-cols (inspector-state-num-cols state))
(num-lines (inspector-state-num-lines state))
(hdr (make-header val num-cols)))
(make-inspector-state val
(cons (inspector-state-val state)
(inspector-state-stack state))
hdr
num-cols
num-lines
(make-inspector-selection-list
num-cols
(- num-lines (length hdr))
val))))
(define (inspector-state-pop-value state)
(let ((stack (inspector-state-stack state))
(num-cols (inspector-state-num-cols state))
(num-lines (inspector-state-num-lines state)))
(if (null? stack)
(inspector-state-exchange-header-msg state
"Can't go up from here.")
(let ((hdr (make-header (car stack) num-cols)))
(make-inspector-state (car stack)
(cdr stack)
hdr
num-cols
num-lines
(make-inspector-selection-list
num-cols
(- num-lines (length hdr))
(car stack)))))))
(define (inspect-value val) (define (inspect-value val)
(error "not yet")) (error "not yet"))
@ -112,63 +38,66 @@
(define down-key key-d) (define down-key key-d)
(define up-key key-u) (define up-key key-u)
(define (inspector-receiver message) (define (make-inspector focus-obj buffer)
(debug-message "inspector-receiver " message) (let* ((num-cols (result-buffer-num-cols buffer))
(cond (num-lines (result-buffer-num-lines buffer))
((init-with-result-message? message) (val focus-obj)
(let* ((focus-obj (init-with-result-message-result message)) (stack '())
(buffer (init-with-result-message-buffer message)) (header (make-header focus-obj num-cols))
(num-cols (result-buffer-num-cols buffer)) (num-cols num-cols)
(num-lines (result-buffer-num-lines buffer))) (num-lines num-lines)
(make-initial-inspector-state focus-obj (selection-list
(make-inspector-selection-list num-cols
(- num-lines (length header))
focus-obj)))
(define (inspect-next-continuation)
(if (continuation? val)
(set! stack (cons stack (continuation-parent val)))
(set! header
"Can't go down from a non-continuation.")))
(define (inspector-state-pop-value)
(if (null? stack)
(set! header "Can't go up from here.")
(begin
(set! header (make-header (car stack) num-cols))
(set! val (car stack))
(set! stack (cdr stack))
(set! selection-list
(make-inspector-selection-list
num-cols num-cols
num-lines))) (- num-lines (length header))
((print-message? message) val)))))
(lambda (win result-buffer have-focus?)
(let* ((state (message-result-object message)) (lambda (message)
(hdr (inspector-state-header state)) (case message
(hdr-len (length hdr))) ((paint)
(lambda (self win result-buffer have-focus?)
(let ((hdr-len (length header)))
(for-each (lambda (text y) (for-each (lambda (text y)
(mvwaddstr win y 0 text)) (mvwaddstr win y 0 text))
hdr header
(iota hdr-len)) (iota hdr-len))
((paint-selection-list-at (paint-selection-list-at
(inspector-state-selection-list state) selection-list
0 hdr-len) 0 hdr-len
win result-buffer have-focus?)))) win result-buffer have-focus?))))
((key-pressed-message? message) ((key-press)
(let ((old-state (message-result-object message)) (lambda (self key control-x-pressed?)
(key (key-pressed-message-key message)))
(cond (cond
((= key down-key) ((= key down-key)
(inspect-next-continuation old-state)) (inspect-next-continuation))
((= key up-key) ((= key up-key)
(inspector-state-pop-value old-state)) (inspector-state-pop-value))
(else (else
(let ((old-state (message-result-object message))) (set! selection-list
(inspector-state-exchange-selection-list
old-state
(select-list-handle-key-press (select-list-handle-key-press
(inspector-state-selection-list old-state) selection-list key))))
message))))))) self))
(else (else
(debug-message "did not handle message " message)))) (error "did not handle message " message))))))
(define (inspect-next-continuation state)
(let ((val (inspector-state-val state)))
(if (continuation? val)
(inspector-state-push-value state (continuation-parent val))
(inspector-state-exchange-header-msg
state
"Can't go down from a non-continuation."))))
(define (error-receiver message)
(inspector-receiver message))
(register-plugin! (register-plugin!
(make-view-plugin error-receiver exception-continuation?)) (make-view-plugin make-inspector exception-continuation?))
(register-plugin!
(make-view-plugin inspector-receiver inspector-state?))

View File

@ -30,22 +30,15 @@
processes) processes)
num-lines))) num-lines)))
(define (make-pps-viewer) (define (make-pps-viewer processes buffer)
(let ((processes #f) (let ((processes processes)
(select-list #f)) (select-list
(make-process-selection-list
(result-buffer-num-cols buffer)
(result-buffer-num-lines buffer)
processes)))
(lambda (message) (lambda (message)
(cond (cond
((eq? message 'init)
(lambda (self process-list buffer)
(let ((num-cols (result-buffer-num-cols buffer))
(num-lines (result-buffer-num-lines buffer)))
(set! processes process-list)
(set! select-list
(make-process-selection-list
num-cols num-lines processes))
self)))
((eq? message 'paint) ((eq? message 'paint)
(lambda (self . args) (lambda (self . args)
(apply paint-selection-list (apply paint-selection-list

View File

@ -1,21 +1,12 @@
(define (make-standard-viewer) (define (make-standard-viewer value buffer)
(let ((x 1) (let ((x 1)
(y 1) (y 1)
(text "") (value value)
(value #f)) (text (layout-result-standard
(exp->string value)
(result-buffer-num-cols buffer))))
(lambda (message) (lambda (message)
(cond (cond
((eq? message 'init)
(lambda (self new-value buffer)
(set! value new-value)
(set! text
(layout-result-standard
(exp->string value)
(result-buffer-num-cols buffer)))
self))
((eq? message 'paint) ((eq? message 'paint)
(lambda (self win buffer have-focus?) (lambda (self win buffer have-focus?)
;; #### get rid of this cruft ;; #### get rid of this cruft