diff options
| author | Glenn Morris <rgm@gnu.org> | 2008-04-01 04:10:09 +0000 | 
|---|---|---|
| committer | Glenn Morris <rgm@gnu.org> | 2008-04-01 04:10:09 +0000 | 
| commit | c899d5e37a6dd5ab33bc9c19280715aa02b04643 (patch) | |
| tree | 2e9e81633b9aebe37c5bce33f67558441ee78b7f /lisp | |
| parent | eff756afa6d3b292aee7e32a76ebc0aab0d34845 (diff) | |
| download | emacs-c899d5e37a6dd5ab33bc9c19280715aa02b04643.tar.gz | |
(calendar-make-temp-face): New function.
(mark-visible-calendar-date): Use it.
Diffstat (limited to 'lisp')
| -rw-r--r-- | lisp/ChangeLog | 4 | ||||
| -rw-r--r-- | lisp/calendar/calendar.el | 50 | 
2 files changed, 32 insertions, 22 deletions
| diff --git a/lisp/ChangeLog b/lisp/ChangeLog index 1d7f1108dd8..b2ec3dc151a 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,5 +1,9 @@  2008-04-01  Glenn Morris  <rgm@gnu.org> +	* calendar/calendar.el (calendar-make-temp-face): New function. +	(mark-visible-calendar-date): +	* calendar/diary-lib.el (fancy-diary-display): Use it. +  	* vc-hooks.el (vc-responsible-backend): Declare as function.  	* calendar/calendar.el (calendar-nongregorian-visible-p): New function. diff --git a/lisp/calendar/calendar.el b/lisp/calendar/calendar.el index 61b65130864..fce43de2cac 100644 --- a/lisp/calendar/calendar.el +++ b/lisp/calendar/calendar.el @@ -2387,6 +2387,31 @@ Returns the corresponding Gregorian date."     (= (extract-calendar-day date1) (extract-calendar-day date2))     (= (extract-calendar-year date1) (extract-calendar-year date2)))) +(defun calendar-make-temp-face (attrlist) +  "Return a temporary face based on the attributes in ATTRLIST. +ATTRLIST is a list with elements of the form :face face :foreground color." +  (let ((temp-face (make-symbol +                    (mapconcat (lambda (sym) +                                 (cond +                                  ((symbolp sym) (symbol-name sym)) +                                  ((numberp sym) (number-to-string sym)) +                                  (t sym))) +                               attrlist ""))) +        (faceinfo attrlist)) +  (make-face temp-face) +  ;; Remove :face info, copy into temp-face. +  (while (setq faceinfo (memq :face faceinfo)) +    ;; FIXME is there any point doing this multiple times, or could we +    ;; just take the last? +    (condition-case nil +        (copy-face (intern-soft (cadr faceinfo)) temp-face) +      (error nil)) +    (setq faceinfo (cddr faceinfo))) +  (setq attrlist (delq nil attrlist)) +  ;; Apply the font aspects. +  (apply 'set-face-attribute temp-face nil attrlist) +  temp-face)) +  (defun mark-visible-calendar-date (date &optional mark)    "Mark DATE in the calendar window with MARK.  MARK is a single-character string, a list of face attributes/values, or a face. @@ -2410,28 +2435,9 @@ MARK defaults to `diary-entry-marker'."              (overlay-put               (make-overlay (1+ (point)) (+ 2 (point))) 'display mark))             (t                           ; attr list -            (let ((temp-face -                   (make-symbol -                    (apply 'concat "temp-" -                           (mapcar (lambda (sym) -                                     (cond -                                      ((symbolp sym) (symbol-name sym)) -                                      ((numberp sym) (number-to-string sym)) -                                      (t sym))) -                                   mark)))) -                  (faceinfo mark)) -              (make-face temp-face) -              ;; Remove :face info from mark, copy the face info into temp-face. -              (while (setq faceinfo (memq :face faceinfo)) -                ;; FIXME not read. -                (copy-face (read (nth 1 faceinfo)) temp-face) -                (setcar faceinfo nil) -                (setcar (cdr faceinfo) nil)) -              (setq mark (delq nil mark)) -              ;; Apply the font aspects. -              (apply 'set-face-attribute temp-face nil mark) -              (overlay-put -               (make-overlay (1- (point)) (1+ (point))) 'face temp-face)))))))) +            (overlay-put +             (make-overlay (1- (point)) (1+ (point))) 'face +             (calendar-make-temp-face mark))))))))  (defun calendar-star-date ()    "Replace the date under the cursor in the calendar window with asterisks. | 
