From f401c42f9c22de9df7a40ee31727ff0eab5dd30e Mon Sep 17 00:00:00 2001 From: Junegunn Choi Date: Thu, 8 Jan 2015 22:07:04 +0900 Subject: [PATCH] Adjust initial coordinator delay --- src/core.go | 10 +++++++--- src/util.go | 13 +++++++++++++ 2 files changed, 20 insertions(+), 3 deletions(-) diff --git a/src/core.go b/src/core.go index b6f0857..5a81efa 100644 --- a/src/core.go +++ b/src/core.go @@ -7,7 +7,8 @@ import ( "time" ) -const COORDINATOR_DELAY time.Duration = 100 * time.Millisecond +const COORDINATOR_DELAY_MAX time.Duration = 100 * time.Millisecond +const COORDINATOR_DELAY_STEP time.Duration = 10 * time.Millisecond func initProcs() { runtime.GOMAXPROCS(runtime.NumCPU()) @@ -151,8 +152,11 @@ func Run(options *Options) { } } }) - if ticks > 3 && delay && reading { - time.Sleep(COORDINATOR_DELAY) + if delay && reading { + dur := DurWithin( + time.Duration(ticks)*COORDINATOR_DELAY_STEP, + 0, COORDINATOR_DELAY_MAX) + time.Sleep(dur) } } } diff --git a/src/util.go b/src/util.go index 2144e54..cc8d4f5 100644 --- a/src/util.go +++ b/src/util.go @@ -1,5 +1,7 @@ package fzf +import "time" + func Max(first int, items ...int) int { max := first for _, item := range items { @@ -19,3 +21,14 @@ func Min(first int, items ...int) int { } return min } + +func DurWithin( + val time.Duration, min time.Duration, max time.Duration) time.Duration { + if val < min { + return min + } + if val > max { + return max + } + return val +}