Use sunterlib's INSPECT-EXCEPTION package for debugging. Fix a crash
when switching from result buffer to command buffer.
This commit is contained in:
parent
03ffcf8280
commit
0a2c373bc0
|
@ -211,7 +211,19 @@
|
||||||
|
|
||||||
;;start the whole thing
|
;;start the whole thing
|
||||||
(define (nuit)
|
(define (nuit)
|
||||||
(run))
|
(with-inspecting-handler
|
||||||
|
8888
|
||||||
|
(lambda (condition)
|
||||||
|
(with-current-output-port*
|
||||||
|
(error-output-port)
|
||||||
|
(lambda ()
|
||||||
|
(display "starting remote handler for condition")
|
||||||
|
(display condition)
|
||||||
|
(newline)
|
||||||
|
(display "Please connect to port 8888")
|
||||||
|
(newline)
|
||||||
|
#t)))
|
||||||
|
run))
|
||||||
|
|
||||||
;;handle input
|
;;handle input
|
||||||
(define (run)
|
(define (run)
|
||||||
|
@ -273,21 +285,20 @@
|
||||||
|
|
||||||
;;Ctrl-x o ->switch buffer
|
;;Ctrl-x o ->switch buffer
|
||||||
((= ch 111)
|
((= ch 111)
|
||||||
(begin
|
(if (focus-on-command-buffer?)
|
||||||
(if (focus-on-command-buffer?)
|
(let ((key-message
|
||||||
(let ((key-message
|
(make-key-pressed-message active-command
|
||||||
(make-key-pressed-message active-command
|
current-result-object
|
||||||
current-result-object
|
97)))
|
||||||
97)))
|
(focus-result-buffer!)
|
||||||
(focus-result-buffer!)
|
(set! current-result-object (switch key-message))
|
||||||
(set! current-result-object (switch key-message))
|
(paint-result-window))
|
||||||
(paint-result-window))
|
(begin
|
||||||
(begin
|
(focus-command-buffer!)
|
||||||
(focus-command-buffer!)
|
(paint-command-window-contents)
|
||||||
(paint-command-window-contents)
|
(move-cursor command-buffer)))
|
||||||
(move-cursor command-buffer)))
|
(set! c-x-pressed #f)
|
||||||
(set! c-x-pressed #f)
|
(loop (wait-for-input)))
|
||||||
(loop (wait-for-input))))
|
|
||||||
|
|
||||||
;;C-x r -> redo
|
;;C-x r -> redo
|
||||||
((= ch 114)
|
((= ch 114)
|
||||||
|
@ -435,9 +446,7 @@
|
||||||
(paint-command-window)
|
(paint-command-window)
|
||||||
(paint-command-window-contents)
|
(paint-command-window-contents)
|
||||||
(paint-result-window)
|
(paint-result-window)
|
||||||
|
(move-cursor command-buffer))
|
||||||
(set! command-buffer
|
|
||||||
(move-cursor command-buffer)))
|
|
||||||
|
|
||||||
(define (wait-for-input)
|
(define (wait-for-input)
|
||||||
(noecho)
|
(noecho)
|
||||||
|
@ -633,7 +642,7 @@
|
||||||
(lambda (string)
|
(lambda (string)
|
||||||
(let loop ((str string))
|
(let loop ((str string))
|
||||||
(if (equal? str "")
|
(if (equal? str "")
|
||||||
values
|
(values)
|
||||||
(let ((first-ch (string-ref str 0)))
|
(let ((first-ch (string-ref str 0)))
|
||||||
(begin
|
(begin
|
||||||
(add-to-command-buffer (char->ascii first-ch))
|
(add-to-command-buffer (char->ascii first-ch))
|
||||||
|
@ -656,7 +665,7 @@
|
||||||
(define print-active-command-win
|
(define print-active-command-win
|
||||||
(lambda (win width)
|
(lambda (win width)
|
||||||
(if (<= width 25)
|
(if (<= width 25)
|
||||||
values
|
(values)
|
||||||
(let ((active-command (string-append active-command
|
(let ((active-command (string-append active-command
|
||||||
active-parameters)))
|
active-parameters)))
|
||||||
(if (> (string-length active-command) (- width 25))
|
(if (> (string-length active-command) (- width 25))
|
||||||
|
@ -698,7 +707,7 @@
|
||||||
(let ((lines (get-right-result-lines)))
|
(let ((lines (get-right-result-lines)))
|
||||||
(let loop ((pos 1))
|
(let loop ((pos 1))
|
||||||
(if (> pos result-lines)
|
(if (> pos result-lines)
|
||||||
values
|
(values)
|
||||||
(let ((line (list-ref lines (- pos 1))))
|
(let ((line (list-ref lines (- pos 1))))
|
||||||
(begin
|
(begin
|
||||||
(if (not (standard-result-obj? current-result-object))
|
(if (not (standard-result-obj? current-result-object))
|
||||||
|
@ -934,7 +943,7 @@
|
||||||
((key-pressed-message? message)
|
((key-pressed-message? message)
|
||||||
(key-pressed-message-result-model message))
|
(key-pressed-message-result-model message))
|
||||||
((restore-message? message)
|
((restore-message? message)
|
||||||
values)
|
(values))
|
||||||
((selection-message? message)
|
((selection-message? message)
|
||||||
""))))
|
""))))
|
||||||
|
|
||||||
|
@ -991,7 +1000,7 @@
|
||||||
((key-pressed-message? message)
|
((key-pressed-message? message)
|
||||||
(key-pressed-message-result-model message))
|
(key-pressed-message-result-model message))
|
||||||
((restore-message? message)
|
((restore-message? message)
|
||||||
values)
|
(values))
|
||||||
((selection-message? message)
|
((selection-message? message)
|
||||||
""))))
|
""))))
|
||||||
|
|
||||||
|
|
|
@ -10,6 +10,7 @@
|
||||||
handle
|
handle
|
||||||
ncurses
|
ncurses
|
||||||
srfi-6
|
srfi-6
|
||||||
|
inspect-exception
|
||||||
rt-modules)
|
rt-modules)
|
||||||
(files nuit-engine
|
(files nuit-engine
|
||||||
handle-fatal-error
|
handle-fatal-error
|
||||||
|
|
Loading…
Reference in New Issue