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