From f76bf30f65c96e18d98c9a0df98353b3e4fad136 Mon Sep 17 00:00:00 2001 From: Juris Arturs Majors <32071671+JurisMajors@users.noreply.github.com> Date: Mon, 2 Dec 2019 12:27:58 +0100 Subject: [PATCH] Asynchronous delete (#238) * Asynchronous deletion, similar to moving * Reversed some sloppy new lines from previous commit * Move delete operations to delete.go * Simplify to use RemoveAll before * Send errors directly to ui.exprChan directly --- app.go | 5 +++++ eval.go | 2 +- nav.go | 22 ++++++++++++++++++---- 3 files changed, 24 insertions(+), 5 deletions(-) diff --git a/app.go b/app.go index 09dbeb3..35e718e 100644 --- a/app.go +++ b/app.go @@ -179,6 +179,11 @@ func (app *app) loop() { continue } + if app.nav.deleting { + app.ui.echoerr("quit: delete operation in progress") + continue + } + log.Print("bye!") if err := app.writeHistory(); err != nil { diff --git a/eval.go b/eval.go index 2d0ade2..814a00e 100644 --- a/eval.go +++ b/eval.go @@ -470,7 +470,7 @@ func insert(app *app, arg string) { normal(app) if arg == "y" { - if err := app.nav.del(); err != nil { + if err := app.nav.del(app.ui); err != nil { app.ui.echoerrf("delete: %s", err) return } diff --git a/nav.go b/nav.go index 1921387..e55c6c6 100644 --- a/nav.go +++ b/nav.go @@ -248,6 +248,7 @@ type nav struct { moveCount int moveTotal int moveUpdate int + deleting bool copyBytesChan chan int64 copyTotalChan chan int64 moveCountChan chan int @@ -775,16 +776,29 @@ func (nav *nav) paste(ui *ui) error { return nil } -func (nav *nav) del() error { +func (nav *nav) del(ui *ui) error { list, err := nav.currFileOrSelections() if err != nil { return err } - for _, path := range list { - if err := os.RemoveAll(path); err != nil { - return err + go func() { + echo := &callExpr{"echoerr", []string{""}, 1} + errCount := 0 + nav.deleting = true + + for _, path := range list { + if err := os.RemoveAll(path); err != nil { + errCount++ + echo.args[0] = fmt.Sprintf("[%d] %s", errCount, err) + ui.exprChan <- echo + } } + nav.deleting = false + }() + + if err := remote("send sync"); err != nil { + return fmt.Errorf("delete: %s", err) } return nil