From: Nikolaus Rath <Nikolaus@rath.org>
To: ding@gnus.org, 20672@debbugs.gnu.org
Subject: [PATCH] Support hiding deleted IMAP messages (v3)
Date: Thu, 02 Jul 2015 19:17:28 -0700 [thread overview]
Message-ID: <87pp4a9e87.fsf@vostro.rath.org> (raw)
[-- Attachment #1: Type: text/plain, Size: 768 bytes --]
Hello,
This patch introduces a new server variable, nnimap-hide-deleted. If
non-nil, articles with the IMAP \Deleted flag will not be included in
Summary buffers.
This is intended to increase operability with other IMAP mailreaders and
the new 'never value for nnimap-expunge (see patch in bug 20670).
Changes in v2:
* Take into account that server may send the UID, FLAGS and RFC822.SIZE
response data items in arbitrary order
Changes in v3:
* Made first line of docstring a complete sentence.
Thanks for considering,
-Nikolaus
--
GPG encrypted emails preferred. Key id: 0xD113FCAC3C4E599F
Fingerprint: ED31 791B 2C5C 1613 AF38 8B8A D113 FCAC 3C4E 599F
»Time flies like an arrow, fruit flies like a Banana.«
[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: nnimap_hide_deleted_v3.diff --]
[-- Type: text/x-diff, Size: 2975 bytes --]
diff --git a/nnimap.el b/nnimap.el
--- a/nnimap.el
+++ b/nnimap.el
@@ -135,6 +135,11 @@
likely value would be \"text/\" to automatically fetch all
textual parts.")
+(defvoo nnimap-hide-deleted nil
+ "Whether to hide deletes messages in summary buffer.
+If non-nil, articles flagged as deleted (using the IMAP
+\\Delete flag) will not be shown in the Summary buffer.")
+
(defgroup nnimap nil
"IMAP for Gnus."
:group 'gnus)
@@ -181,7 +186,7 @@
(nnimap-find-process-buffer nntp-server-buffer))
(defun nnimap-header-parameters ()
- (format "(UID RFC822.SIZE BODYSTRUCTURE %s)"
+ (format "(UID FLAGS RFC822.SIZE BODYSTRUCTURE %s)"
(format
(if (nnimap-ver4-p)
"BODY.PEEK[HEADER.FIELDS %s]"
@@ -240,12 +245,19 @@
(and (re-search-forward "UID \\([0-9]+\\)" (line-end-position)
t)
(match-string 1)))
- (setq lines nil)
+ (beginning-of-line)
+ (setq flags
+ (and (re-search-forward "FLAGS (\\([^)]+\\))"
+ (line-end-position)
+ t)
+ (split-string (match-string 1))))
+ (beginning-of-line)
(setq size
(and (re-search-forward "RFC822.SIZE \\([0-9]+\\)"
(line-end-position)
t)
(match-string 1)))
+ (setq lines nil)
(beginning-of-line)
(when (search-forward "BODYSTRUCTURE" (line-end-position) t)
(let ((structure (ignore-errors
@@ -259,20 +271,25 @@
(equal (upcase (nth 1 structure)) "RFC822"))
(nth 9 structure)
(nth 7 structure)))))
- (delete-region (line-beginning-position) (line-end-position))
- (insert (format "211 %s Article retrieved." article))
- (forward-line 1)
- (when size
- (insert (format "Chars: %s\n" size)))
- (when lines
- (insert (format "Lines: %s\n" lines)))
- ;; Most servers have a blank line after the headers, but
- ;; Davmail doesn't.
- (unless (re-search-forward "^\r$\\|^)\r?$" nil t)
- (goto-char (point-max)))
- (delete-region (line-beginning-position) (line-end-position))
- (insert ".")
- (forward-line 1)))))
+ (if (and nnimap-hide-deleted
+ (member "\\Deleted" flags))
+ (delete-region (line-beginning-position)
+ (or (re-search-forward "^\r$\\|^)\r?$" nil t)
+ (point-max)))
+ (delete-region (line-beginning-position) (line-end-position))
+ (insert (format "211 %s Article retrieved." article))
+ (forward-line 1)
+ (when size
+ (insert (format "Chars: %s\n" size)))
+ (when lines
+ (insert (format "Lines: %s\n" lines)))
+ ;; Most servers have a blank line after the headers, but
+ ;; Davmail doesn't.
+ (unless (re-search-forward "^\r$\\|^)\r?$" nil t)
+ (goto-char (point-max)))
+ (delete-region (line-beginning-position) (line-end-position))
+ (insert ".")
+ (forward-line 1))))))
(defun nnimap-unfold-quoted-lines ()
;; Unfold quoted {number} strings.
next reply other threads:[~2015-07-03 2:17 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-07-03 2:17 Nikolaus Rath [this message]
2015-07-03 13:44 ` Greg Troxel
2015-07-03 19:02 ` Nikolaus Rath
2015-07-03 23:09 ` Greg Troxel
2015-07-04 1:53 ` Nikolaus Rath
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87pp4a9e87.fsf@vostro.rath.org \
--to=nikolaus@rath.org \
--cc=20672@debbugs.gnu.org \
--cc=ding@gnus.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).