Remove unnecessary delay on non/defered interactive mode
This commit is contained in:
parent
0a6cb62169
commit
0dd024a09f
@ -77,6 +77,7 @@ func Run(options *Options) {
|
|||||||
pattern := patternBuilder([]rune(patternString))
|
pattern := patternBuilder([]rune(patternString))
|
||||||
|
|
||||||
looping := true
|
looping := true
|
||||||
|
eventBox.Unwatch(EVT_READ_NEW)
|
||||||
for looping {
|
for looping {
|
||||||
eventBox.Wait(func(events *Events) {
|
eventBox.Wait(func(events *Events) {
|
||||||
for evt, _ := range *events {
|
for evt, _ := range *events {
|
||||||
@ -87,7 +88,6 @@ func Run(options *Options) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
time.Sleep(COORDINATOR_DELAY)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
matches, cancelled := matcher.scan(MatchRequest{
|
matches, cancelled := matcher.scan(MatchRequest{
|
||||||
@ -116,6 +116,7 @@ func Run(options *Options) {
|
|||||||
// Event coordination
|
// Event coordination
|
||||||
reading := true
|
reading := true
|
||||||
ticks := 0
|
ticks := 0
|
||||||
|
eventBox.Watch(EVT_READ_NEW)
|
||||||
for {
|
for {
|
||||||
delay := true
|
delay := true
|
||||||
ticks += 1
|
ticks += 1
|
||||||
|
@ -9,10 +9,14 @@ type Events map[EventType]interface{}
|
|||||||
type EventBox struct {
|
type EventBox struct {
|
||||||
events Events
|
events Events
|
||||||
cond *sync.Cond
|
cond *sync.Cond
|
||||||
|
ignore map[EventType]bool
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewEventBox() *EventBox {
|
func NewEventBox() *EventBox {
|
||||||
return &EventBox{make(Events), sync.NewCond(&sync.Mutex{})}
|
return &EventBox{
|
||||||
|
events: make(Events),
|
||||||
|
cond: sync.NewCond(&sync.Mutex{}),
|
||||||
|
ignore: make(map[EventType]bool)}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (b *EventBox) Wait(callback func(*Events)) {
|
func (b *EventBox) Wait(callback func(*Events)) {
|
||||||
@ -30,8 +34,10 @@ func (b *EventBox) Set(event EventType, value interface{}) {
|
|||||||
b.cond.L.Lock()
|
b.cond.L.Lock()
|
||||||
defer b.cond.L.Unlock()
|
defer b.cond.L.Unlock()
|
||||||
b.events[event] = value
|
b.events[event] = value
|
||||||
|
if _, found := b.ignore[event]; !found {
|
||||||
b.cond.Broadcast()
|
b.cond.Broadcast()
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Unsynchronized; should be called within Wait routine
|
// Unsynchronized; should be called within Wait routine
|
||||||
func (events *Events) Clear() {
|
func (events *Events) Clear() {
|
||||||
@ -46,3 +52,19 @@ func (b *EventBox) Peak(event EventType) bool {
|
|||||||
_, ok := b.events[event]
|
_, ok := b.events[event]
|
||||||
return ok
|
return ok
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (b *EventBox) Watch(events ...EventType) {
|
||||||
|
b.cond.L.Lock()
|
||||||
|
defer b.cond.L.Unlock()
|
||||||
|
for _, event := range events {
|
||||||
|
delete(b.ignore, event)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (b *EventBox) Unwatch(events ...EventType) {
|
||||||
|
b.cond.L.Lock()
|
||||||
|
defer b.cond.L.Unlock()
|
||||||
|
for _, event := range events {
|
||||||
|
b.ignore[event] = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
51
src/eventbox_test.go
Normal file
51
src/eventbox_test.go
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
package fzf
|
||||||
|
|
||||||
|
import "testing"
|
||||||
|
|
||||||
|
func TestEventBox(t *testing.T) {
|
||||||
|
eb := NewEventBox()
|
||||||
|
|
||||||
|
// Wait should return immediately
|
||||||
|
ch := make(chan bool)
|
||||||
|
|
||||||
|
go func() {
|
||||||
|
eb.Set(EVT_READ_NEW, 10)
|
||||||
|
ch <- true
|
||||||
|
<-ch
|
||||||
|
eb.Set(EVT_SEARCH_NEW, 10)
|
||||||
|
eb.Set(EVT_SEARCH_NEW, 15)
|
||||||
|
eb.Set(EVT_SEARCH_NEW, 20)
|
||||||
|
eb.Set(EVT_SEARCH_PROGRESS, 30)
|
||||||
|
ch <- true
|
||||||
|
<-ch
|
||||||
|
eb.Set(EVT_SEARCH_FIN, 40)
|
||||||
|
ch <- true
|
||||||
|
<-ch
|
||||||
|
}()
|
||||||
|
|
||||||
|
count := 0
|
||||||
|
sum := 0
|
||||||
|
looping := true
|
||||||
|
for looping {
|
||||||
|
<-ch
|
||||||
|
eb.Wait(func(events *Events) {
|
||||||
|
for _, value := range *events {
|
||||||
|
switch val := value.(type) {
|
||||||
|
case int:
|
||||||
|
sum += val
|
||||||
|
looping = sum < 100
|
||||||
|
}
|
||||||
|
}
|
||||||
|
events.Clear()
|
||||||
|
})
|
||||||
|
ch <- true
|
||||||
|
count += 1
|
||||||
|
}
|
||||||
|
|
||||||
|
if count != 3 {
|
||||||
|
t.Error("Invalid number of events", count)
|
||||||
|
}
|
||||||
|
if sum != 100 {
|
||||||
|
t.Error("Invalid sum", sum)
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user