From 3f66f08b84238e745eb73fc0de5609f3c7fd8c3f Mon Sep 17 00:00:00 2001 From: neeshy <60193883+neeshy@users.noreply.github.com> Date: Tue, 19 Jan 2021 01:42:01 +0000 Subject: [PATCH] Exhaust queued entries in previewChan prior to calling preview script (#562) * Use ranged for loop over channel And rename variable "path" to "prev" * Exhaust queued entries in previewChan prior to calling preview script --- nav.go | 34 +++++++++++++++++++++++----------- 1 file changed, 23 insertions(+), 11 deletions(-) diff --git a/nav.go b/nav.go index 2b25fbf..b620c5e 100644 --- a/nav.go +++ b/nav.go @@ -460,23 +460,35 @@ func (nav *nav) position() { } func (nav *nav) previewLoop(ui *ui) { - var path string - for { - p, ok := <-nav.previewChan - if !ok { - return + var prev string + for path := range nav.previewChan { + var clear bool + if len(path) == 0 { + clear = true } - if len(p) != 0 { - win := ui.wins[len(ui.wins)-1] - nav.preview(p, win) - path = p - } else if len(gOpts.previewer) != 0 && len(gOpts.cleaner) != 0 && nav.volatilePreview { - cmd := exec.Command(gOpts.cleaner, path) + loop: + for { + select { + case path = <-nav.previewChan: + if len(path) == 0 { + clear = true + } + default: + break loop + } + } + if clear && len(gOpts.previewer) != 0 && len(gOpts.cleaner) != 0 && nav.volatilePreview { + cmd := exec.Command(gOpts.cleaner, prev) if err := cmd.Run(); err != nil { log.Printf("cleaning preview: %s", err) } nav.volatilePreview = false } + if len(path) != 0 { + win := ui.wins[len(ui.wins)-1] + nav.preview(path, win) + prev = path + } } }