use a seperate goroutine/channel for quit
This commit is contained in:
parent
c9b4389c65
commit
1e0b558344
41
app.go
41
app.go
@ -9,8 +9,20 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type App struct {
|
type App struct {
|
||||||
ui *UI
|
ui *UI
|
||||||
nav *Nav
|
nav *Nav
|
||||||
|
quit chan bool
|
||||||
|
}
|
||||||
|
|
||||||
|
func newApp() *App {
|
||||||
|
ui := newUI()
|
||||||
|
nav := newNav(ui.wins[0].h)
|
||||||
|
quit := make(chan bool)
|
||||||
|
return &App{
|
||||||
|
ui: ui,
|
||||||
|
nav: nav,
|
||||||
|
quit: quit,
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func waitKey() error {
|
func waitKey() error {
|
||||||
@ -39,9 +51,8 @@ func waitKey() error {
|
|||||||
|
|
||||||
func (app *App) handleInp() {
|
func (app *App) handleInp() {
|
||||||
for {
|
for {
|
||||||
// exit check is done on the top just in case user quits
|
select {
|
||||||
// before input handling for some reason (e.g. in configuration file)
|
case <-app.quit:
|
||||||
if gExitFlag {
|
|
||||||
log.Print("bye!")
|
log.Print("bye!")
|
||||||
|
|
||||||
if gLastDirPath != "" {
|
if gLastDirPath != "" {
|
||||||
@ -60,18 +71,16 @@ func (app *App) handleInp() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
return
|
return
|
||||||
|
default:
|
||||||
|
e, c := app.ui.getExpr(app.nav)
|
||||||
|
if e == nil {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
for i := 0; i < c; i++ {
|
||||||
|
e.eval(app, nil)
|
||||||
|
}
|
||||||
|
app.ui.draw(app.nav)
|
||||||
}
|
}
|
||||||
e, c := app.ui.getExpr(app.nav)
|
|
||||||
if e == nil {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
for i := 0; i < c; i++ {
|
|
||||||
e.eval(app, nil)
|
|
||||||
}
|
|
||||||
if gExitFlag {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
app.ui.draw(app.nav)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -25,9 +25,7 @@ func client() {
|
|||||||
}
|
}
|
||||||
defer termbox.Close()
|
defer termbox.Close()
|
||||||
|
|
||||||
ui := newUI()
|
app := newApp()
|
||||||
nav := newNav(ui.wins[0].h)
|
|
||||||
app := &App{ui, nav}
|
|
||||||
|
|
||||||
app.ui.loadFile(app.nav)
|
app.ui.loadFile(app.nav)
|
||||||
|
|
||||||
|
6
eval.go
6
eval.go
@ -193,6 +193,7 @@ func (e *CallExpr) eval(app *App, args []string) {
|
|||||||
out, err := os.Create(gSelectionPath)
|
out, err := os.Create(gSelectionPath)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Printf("opening selection file: %s", err)
|
log.Printf("opening selection file: %s", err)
|
||||||
|
return
|
||||||
}
|
}
|
||||||
defer out.Close()
|
defer out.Close()
|
||||||
|
|
||||||
@ -211,7 +212,8 @@ func (e *CallExpr) eval(app *App, args []string) {
|
|||||||
log.Printf("writing selection file: %s", err)
|
log.Printf("writing selection file: %s", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
gExitFlag = true
|
go func() { app.quit <- true }()
|
||||||
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -219,7 +221,7 @@ func (e *CallExpr) eval(app *App, args []string) {
|
|||||||
cmd.eval(app, e.args)
|
cmd.eval(app, e.args)
|
||||||
}
|
}
|
||||||
case "quit":
|
case "quit":
|
||||||
gExitFlag = true
|
go func() { app.quit <- true }()
|
||||||
case "bot":
|
case "bot":
|
||||||
app.nav.bot()
|
app.nav.bot()
|
||||||
app.ui.loadFile(app.nav)
|
app.ui.loadFile(app.nav)
|
||||||
|
Loading…
Reference in New Issue
Block a user