Gnus development mailing list
 help / color / mirror / Atom feed
From: Ted Zlatanov <tzz@lifelogs.com>
To: ding@gnus.org
Subject: Re: special face for marks
Date: Thu, 29 Sep 2011 04:41:55 -0500	[thread overview]
Message-ID: <878vp7lm70.fsf@lifelogs.com> (raw)
In-Reply-To: <878vrunop4.fsf@yun.yagibdah.de>

On Tue, 19 Jul 2011 19:51:51 +0200 lee <lee@yun.yagibdah.de> wrote: 

l> (defun gnus-user-format-function-M (header)
l>   (let ( (str "|") )
l>     (if (equal gnus-tmp-unread gnus-unread-mark)
l> 	(setq str (concat str "U") )  )
l>     (if (equal gnus-tmp-read gnus-read-mark)
l> 	(setq str (concat str "R") )  )
l>     (if (equal gnus-tmp-del gnus-del-mark)
l> 	(setq str (concat "d" str) )  )
l>     (if (equal gnus-tmp-read gnus-read-mark)
l>     	(setq str (concat "R" str) )  )
l>     (if (equal gnus-tmp-ancient gnus-ancient-mark)
l>     	(setq str (concat "O" str) )  )
l>     (if (equal gnus-tmp-killed gnus-killed-mark)
l>     	(setq str (concat "K" str) )  )
l>     (if (equal gnus-tmp-kill-file gnus-kill-file-mark)
l>     	(setq str (concat "X" str) )  )
l>     (if (equal gnus-tmp-low-score gnus-low-score-mark)
l>     	(setq str (concat "Y" str) )  )
l>     (if (equal gnus-tmp-catchup gnus-catchup-mark)
l>     	(setq str (concat "C" str) )  )
l>     (if (equal gnus-tmp-cancled gnus-cancled-mark)
l>     	(setq str (concat "G" str) )  )
l>     (if (equal gnus-tmp-sparse gnus-sparse-mark)
l>     	(setq str (concat "Q" str) )  )
l>     (if (equal gnus-tmp-duplicate gnus-duplicate-mark)
l> 	(setq str (concat "M" str) )  )
l>     (if (equal gnus-tmp-expirable gnus-expirable-mark)
l> 	(setq str (concat "E" str) )  )
l>     )
l>   )

Without commenting on the marks themselves, just a note on the Lisp: it
may be cleaner to write it like this:

#+begin_src lisp
(defun gnus-user-format-function-M (header)
  (concat "|"
          (mapconcat (lambda (mark-info)
                       (let* ((s (car mark-info))
                              (tmp (intern (format "gnus-tmp-%s" s)))
                              (mark (intern (format "gnus-%s-mark") s)))
                         (when (equal (symbol-value tmp)
                                      (symbol-value mark))
                           (cdr mark-info))))
                     '((unread . "U")
                       (read . "R")
                       ;; ... the rest
                       )
                     "")))

#+end_src

I'm sure there's better ways but at least the repetition should be avoided.

Ted




      reply	other threads:[~2011-09-29  9:41 UTC|newest]

Thread overview: 26+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2011-05-23 18:04 setting face in gnus-user-format-function-x Peter Münster
2011-05-24  6:18 ` Reiner Steib
2011-05-25 13:38   ` Peter Münster
2011-05-26  6:37     ` Reiner Steib
2011-05-27  8:26       ` Peter Münster
2011-05-27  9:44         ` Michael Piotrowski
2011-05-30 18:10 ` Lars Magne Ingebrigtsen
2011-05-31  7:06   ` Peter Münster
2011-06-07 16:24     ` Michael Piotrowski
2011-06-23  8:47       ` Peter Münster
2011-06-26 10:06         ` Lars Magne Ingebrigtsen
2011-06-27 12:46           ` Peter Münster
2011-06-30  2:23             ` Lars Magne Ingebrigtsen
2011-06-30  5:14               ` Peter Münster
2011-06-30 22:03                 ` Lars Magne Ingebrigtsen
2011-07-13  9:15                   ` setting face in gnus-user-format-function-x (solved) Peter Münster
2011-07-13 11:35                     ` Peter Münster
2011-07-14  8:12                     ` Peter Münster
2011-07-14 19:09                       ` Reiner Steib
2011-07-11 16:57         ` setting face in gnus-user-format-function-x Michael Piotrowski
2011-07-13  7:36           ` Peter Münster
2011-07-18 21:09   ` special face for marks (was: setting face in gnus-user-format-function-x) Peter Münster
2011-07-19 10:09     ` special face for marks lee
2011-07-19 10:58       ` Peter Münster
2011-07-19 17:51         ` lee
2011-09-29  9:41           ` Ted Zlatanov [this message]

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=878vp7lm70.fsf@lifelogs.com \
    --to=tzz@lifelogs.com \
    --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).