Mercurial > emacs
annotate lisp/calendar/cal-x.el @ 71984:bb119ed4db49
(Fload): Use xsignal2, signal_error.
(end_of_file_error): Use xsignal0, xsignal1.
(read0): Use xsignal1.
(invalid_syntax): New error function marked no-return.
(read_integer, read1, read_list): Use it.
author | Kim F. Storm <storm@cua.dk> |
---|---|
date | Tue, 18 Jul 2006 13:28:34 +0000 |
parents | 8daf7d9a0771 |
children | 7a3f13e2dd57 4b3d39451150 |
rev | line source |
---|---|
14269
af156af979be
Fix doc strings at top of file.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents:
14169
diff
changeset
|
1 ;;; cal-x.el --- calendar windows in dedicated frames in X |
10088 | 2 |
68721 | 3 ;; Copyright (C) 1994, 1995, 2001, 2002, 2003, 2004, 2005, 2006 |
67465
a55ee709ec8d
Update copyright pending Emacs 22.
Glenn Morris <rgm@gnu.org>
parents:
65919
diff
changeset
|
4 ;; Free Software Foundation, Inc. |
10088 | 5 |
6 ;; Author: Michael Kifer <kifer@cs.sunysb.edu> | |
7 ;; Edward M. Reingold <reingold@cs.uiuc.edu> | |
65919
5c09efcfc1d9
Update maintainer email address.
Glenn Morris <rgm@gnu.org>
parents:
64085
diff
changeset
|
8 ;; Maintainer: Glenn Morris <rgm@gnu.org> |
10088 | 9 ;; Keywords: calendar |
14269
af156af979be
Fix doc strings at top of file.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents:
14169
diff
changeset
|
10 ;; Human-Keywords: calendar, dedicated frames, X Window System |
10088 | 11 |
12 ;; This file is part of GNU Emacs. | |
13 | |
14 ;; GNU Emacs is free software; you can redistribute it and/or modify | |
15 ;; it under the terms of the GNU General Public License as published by | |
16 ;; the Free Software Foundation; either version 2, or (at your option) | |
17 ;; any later version. | |
18 | |
19 ;; GNU Emacs is distributed in the hope that it will be useful, | |
20 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
21 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
22 ;; GNU General Public License for more details. | |
23 | |
24 ;; You should have received a copy of the GNU General Public License | |
14169 | 25 ;; along with GNU Emacs; see the file COPYING. If not, write to the |
64085 | 26 ;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, |
27 ;; Boston, MA 02110-1301, USA. | |
10088 | 28 |
29 ;;; Commentary: | |
30 | |
14269
af156af979be
Fix doc strings at top of file.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents:
14169
diff
changeset
|
31 ;; This collection of functions implements dedicated frames in X for |
10088 | 32 ;; calendar.el. |
33 | |
34 ;; Comments, corrections, and improvements should be sent to | |
35 ;; Edward M. Reingold Department of Computer Science | |
36 ;; (217) 333-6733 University of Illinois at Urbana-Champaign | |
37 ;; reingold@cs.uiuc.edu 1304 West Springfield Avenue | |
38 ;; Urbana, Illinois 61801 | |
39 | |
40 ;;; Code: | |
41 | |
13441 | 42 (require 'calendar) |
43 | |
10088 | 44 (defvar calendar-frame nil "Frame in which to display the calendar.") |
45 | |
46 (defvar diary-frame nil "Frame in which to display the diary.") | |
49598
0d8b17d428b5
Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
37431
diff
changeset
|
47 |
15114
2151ff2428aa
(diary-frame-parameters, calendar-frame-parameters)
Richard M. Stallman <rms@gnu.org>
parents:
14269
diff
changeset
|
48 ;; This should not specify the font. That's up to the user. |
2151ff2428aa
(diary-frame-parameters, calendar-frame-parameters)
Richard M. Stallman <rms@gnu.org>
parents:
14269
diff
changeset
|
49 ;; Certainly it should not specify auto-lower and auto-raise |
2151ff2428aa
(diary-frame-parameters, calendar-frame-parameters)
Richard M. Stallman <rms@gnu.org>
parents:
14269
diff
changeset
|
50 ;; since most users won't like that. |
10088 | 51 (defvar diary-frame-parameters |
23552
905aab3037e8
Add title parameters to frames.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents:
22262
diff
changeset
|
52 '((name . "Diary") (title . "Diary") (height . 10) (width . 80) |
905aab3037e8
Add title parameters to frames.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents:
22262
diff
changeset
|
53 (unsplittable . t) (minibuffer . nil)) |
10088 | 54 "Parameters of the diary frame, if the diary is in its own frame. |
55 Location and color should be set in .Xdefaults.") | |
49598
0d8b17d428b5
Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
37431
diff
changeset
|
56 |
10088 | 57 (defvar calendar-frame-parameters |
23552
905aab3037e8
Add title parameters to frames.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents:
22262
diff
changeset
|
58 '((name . "Calendar") (title . "Calendar") (minibuffer . nil) |
905aab3037e8
Add title parameters to frames.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents:
22262
diff
changeset
|
59 (height . 10) (width . 80) (unsplittable . t) (vertical-scroll-bars . nil)) |
10088 | 60 "Parameters of the calendar frame, if the calendar is in a separate frame. |
61 Location and color should be set in .Xdefaults.") | |
62 | |
63 (defvar calendar-and-diary-frame-parameters | |
23552
905aab3037e8
Add title parameters to frames.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents:
22262
diff
changeset
|
64 '((name . "Calendar") (title . "Calendar") (height . 28) (width . 80) |
905aab3037e8
Add title parameters to frames.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents:
22262
diff
changeset
|
65 (minibuffer . nil)) |
10088 | 66 "Parameters of the frame that displays both the calendar and the diary. |
67 Location and color should be set in .Xdefaults.") | |
49598
0d8b17d428b5
Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
37431
diff
changeset
|
68 |
10088 | 69 (defvar calendar-after-frame-setup-hooks nil |
70 "Hooks to be run just after setting up a calendar frame. | |
71 Can be used to change frame parameters, such as font, color, location, etc.") | |
49598
0d8b17d428b5
Trailing whitepace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
37431
diff
changeset
|
72 |
10088 | 73 (defun calendar-one-frame-setup (&optional arg) |
53558 | 74 "Start calendar and display it in a dedicated frame together with the diary. |
75 This function requires a display capable of multiple frames, else | |
76 `calendar-basic-setup' is used instead." | |
37431
bd1a8b1c88d7
(calendar-two-frame-setup, calendar-only-one-frame-setup)
Eli Zaretskii <eliz@gnu.org>
parents:
24890
diff
changeset
|
77 (if (not (display-multi-frame-p)) |
10088 | 78 (calendar-basic-setup arg) |
79 (if (frame-live-p calendar-frame) (delete-frame calendar-frame)) | |
80 (if (frame-live-p diary-frame) (delete-frame diary-frame)) | |
81 (let ((special-display-buffer-names nil) | |
82 (view-diary-entries-initially t)) | |
83 (save-window-excursion | |
84 (save-excursion | |
85 (setq calendar-frame | |
86 (make-frame calendar-and-diary-frame-parameters)) | |
87 (run-hooks 'calendar-after-frame-setup-hooks) | |
88 (select-frame calendar-frame) | |
89 (if (eq 'icon (cdr (assoc 'visibility | |
90 (frame-parameters calendar-frame)))) | |
91 (iconify-or-deiconify-frame)) | |
92 (calendar-basic-setup arg) | |
61142
1b5d0d3282a7
Update copyright and maintainer.
Glenn Morris <rgm@gnu.org>
parents:
53558
diff
changeset
|
93 (set-window-dedicated-p (selected-window) t) |
10088 | 94 (set-window-dedicated-p |
95 (display-buffer | |
12060
b163768a998f
Fix cal-x.el to create an empty fancy-diary-buffer, if needed.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents:
12049
diff
changeset
|
96 (if (not (memq 'fancy-diary-display diary-display-hook)) |
b163768a998f
Fix cal-x.el to create an empty fancy-diary-buffer, if needed.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents:
12049
diff
changeset
|
97 (get-file-buffer diary-file) |
b163768a998f
Fix cal-x.el to create an empty fancy-diary-buffer, if needed.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents:
12049
diff
changeset
|
98 (if (not (bufferp (get-buffer fancy-diary-buffer))) |
b163768a998f
Fix cal-x.el to create an empty fancy-diary-buffer, if needed.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents:
12049
diff
changeset
|
99 (make-fancy-diary-buffer)) |
b163768a998f
Fix cal-x.el to create an empty fancy-diary-buffer, if needed.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents:
12049
diff
changeset
|
100 fancy-diary-buffer)) |
61142
1b5d0d3282a7
Update copyright and maintainer.
Glenn Morris <rgm@gnu.org>
parents:
53558
diff
changeset
|
101 t)))))) |
12060
b163768a998f
Fix cal-x.el to create an empty fancy-diary-buffer, if needed.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents:
12049
diff
changeset
|
102 |
24890
5f37b93c8538
(calendar-only-one-frame-setup): New function.
Karl Heuer <kwzh@gnu.org>
parents:
24860
diff
changeset
|
103 (defun calendar-only-one-frame-setup (&optional arg) |
53558 | 104 "Start calendar and display it in a dedicated frame. |
105 This function requires a display capable of multiple frames, else | |
106 `calendar-basic-setup' is used instead." | |
37431
bd1a8b1c88d7
(calendar-two-frame-setup, calendar-only-one-frame-setup)
Eli Zaretskii <eliz@gnu.org>
parents:
24890
diff
changeset
|
107 (if (not (display-multi-frame-p)) |
24890
5f37b93c8538
(calendar-only-one-frame-setup): New function.
Karl Heuer <kwzh@gnu.org>
parents:
24860
diff
changeset
|
108 (calendar-basic-setup arg) |
5f37b93c8538
(calendar-only-one-frame-setup): New function.
Karl Heuer <kwzh@gnu.org>
parents:
24860
diff
changeset
|
109 (if (frame-live-p calendar-frame) (delete-frame calendar-frame)) |
5f37b93c8538
(calendar-only-one-frame-setup): New function.
Karl Heuer <kwzh@gnu.org>
parents:
24860
diff
changeset
|
110 (let ((special-display-buffer-names nil) |
5f37b93c8538
(calendar-only-one-frame-setup): New function.
Karl Heuer <kwzh@gnu.org>
parents:
24860
diff
changeset
|
111 (view-diary-entries-initially nil)) |
5f37b93c8538
(calendar-only-one-frame-setup): New function.
Karl Heuer <kwzh@gnu.org>
parents:
24860
diff
changeset
|
112 (save-window-excursion |
5f37b93c8538
(calendar-only-one-frame-setup): New function.
Karl Heuer <kwzh@gnu.org>
parents:
24860
diff
changeset
|
113 (save-excursion |
5f37b93c8538
(calendar-only-one-frame-setup): New function.
Karl Heuer <kwzh@gnu.org>
parents:
24860
diff
changeset
|
114 (setq calendar-frame |
5f37b93c8538
(calendar-only-one-frame-setup): New function.
Karl Heuer <kwzh@gnu.org>
parents:
24860
diff
changeset
|
115 (make-frame calendar-frame-parameters)) |
5f37b93c8538
(calendar-only-one-frame-setup): New function.
Karl Heuer <kwzh@gnu.org>
parents:
24860
diff
changeset
|
116 (run-hooks 'calendar-after-frame-setup-hooks) |
5f37b93c8538
(calendar-only-one-frame-setup): New function.
Karl Heuer <kwzh@gnu.org>
parents:
24860
diff
changeset
|
117 (select-frame calendar-frame) |
5f37b93c8538
(calendar-only-one-frame-setup): New function.
Karl Heuer <kwzh@gnu.org>
parents:
24860
diff
changeset
|
118 (if (eq 'icon (cdr (assoc 'visibility |
5f37b93c8538
(calendar-only-one-frame-setup): New function.
Karl Heuer <kwzh@gnu.org>
parents:
24860
diff
changeset
|
119 (frame-parameters calendar-frame)))) |
5f37b93c8538
(calendar-only-one-frame-setup): New function.
Karl Heuer <kwzh@gnu.org>
parents:
24860
diff
changeset
|
120 (iconify-or-deiconify-frame)) |
5f37b93c8538
(calendar-only-one-frame-setup): New function.
Karl Heuer <kwzh@gnu.org>
parents:
24860
diff
changeset
|
121 (calendar-basic-setup arg) |
61142
1b5d0d3282a7
Update copyright and maintainer.
Glenn Morris <rgm@gnu.org>
parents:
53558
diff
changeset
|
122 (set-window-dedicated-p (selected-window) t)))))) |
24890
5f37b93c8538
(calendar-only-one-frame-setup): New function.
Karl Heuer <kwzh@gnu.org>
parents:
24860
diff
changeset
|
123 |
10088 | 124 (defun calendar-two-frame-setup (&optional arg) |
53558 | 125 "Start calendar and diary in separate, dedicated frames. |
126 This function requires a display capable of multiple frames, else | |
127 `calendar-basic-setup' is used instead." | |
37431
bd1a8b1c88d7
(calendar-two-frame-setup, calendar-only-one-frame-setup)
Eli Zaretskii <eliz@gnu.org>
parents:
24890
diff
changeset
|
128 (if (not (display-multi-frame-p)) |
10088 | 129 (calendar-basic-setup arg) |
130 (if (frame-live-p calendar-frame) (delete-frame calendar-frame)) | |
131 (if (frame-live-p diary-frame) (delete-frame diary-frame)) | |
132 (let ((pop-up-windows nil) | |
133 (view-diary-entries-initially nil) | |
134 (special-display-buffer-names nil)) | |
135 (save-window-excursion | |
136 (save-excursion (calendar-basic-setup arg)) | |
137 (setq calendar-frame (make-frame calendar-frame-parameters)) | |
138 (run-hooks 'calendar-after-frame-setup-hooks) | |
139 (select-frame calendar-frame) | |
140 (if (eq 'icon (cdr (assoc 'visibility | |
141 (frame-parameters calendar-frame)))) | |
142 (iconify-or-deiconify-frame)) | |
143 (display-buffer calendar-buffer) | |
61142
1b5d0d3282a7
Update copyright and maintainer.
Glenn Morris <rgm@gnu.org>
parents:
53558
diff
changeset
|
144 (set-window-dedicated-p (selected-window) t) |
10088 | 145 (setq diary-frame (make-frame diary-frame-parameters)) |
146 (run-hooks 'calendar-after-frame-setup-hooks) | |
147 (select-frame diary-frame) | |
148 (if (eq 'icon (cdr (assoc 'visibility | |
149 (frame-parameters diary-frame)))) | |
150 (iconify-or-deiconify-frame)) | |
151 (save-excursion (diary)) | |
152 (set-window-dedicated-p | |
153 (display-buffer | |
12060
b163768a998f
Fix cal-x.el to create an empty fancy-diary-buffer, if needed.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents:
12049
diff
changeset
|
154 (if (not (memq 'fancy-diary-display diary-display-hook)) |
b163768a998f
Fix cal-x.el to create an empty fancy-diary-buffer, if needed.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents:
12049
diff
changeset
|
155 (get-file-buffer diary-file) |
b163768a998f
Fix cal-x.el to create an empty fancy-diary-buffer, if needed.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents:
12049
diff
changeset
|
156 (if (not (bufferp (get-buffer fancy-diary-buffer))) |
b163768a998f
Fix cal-x.el to create an empty fancy-diary-buffer, if needed.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents:
12049
diff
changeset
|
157 (make-fancy-diary-buffer)) |
b163768a998f
Fix cal-x.el to create an empty fancy-diary-buffer, if needed.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents:
12049
diff
changeset
|
158 fancy-diary-buffer)) |
61142
1b5d0d3282a7
Update copyright and maintainer.
Glenn Morris <rgm@gnu.org>
parents:
53558
diff
changeset
|
159 t))))) |
10088 | 160 |
24860
069cad4a56ef
(special-display-buffer-names):
Karl Heuer <kwzh@gnu.org>
parents:
23552
diff
changeset
|
161 ;; Formerly (get-file-buffer diary-file) was added to the list here, |
069cad4a56ef
(special-display-buffer-names):
Karl Heuer <kwzh@gnu.org>
parents:
23552
diff
changeset
|
162 ;; but that isn't clean, and the value could even be nil. |
10088 | 163 (setq special-display-buffer-names |
164 (append special-display-buffer-names | |
165 (list "*Yahrzeits*" lunar-phases-buffer holiday-buffer | |
24860
069cad4a56ef
(special-display-buffer-names):
Karl Heuer <kwzh@gnu.org>
parents:
23552
diff
changeset
|
166 fancy-diary-buffer |
22262
ac47a12e523c
Fix list of "special" buffers.
Edward M. Reingold <reingold@emr.cs.iit.edu>
parents:
15114
diff
changeset
|
167 other-calendars-buffer calendar-buffer))) |
10088 | 168 |
169 (run-hooks 'cal-x-load-hook) | |
170 | |
171 (provide 'cal-x) | |
172 | |
52401 | 173 ;;; arch-tag: c6dbddca-ae84-442d-87fc-244b76e38e17 |
10088 | 174 ;;; cal-x.el ends here |