Using the default style helps with cursor visibility on many terminals.

This commit is contained in:
Tony Garnock-Jones 2014-12-26 19:38:01 -05:00
parent 578b759a2a
commit 45b89d9682
2 changed files with 22 additions and 18 deletions

View File

@ -16,6 +16,7 @@
tty-reset tty-reset
tty-goto tty-goto
tty-set-pen! tty-set-pen!
tty-default-pen
tty-pen tty-pen
tty-flush tty-flush
tty-next-key tty-next-key
@ -68,7 +69,7 @@
(define new-contents (for/vector ((row rows)) (vector-copy (vector-ref contents row)))) (define new-contents (for/vector ((row rows)) (vector-copy (vector-ref contents row))))
(screen rows columns cursor-row cursor-column pen new-contents)) (screen rows columns cursor-row cursor-column pen new-contents))
(define *pen-white-on-black* (pen ansi:color-white ansi:color-black #f #f)) (define tty-default-pen 'default)
(define *stdin-tty* #f) (define *stdin-tty* #f)
(define (stdin-tty) (define (stdin-tty)
@ -78,8 +79,8 @@
(tty (current-input-port) (tty (current-input-port)
(current-output-port) (current-output-port)
ansi:lex-lcd-input ansi:lex-lcd-input
(make-screen 24 80 *pen-white-on-black*) (make-screen 24 80 tty-default-pen)
(make-screen 24 80 *pen-white-on-black*))) (make-screen 24 80 tty-default-pen)))
(reset *stdin-tty*) (reset *stdin-tty*)
(plumber-add-flush! (current-plumber) (plumber-add-flush! (current-plumber)
(lambda (h) (lambda (h)
@ -112,22 +113,25 @@
;; (set! report (ansi:position-report 5 10)) ;; (set! report (ansi:position-report 5 10))
(define rows (ansi:position-report-row report)) (define rows (ansi:position-report-row report))
(define columns (ansi:position-report-column report)) (define columns (ansi:position-report-column report))
(set-pen tty *pen-white-on-black* #:force #t) (set-pen tty tty-default-pen #:force #t)
(clear tty) (clear tty)
(flush tty) (flush tty)
(set-tty-displayed-screen! tty (make-screen rows columns *pen-white-on-black*)) (set-tty-displayed-screen! tty (make-screen rows columns tty-default-pen))
(set-tty-pending-screen! tty (make-screen rows columns *pen-white-on-black*)) (set-tty-pending-screen! tty (make-screen rows columns tty-default-pen))
tty) tty)
(define (set-pen tty p #:force [force #f]) (define (set-pen tty p #:force [force #f])
(match-define (pen fgcolor bgcolor bold? italic?) p)
(when (or force (not (equal? p (screen-pen (tty-displayed-screen tty))))) (when (or force (not (equal? p (screen-pen (tty-displayed-screen tty)))))
(output tty (match p
(apply ansi:select-graphic-rendition [(pen fgcolor bgcolor bold? italic?)
`(,@(if bold? (list ansi:style-bold) (list)) (output tty
,@(if italic? (list ansi:style-italic/inverse) (list)) (apply ansi:select-graphic-rendition
,(ansi:style-text-color fgcolor) `(,@(if bold? (list ansi:style-bold) (list))
,(ansi:style-background-color bgcolor)))) ,@(if italic? (list ansi:style-italic/inverse) (list))
,(ansi:style-text-color fgcolor)
,(ansi:style-background-color bgcolor))))]
['default
(output tty (ansi:select-graphic-rendition ansi:style-normal))])
(set-screen-pen! (tty-displayed-screen tty) p)) (set-screen-pen! (tty-displayed-screen tty) p))
tty) tty)
@ -152,7 +156,7 @@
(define (delete-lines tty n) (define (delete-lines tty n)
(define s (tty-displayed-screen tty)) (define s (tty-displayed-screen tty))
(set-pen tty *pen-white-on-black*) (set-pen tty tty-default-pen)
(output tty (ansi:delete-lines n)) (output tty (ansi:delete-lines n))
(define blank-line (make-vector (screen-columns s) (cons (screen-pen s) 'empty))) (define blank-line (make-vector (screen-columns s) (cons (screen-pen s) 'empty)))
(vector-delete! (screen-contents s) (screen-cursor-row s) n blank-line) (vector-delete! (screen-contents s) (screen-cursor-row s) n blank-line)
@ -160,7 +164,7 @@
(define (insert-lines tty n) (define (insert-lines tty n)
(define s (tty-displayed-screen tty)) (define s (tty-displayed-screen tty))
(set-pen tty *pen-white-on-black*) (set-pen tty tty-default-pen)
(output tty (ansi:insert-lines n)) (output tty (ansi:insert-lines n))
(define blank-line (make-vector (screen-columns s) (cons (screen-pen s) 'empty))) (define blank-line (make-vector (screen-columns s) (cons (screen-pen s) 'empty)))
(vector-insert! (screen-contents s) (screen-cursor-row s) n blank-line) (vector-insert! (screen-contents s) (screen-cursor-row s) n blank-line)
@ -168,7 +172,7 @@
(define (delete-columns tty n) (define (delete-columns tty n)
(define s (tty-displayed-screen tty)) (define s (tty-displayed-screen tty))
(set-pen tty *pen-white-on-black*) (set-pen tty tty-default-pen)
(output tty (ansi:delete-characters n)) (output tty (ansi:delete-characters n))
(define blank-cell (cons (screen-pen s) 'empty)) (define blank-cell (cons (screen-pen s) 'empty))
(define line (vector-ref (screen-contents s) (screen-cursor-row s))) (define line (vector-ref (screen-contents s) (screen-cursor-row s)))
@ -240,7 +244,7 @@
(define (tty-clear-to-eol tty) (define (tty-clear-to-eol tty)
(define start-column (tty-cursor-column tty)) (define start-column (tty-cursor-column tty))
(define pen (screen-pen (tty-pending-screen tty))) (define pen (screen-pen (tty-pending-screen tty)))
(tty-set-pen! tty *pen-white-on-black*) (tty-set-pen! tty tty-default-pen)
(for ((i (- (tty-columns tty) (tty-cursor-column tty)))) (putc tty 'empty)) (for ((i (- (tty-columns tty) (tty-cursor-column tty)))) (putc tty 'empty))
(tty-set-pen! tty pen) (tty-set-pen! tty pen)
(tty-goto tty (tty-cursor-row tty) start-column) (tty-goto tty (tty-cursor-row tty) start-column)

View File

@ -49,7 +49,7 @@
new-top-of-window-pos)]))) new-top-of-window-pos)])))
(define (tty-body-style t is-active?) (define (tty-body-style t is-active?)
(tty-set-pen! t (pen color-white color-black #f #f))) (tty-set-pen! t tty-default-pen))
(define (tty-statusline-style t is-active?) (define (tty-statusline-style t is-active?)
(tty-set-pen! t (pen color-black color-white #f #f))) (tty-set-pen! t (pen color-black color-white #f #f)))