From 2a669e9a1754c71fb88c6a316378ee708d710efd Mon Sep 17 00:00:00 2001 From: Junegunn Choi <junegunn.c@gmail.com> Date: Sun, 22 Jan 2017 03:19:50 +0900 Subject: [PATCH] Clear lines even when background color is not set Also revert the workaround in Vim plugin introduced in fa7c897. Related: #814 --- plugin/fzf.vim | 2 +- src/tui/light.go | 12 +++++++++--- 2 files changed, 10 insertions(+), 4 deletions(-) diff --git a/plugin/fzf.vim b/plugin/fzf.vim index 8778c785..4064a559 100644 --- a/plugin/fzf.vim +++ b/plugin/fzf.vim @@ -430,7 +430,7 @@ function! s:execute(dict, command, use_height, temps) abort endif if a:use_height let stdin = has_key(a:dict, 'source') ? '' : '< /dev/tty' - call system(printf('tput cup %d > /dev/tty; tput cnorm > /dev/tty; tput el > /dev/tty; %s %s 2> /dev/tty', &lines, command, stdin)) + call system(printf('tput cup %d > /dev/tty; tput cnorm > /dev/tty; %s %s 2> /dev/tty', &lines, command, stdin)) else execute 'silent !'.command endif diff --git a/src/tui/light.go b/src/tui/light.go index 075fd6bc..17cc6aec 100644 --- a/src/tui/light.go +++ b/src/tui/light.go @@ -185,11 +185,10 @@ func (r *LightRenderer) Init() { _, x := r.findOffset() if x > 0 { r.upOneLine = true - r.stderr("\n") + r.makeSpace() } for i := 1; i < r.MaxY(); i++ { - r.stderr("\n") - r.csi("G") + r.makeSpace() } if r.mouse { @@ -197,12 +196,19 @@ func (r *LightRenderer) Init() { } r.csi(fmt.Sprintf("%dA", r.MaxY()-1)) r.csi("G") + r.csi("K") // r.csi("s") if r.mouse { r.yoffset, _ = r.findOffset() } } +func (r *LightRenderer) makeSpace() { + r.stderr("\n") + r.csi("G") + r.csi("K") +} + func (r *LightRenderer) move(y int, x int) { // w.csi("u") if r.y < y { -- GitLab