annotate lisp/net/newsticker-ticker.el @ 95874:eafbd7a5c9be

Update Back-Cover Text as per maintain.info.
author Glenn Morris <rgm@gnu.org>
date Fri, 13 Jun 2008 04:20:28 +0000
parents 91e240b4d487
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
95678
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
1 ;; newsticker-ticker.el --- modeline ticker for newsticker.
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
2
95767
efe53e2a05b0 Correct copyright years to reflect the original newsticker.el from
Glenn Morris <rgm@gnu.org>
parents: 95684
diff changeset
3 ;; Copyright (C) 2003, 2004, 2005, 2006, 2007, 2008
efe53e2a05b0 Correct copyright years to reflect the original newsticker.el from
Glenn Morris <rgm@gnu.org>
parents: 95684
diff changeset
4 ;; Free Software Foundation, Inc.
95678
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
5
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
6 ;; Author: Ulf Jasper <ulf.jasper@web.de>
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
7 ;; Filename: newsticker-ticker.el
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
8 ;; URL: http://www.nongnu.org/newsticker
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
9 ;; Keywords: News, RSS, Atom
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
10 ;; Time-stamp: "7. Juni 2008, 15:12:27 (ulf)"
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
11
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
12 ;; ======================================================================
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
13
95767
efe53e2a05b0 Correct copyright years to reflect the original newsticker.el from
Glenn Morris <rgm@gnu.org>
parents: 95684
diff changeset
14 ;; This file is part of GNU Emacs.
efe53e2a05b0 Correct copyright years to reflect the original newsticker.el from
Glenn Morris <rgm@gnu.org>
parents: 95684
diff changeset
15
95678
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
16 ;; GNU Emacs is free software: you can redistribute it and/or modify
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
17 ;; it under the terms of the GNU General Public License as published by
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
18 ;; the Free Software Foundation, either version 3 of the License, or
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
19 ;; (at your option) any later version.
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
20
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
21 ;; GNU Emacs is distributed in the hope that it will be useful,
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
22 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
23 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
24 ;; GNU General Public License for more details.
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
25
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
26 ;; You should have received a copy of the GNU General Public License
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
27 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
28
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
29 ;; ======================================================================
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
30
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
31 ;;; Commentary:
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
32
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
33 ;; See newsticker.el
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
34
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
35 ;; ======================================================================
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
36 ;;; Code:
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
37
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
38 (require 'newsticker-backend)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
39
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
40 (defvar newsticker--ticker-timer nil
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
41 "Timer for newsticker ticker.")
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
42
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
43 ;;;###autoload
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
44 (defun newsticker-ticker-running-p ()
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
45 "Check whether newsticker's actual ticker is running.
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
46 Return t if ticker is running, nil otherwise. Newsticker is
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
47 considered to be running if the newsticker timer list is not
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
48 empty."
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
49 (timerp newsticker--ticker-timer))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
50
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
51 ;; customization group ticker
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
52 (defgroup newsticker-ticker nil
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
53 "Settings for the headline ticker."
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
54 :group 'newsticker)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
55
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
56 (defun newsticker--set-customvar-ticker (symbol value)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
57 "Set newsticker-variable SYMBOL value to VALUE.
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
58 Calls all actions which are necessary in order to make the new
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
59 value effective."
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
60 (if (or (not (boundp symbol))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
61 (equal (symbol-value symbol) value))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
62 (set symbol value)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
63 ;; something must have changed -- restart ticker
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
64 (when (newsticker-running-p)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
65 (message "Restarting ticker")
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
66 (newsticker-stop-ticker)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
67 (newsticker--ticker-text-setup)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
68 (newsticker-start-ticker)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
69 (message ""))))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
70
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
71 (defcustom newsticker-ticker-interval
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
72 0.3
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
73 "Time interval for displaying news items in the echo area (seconds).
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
74 If equal or less than 0 no messages are shown in the echo area. For
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
75 smooth display (see `newsticker-scroll-smoothly') a value of 0.3 seems
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
76 reasonable. For non-smooth display a value of 10 is a good starting
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
77 point."
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
78 :type 'number
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
79 :set 'newsticker--set-customvar-ticker
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
80 :group 'newsticker-ticker)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
81
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
82 (defcustom newsticker-scroll-smoothly
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
83 t
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
84 "Decides whether to flash or scroll news items.
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
85 If t the news headlines are scrolled (more-or-less) smoothly in the echo
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
86 area. If nil one headline after another is displayed in the echo area.
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
87 The variable `newsticker-ticker-interval' determines how fast this
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
88 display moves/changes and whether headlines are shown in the echo area
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
89 at all. If you change `newsticker-scroll-smoothly' you should also change
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
90 `newsticker-ticker-interval'."
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
91 :type 'boolean
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
92 :group 'newsticker-ticker)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
93
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
94 (defcustom newsticker-hide-immortal-items-in-echo-area
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
95 t
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
96 "Decides whether to show immortal/non-expiring news items in the ticker.
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
97 If t the echo area will not show immortal items. See also
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
98 `newsticker-hide-old-items-in-echo-area'."
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
99 :type 'boolean
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
100 :set 'newsticker--set-customvar-ticker
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
101 :group 'newsticker-ticker)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
102
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
103 (defcustom newsticker-hide-old-items-in-echo-area
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
104 t
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
105 "Decides whether to show only the newest news items in the ticker.
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
106 If t the echo area will show only new items, i.e. only items which have
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
107 been added between the last two retrievals."
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
108 :type 'boolean
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
109 :set 'newsticker--set-customvar-ticker
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
110 :group 'newsticker-ticker)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
111
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
112 (defcustom newsticker-hide-obsolete-items-in-echo-area
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
113 t
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
114 "Decides whether to show obsolete items items in the ticker.
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
115 If t the echo area will not show obsolete items. See also
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
116 `newsticker-hide-old-items-in-echo-area'."
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
117 :type 'boolean
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
118 :set 'newsticker--set-customvar-ticker
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
119 :group 'newsticker-ticker)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
120
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
121 (defun newsticker--display-tick ()
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
122 "Called from the display timer.
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
123 This function calls a display function, according to the variable
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
124 `newsticker-scroll-smoothly'."
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
125 (if newsticker-scroll-smoothly
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
126 (newsticker--display-scroll)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
127 (newsticker--display-jump)))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
128
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
129 (defsubst newsticker--echo-area-clean-p ()
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
130 "Check whether somebody is using the echo area / minibuffer.
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
131 Return t if echo area and minibuffer are unused."
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
132 (not (or (active-minibuffer-window)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
133 (and (current-message)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
134 (not (string= (current-message)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
135 newsticker--prev-message))))))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
136
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
137 (defun newsticker--display-jump ()
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
138 "Called from the display timer.
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
139 This function displays the next ticker item in the echo area, unless
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
140 there is another message displayed or the minibuffer is active."
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
141 (let ((message-log-max nil));; prevents message text from being logged
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
142 (when (newsticker--echo-area-clean-p)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
143 (setq newsticker--item-position (1+ newsticker--item-position))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
144 (when (>= newsticker--item-position (length newsticker--item-list))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
145 (setq newsticker--item-position 0))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
146 (setq newsticker--prev-message
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
147 (nth newsticker--item-position newsticker--item-list))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
148 (message "%s" newsticker--prev-message))))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
149
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
150 (defun newsticker--display-scroll ()
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
151 "Called from the display timer.
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
152 This function scrolls the ticker items in the echo area, unless
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
153 there is another message displayed or the minibuffer is active."
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
154 (when (newsticker--echo-area-clean-p)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
155 (let* ((width (- (frame-width) 1))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
156 (message-log-max nil);; prevents message text from being logged
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
157 (i newsticker--item-position)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
158 subtext
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
159 (s-text newsticker--scrollable-text)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
160 (l (length s-text)))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
161 ;; don't show anything if there is nothing to show
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
162 (unless (< (length s-text) 1)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
163 ;; repeat the ticker string if it is shorter than frame width
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
164 (while (< (length s-text) width)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
165 (setq s-text (concat s-text s-text)))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
166 ;; get the width of the printed string
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
167 (setq l (length s-text))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
168 (cond ((< i (- l width))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
169 (setq subtext (substring s-text i (+ i width))))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
170 (t
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
171 (setq subtext (concat
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
172 (substring s-text i l)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
173 (substring s-text 0 (- width (- l i)))))))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
174 ;; Take care of multibyte strings, for which (string-width) is
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
175 ;; larger than (length).
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
176 ;; Actually, such strings may be smaller than (frame-width)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
177 ;; because return values of (string-width) are too large:
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
178 ;; (string-width "<japanese character>") => 2
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
179 (let ((t-width (1- (length subtext))))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
180 (while (> (string-width subtext) width)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
181 (setq subtext (substring subtext 0 t-width))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
182 (setq t-width (1- t-width))))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
183 ;; show the ticker text and save current position
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
184 (message "%s" subtext)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
185 (setq newsticker--prev-message subtext)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
186 (setq newsticker--item-position (1+ i))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
187 (when (>= newsticker--item-position l)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
188 (setq newsticker--item-position 0))))))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
189
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
190 ;;;###autoload
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
191 (defun newsticker-start-ticker ()
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
192 "Start newsticker's ticker (but not the news retrieval).
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
193 Start display timer for the actual ticker if wanted and not
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
194 running already."
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
195 (interactive)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
196 (if (and (> newsticker-ticker-interval 0)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
197 (not newsticker--ticker-timer))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
198 (setq newsticker--ticker-timer
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
199 (run-at-time newsticker-ticker-interval
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
200 newsticker-ticker-interval
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
201 'newsticker--display-tick))))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
202
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
203 (defun newsticker-stop-ticker ()
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
204 "Stop newsticker's ticker (but not the news retrieval)."
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
205 (interactive)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
206 (when newsticker--ticker-timer
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
207 (cancel-timer newsticker--ticker-timer)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
208 (setq newsticker--ticker-timer nil)))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
209
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
210 ;; ======================================================================
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
211 ;;; Manipulation of ticker text
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
212 ;; ======================================================================
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
213 (defun newsticker--ticker-text-setup ()
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
214 "Build the ticker text which is scrolled or flashed in the echo area."
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
215 ;; reset scrollable text
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
216 (setq newsticker--scrollable-text "")
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
217 (setq newsticker--item-list nil)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
218 (setq newsticker--item-position 0)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
219 ;; build scrollable text from cache data
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
220 (let ((have-something nil))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
221 (mapc
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
222 (lambda (feed)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
223 (let ((feed-name (symbol-name (car feed))))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
224 (let ((num-new (newsticker--stat-num-items (car feed) 'new))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
225 (num-old (newsticker--stat-num-items (car feed) 'old))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
226 (num-imm (newsticker--stat-num-items (car feed) 'immortal))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
227 (num-obs (newsticker--stat-num-items (car feed) 'obsolete)))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
228 (when (or (> num-new 0)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
229 (and (> num-old 0)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
230 (not newsticker-hide-old-items-in-echo-area))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
231 (and (> num-imm 0)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
232 (not newsticker-hide-immortal-items-in-echo-area))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
233 (and (> num-obs 0)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
234 (not newsticker-hide-obsolete-items-in-echo-area)))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
235 (setq have-something t)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
236 (mapc
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
237 (lambda (item)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
238 (let ((title (replace-regexp-in-string
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
239 "[\r\n]+" " "
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
240 (newsticker--title item)))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
241 (age (newsticker--age item)))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
242 (unless (string= title newsticker--error-headline)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
243 (when
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
244 (or (eq age 'new)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
245 (and (eq age 'old)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
246 (not newsticker-hide-old-items-in-echo-area))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
247 (and (eq age 'obsolete)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
248 (not
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
249 newsticker-hide-obsolete-items-in-echo-area))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
250 (and (eq age 'immortal)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
251 (not
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
252 newsticker-hide-immortal-items-in-echo-area)))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
253 (setq title (newsticker--remove-whitespace title))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
254 ;; add to flash list
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
255 (add-to-list 'newsticker--item-list
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
256 (concat feed-name ": " title) t)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
257 ;; and to the scrollable text
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
258 (setq newsticker--scrollable-text
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
259 (concat newsticker--scrollable-text
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
260 " " feed-name ": " title " +++"))))))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
261 (cdr feed))))))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
262 newsticker--cache)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
263 (when have-something
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
264 (setq newsticker--scrollable-text
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
265 (concat "+++ "
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
266 (format-time-string "%A, %H:%M"
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
267 newsticker--latest-update-time)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
268 " ++++++" newsticker--scrollable-text)))))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
269
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
270 (defun newsticker--ticker-text-remove (feed title)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
271 "Remove the item of FEED with TITLE from the ticker text."
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
272 ;; reset scrollable text
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
273 (setq newsticker--item-position 0)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
274 (let ((feed-name (symbol-name feed))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
275 (t-title (replace-regexp-in-string "[\r\n]+" " " title)))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
276 ;; remove from flash list
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
277 (setq newsticker--item-list (remove (concat feed-name ": " t-title)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
278 newsticker--item-list))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
279 ;; and from the scrollable text
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
280 (setq newsticker--scrollable-text
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
281 (replace-regexp-in-string
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
282 (regexp-quote (concat " " feed-name ": " t-title " +++"))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
283 ""
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
284 newsticker--scrollable-text))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
285 (if (string-match (concat "^\\+\\+\\+ [A-Z][a-z]+, "
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
286 "[012]?[0-9]:[0-9][0-9] \\+\\+\\+\\+\\+\\+$")
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
287 newsticker--scrollable-text)
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
288 (setq newsticker--scrollable-text ""))))
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
289
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
290 (provide 'newsticker-ticker)
95684
4ab45b5c92cd Add arch tagline
Miles Bader <miles@gnu.org>
parents: 95678
diff changeset
291
4ab45b5c92cd Add arch tagline
Miles Bader <miles@gnu.org>
parents: 95678
diff changeset
292 ;; arch-tag: faee3ebb-749b-4935-9835-7f36d4b700f0
95678
86fd39c6039a Initial check-in.
Ulf Jasper <ulf.jasper@web.de>
parents:
diff changeset
293 ;;; newsticker-ticker.el ends here