summaryrefslogtreecommitdiff
path: root/commands/msg/reply.go
diff options
context:
space:
mode:
authorReto Brunner <reto@labrat.space>2020-05-04 19:17:23 +0200
committerDrew DeVault <sir@cmpwn.com>2020-05-06 10:00:36 -0400
commit8f2e5055eeb7e8058b637ab6cff6ff5f44da487b (patch)
tree61a743aba3aaf05b3d73f53caabef485a5710b99 /commands/msg/reply.go
parentd1600e4666e9efdb3ae45ef2cc01182950a41bb5 (diff)
downloadaerc-8f2e5055eeb7e8058b637ab6cff6ff5f44da487b.zip
msg/reply: Deduplicate TO: and CC:
If a recipient is already in TO:, there's no need to also put them in CC:
Diffstat (limited to 'commands/msg/reply.go')
-rw-r--r--commands/msg/reply.go12
1 files changed, 12 insertions, 0 deletions
diff --git a/commands/msg/reply.go b/commands/msg/reply.go
index 291fc4b..74f0097 100644
--- a/commands/msg/reply.go
+++ b/commands/msg/reply.go
@@ -89,8 +89,20 @@ func (reply) Execute(aerc *widgets.Aerc, args []string) error {
to = append(to, fmt.Sprintf("<%s@%s>", addr.Mailbox, addr.Host))
}
}
+ isMainRecipient := func(a *models.Address) bool {
+ for _, ta := range toList {
+ if ta.Mailbox == a.Mailbox && ta.Host == a.Host {
+ return true
+ }
+ }
+ return false
+ }
if replyAll {
for _, addr := range msg.Envelope.Cc {
+ //dedupe stuff already in the to: header, no need to repeat
+ if isMainRecipient(addr) {
+ continue
+ }
cc = append(cc, addr.Format())
}
for _, addr := range msg.Envelope.To {