comparison lisp/calendar/cal-x.el @ 0:376386a54a3c r19-14

Import from CVS: tag r19-14
author cvs
date Mon, 13 Aug 2007 08:45:50 +0200
parents
children
comparison
equal deleted inserted replaced
-1:000000000000 0:376386a54a3c
1 ;;; cal-x.el --- calendar windows in dedicated frames in x-windows
2
3 ;; Copyright (C) 1994 Free Software Foundation, Inc.
4
5 ;; Author: Michael Kifer <kifer@cs.sunysb.edu>
6 ;; Edward M. Reingold <reingold@cs.uiuc.edu>
7 ;; Modified for XEmacs by: Chuck Thompson <cthomp@cs.uiuc.edu>
8 ;; Keywords: calendar
9 ;; Human-Keywords: calendar, dedicated frames, x-windows
10
11 ;; This file is part of GNU Emacs.
12
13 ;; GNU Emacs is free software; you can redistribute it and/or modify
14 ;; it under the terms of the GNU General Public License as published by
15 ;; the Free Software Foundation; either version 2, or (at your option)
16 ;; any later version.
17
18 ;; GNU Emacs is distributed in the hope that it will be useful,
19 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
20 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 ;; GNU General Public License for more details.
22
23 ;; You should have received a copy of the GNU General Public License
24 ;; along with GNU Emacs; see the file COPYING. If not, write to
25 ;; the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
26
27 ;;; Commentary:
28
29 ;; This collection of functions implements dedicated frames in x-windows for
30 ;; calendar.el.
31
32 ;; Comments, corrections, and improvements should be sent to
33 ;; Edward M. Reingold Department of Computer Science
34 ;; (217) 333-6733 University of Illinois at Urbana-Champaign
35 ;; reingold@cs.uiuc.edu 1304 West Springfield Avenue
36 ;; Urbana, Illinois 61801
37
38 ;;; Code:
39
40 (require 'calendar)
41 (if (not (fboundp 'calendar-basic-setup))
42 (fset 'calendar-basic-setup (symbol-function 'calendar)))
43
44 ;;;###autoload
45 (defvar calendar-setup 'one-frame
46 "The frame set up of the calendar.
47 The choices are `one-frame' (calendar and diary together in one separate,
48 dediciated frame) or `two-frames' (calendar and diary in separate, dedicated
49 frames); with any other value the current frame is used.")
50
51 (defun calendar (&optional arg)
52 "Choose between the one frame, two frame, or basic calendar displays.
53 The original function `calendar' has been renamed `calendar-basic-setup'."
54 (interactive "P")
55 (cond ((equal calendar-setup 'one-frame) (calendar-one-frame-setup arg))
56 ((equal calendar-setup 'two-frames) (calendar-two-frame-setup arg))
57 (t (calendar-basic-setup arg))))
58
59 (defvar calendar-frame nil "Frame in which to display the calendar.")
60
61 (defvar diary-frame nil "Frame in which to display the diary.")
62
63 (defvar diary-frame-parameters
64 '((name . "Diary") (height . 10) (width . 80) (unsplittable . t)
65 (font . "6x13") (auto-lower . t) (auto-raise . t) (minibuffer . nil))
66 "Parameters of the diary frame, if the diary is in its own frame.
67 Location and color should be set in .Xdefaults.")
68
69 (defvar calendar-frame-parameters
70 '((name . "Calendar") (minibuffer . nil) (height . 10) (width . 80)
71 (auto-raise . t) (auto-lower . t) (font . "6x13") (unsplittable . t)
72 (vertical-scroll-bars . nil))
73 "Parameters of the calendar frame, if the calendar is in a separate frame.
74 Location and color should be set in .Xdefaults.")
75
76 (defvar calendar-and-diary-frame-parameters
77 '((name . "Calendar") (height . 28) (width . 80) (minibuffer . nil)
78 (font . "6x13") (auto-raise . t) (auto-lower . t))
79 "Parameters of the frame that displays both the calendar and the diary.
80 Location and color should be set in .Xdefaults.")
81
82 (defvar calendar-after-frame-setup-hooks nil
83 "Hooks to be run just after setting up a calendar frame.
84 Can be used to change frame parameters, such as font, color, location, etc.")
85
86 (defun calendar-not-using-window-system-p ()
87 "Return t if not running under a window system."
88 (if (fboundp 'device-type)
89 (not (eq (device-type (selected-device)) 'x))
90 (not window-system)))
91
92 (defun calendar-deiconify-frame (frame)
93 "Deiconify the given frame if it is currently iconified."
94 (if (string-match "XEmacs" emacs-version)
95 (if (frame-iconified-p frame)
96 (deiconify-frame frame))
97 (if (eq 'icon (cdr (assoc 'visibility (frame-parameters frame))))
98 ;; This isn't necessary going to do what is intended since it
99 ;; only works with the selected frame.
100 (iconify-or-deiconify-frame))))
101
102 (defun calendar-one-frame-setup (&optional arg)
103 "Start calendar and display it in a dedicated frame together with the diary."
104 (if (calendar-not-using-window-system-p)
105 (calendar-basic-setup arg)
106 (if (frame-live-p calendar-frame) (delete-frame calendar-frame))
107 (if (frame-live-p diary-frame) (delete-frame diary-frame))
108 (let ((special-display-buffer-names nil)
109 (view-diary-entries-initially t))
110 (save-window-excursion
111 (save-excursion
112 (setq calendar-frame
113 (make-frame calendar-and-diary-frame-parameters))
114 (run-hooks 'calendar-after-frame-setup-hooks)
115 (select-frame calendar-frame)
116 (calendar-deiconify-frame calendar-frame)
117 (calendar-basic-setup arg)
118 (set-window-dedicated-p (selected-window) 'calendar)
119 (set-window-dedicated-p
120 (display-buffer
121 (if (not (memq 'fancy-diary-display diary-display-hook))
122 (get-file-buffer diary-file)
123 (if (not (bufferp (get-buffer fancy-diary-buffer)))
124 (make-fancy-diary-buffer))
125 fancy-diary-buffer))
126 'diary))))))
127
128 (defun calendar-two-frame-setup (&optional arg)
129 "Start calendar and diary in separate, dedicated frames."
130 (if (calendar-not-using-window-system-p)
131 (calendar-basic-setup arg)
132 (if (frame-live-p calendar-frame) (delete-frame calendar-frame))
133 (if (frame-live-p diary-frame) (delete-frame diary-frame))
134 (let ((pop-up-windows nil)
135 (view-diary-entries-initially nil)
136 (special-display-buffer-names nil))
137 (save-window-excursion
138 (save-excursion (calendar-basic-setup arg))
139 (setq calendar-frame (make-frame calendar-frame-parameters))
140 (run-hooks 'calendar-after-frame-setup-hooks)
141 (select-frame calendar-frame)
142 (calendar-deiconify-frame calendar-frame)
143 (display-buffer calendar-buffer)
144 (set-window-dedicated-p (selected-window) 'calendar)
145 (setq diary-frame (make-frame diary-frame-parameters))
146 (run-hooks 'calendar-after-frame-setup-hooks)
147 (select-frame diary-frame)
148 (calendar-deiconify-frame diary-frame)
149 (save-excursion (diary))
150 (set-window-dedicated-p
151 (display-buffer
152 (if (not (memq 'fancy-diary-display diary-display-hook))
153 (get-file-buffer diary-file)
154 (if (not (bufferp (get-buffer fancy-diary-buffer)))
155 (make-fancy-diary-buffer))
156 fancy-diary-buffer))
157 'diary)))))
158
159 (defun make-fancy-diary-buffer ()
160 (save-excursion
161 (set-buffer (get-buffer-create fancy-diary-buffer))
162 (setq buffer-read-only nil)
163 (make-local-variable 'mode-line-format)
164 (calendar-set-mode-line "Diary Entries")
165 (erase-buffer)
166 (set-buffer-modified-p nil)
167 (setq buffer-read-only t)))
168
169 (if (not (string-match "XEmacs" emacs-version))
170 (setq special-display-buffer-names
171 (append special-display-buffer-names
172 (list "*Yahrzeits*" lunar-phases-buffer holiday-buffer
173 fancy-diary-buffer (get-file-buffer diary-file)
174 calendar-buffer))))
175
176 (run-hooks 'cal-x-load-hook)
177
178 (provide 'cal-x)
179
180 ;;; cal-x.el ends here