summary refs log tree commit diff stats
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2019-05-14 16:55:50 -0400
committerDrew DeVault <sir@cmpwn.com>2019-05-14 16:55:50 -0400
commit2e5ae1946bb3f55d00db5a1deebde2c84826ebf6 (patch)
treed2fe5c254167162313feddd2bcfc4ca021d54cdf
parent07138146a01d802e4d1b5a7d0ccf4601d89eeef8 (diff)
downloadaerc-2e5ae1946bb3f55d00db5a1deebde2c84826ebf6.tar.gz
Implement move, mv commands
-rw-r--r--commands/account/move.go38
-rw-r--r--lib/msgstore.go27
-rw-r--r--worker/types/messages.go6
3 files changed, 65 insertions, 6 deletions
diff --git a/commands/account/move.go b/commands/account/move.go
new file mode 100644
index 0000000..f84427e
--- /dev/null
+++ b/commands/account/move.go
@@ -0,0 +1,38 @@
+package account
+
+import (
+	"errors"
+	"time"
+
+	"github.com/gdamore/tcell"
+
+	"git.sr.ht/~sircmpwn/aerc2/widgets"
+	"git.sr.ht/~sircmpwn/aerc2/worker/types"
+)
+
+func init() {
+	register("mv", Move)
+	register("move", Move)
+}
+
+func Move(aerc *widgets.Aerc, args []string) error {
+	if len(args) != 2 {
+		return errors.New("Usage: mv <folder>")
+	}
+	acct := aerc.SelectedAccount()
+	if acct == nil {
+		return errors.New("No account selected")
+	}
+	msg := acct.Messages().Selected()
+	store := acct.Messages().Store()
+	store.Move([]uint32{msg.Uid}, args[1], func(msg types.WorkerMessage) {
+		switch msg := msg.(type) {
+		case *types.Done:
+			aerc.PushStatus("Messages moved.", 10*time.Second)
+		case *types.Error:
+			aerc.PushStatus(" "+msg.Error.Error(), 10*time.Second).
+				Color(tcell.ColorDefault, tcell.ColorRed)
+		}
+	})
+	return nil
+}
diff --git a/lib/msgstore.go b/lib/msgstore.go
index c4f5326..bd34789 100644
--- a/lib/msgstore.go
+++ b/lib/msgstore.go
@@ -246,3 +246,30 @@ func (store *MessageStore) Copy(uids []uint32, dest string,
 		Uids:        set,
 	}, cb)
 }
+
+func (store *MessageStore) Move(uids []uint32, dest string,
+	cb func(msg types.WorkerMessage)) {
+	store.Lock()
+
+	var set imap.SeqSet
+	for _, uid := range uids {
+		set.AddNum(uid)
+		store.Deleted[uid] = nil
+	}
+
+	store.Unlock()
+
+	store.worker.PostAction(&types.CopyMessages{
+		Destination: dest,
+		Uids:        set,
+	}, func(msg types.WorkerMessage) {
+		switch msg.(type) {
+		case *types.Error:
+			cb(msg)
+		case *types.Done:
+			store.worker.PostAction(&types.DeleteMessages{Uids: set}, cb)
+		}
+	})
+
+	store.update()
+}
diff --git a/worker/types/messages.go b/worker/types/messages.go
index fdd3263..e97ae02 100644
--- a/worker/types/messages.go
+++ b/worker/types/messages.go
@@ -103,12 +103,6 @@ type CopyMessages struct {
 	Uids        imap.SeqSet
 }
 
-type MoveMessages struct {
-	Message
-	Destination string
-	Uids        imap.SeqSet
-}
-
 // Messages
 
 type CertificateApprovalRequest struct {