annotate lisp/frame.el @ 83360:0036e612aaef

Apply settings in `window-system-default-frame-alist' to the initial frame as well. * lisp/frame.el (frame-notice-user-settings): Extend to apply settings in `window-system-default-frame-alist' as well. git-archimport-id: lorentey@elte.hu--2004/emacs--multi-tty--0--patch-400
author Karoly Lorentey <lorentey@elte.hu>
date Wed, 07 Sep 2005 23:11:21 +0000
parents 532e0a9335a9
children 0181341f0aca
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
38412
253f761ad37b Some fixes to follow coding conventions in files maintained by FSF.
Pavel Janík <Pavel@Janik.cz>
parents: 37823
diff changeset
1 ;;; frame.el --- multi-frame management independent of window systems
658
7cbd4fcd8b0f *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 584
diff changeset
2
64762
41bb365f41c4 Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 64543
diff changeset
3 ;; Copyright (C) 1993, 1994, 1996, 1997, 2000, 2001, 2002, 2003,
41bb365f41c4 Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 64543
diff changeset
4 ;; 2004, 2005 Free Software Foundation, Inc.
846
20674ae6bf52 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 827
diff changeset
5
793
6fb68a1460a6 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 777
diff changeset
6 ;; Maintainer: FSF
811
e694e0879463 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 806
diff changeset
7 ;; Keywords: internal
793
6fb68a1460a6 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 777
diff changeset
8
14169
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 12220
diff changeset
9 ;; This file is part of GNU Emacs.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 12220
diff changeset
10
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 12220
diff changeset
11 ;; GNU Emacs is free software; you can redistribute it and/or modify
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 12220
diff changeset
12 ;; it under the terms of the GNU General Public License as published by
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 12220
diff changeset
13 ;; the Free Software Foundation; either version 2, or (at your option)
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 12220
diff changeset
14 ;; any later version.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 12220
diff changeset
15
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 12220
diff changeset
16 ;; GNU Emacs is distributed in the hope that it will be useful,
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 12220
diff changeset
17 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 12220
diff changeset
18 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 12220
diff changeset
19 ;; GNU General Public License for more details.
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 12220
diff changeset
20
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 12220
diff changeset
21 ;; You should have received a copy of the GNU General Public License
83f275dcd93a Update FSF's address.
Erik Naggum <erik@naggum.no>
parents: 12220
diff changeset
22 ;; along with GNU Emacs; see the file COPYING. If not, write to the
64091
6fb026ad601f Update FSF's address.
Lute Kamstra <lute@gnu.org>
parents: 63178
diff changeset
23 ;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
6fb026ad601f Update FSF's address.
Lute Kamstra <lute@gnu.org>
parents: 63178
diff changeset
24 ;; Boston, MA 02110-1301, USA.
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
25
38412
253f761ad37b Some fixes to follow coding conventions in files maintained by FSF.
Pavel Janík <Pavel@Janik.cz>
parents: 37823
diff changeset
26 ;;; Commentary:
253f761ad37b Some fixes to follow coding conventions in files maintained by FSF.
Pavel Janík <Pavel@Janik.cz>
parents: 37823
diff changeset
27
793
6fb68a1460a6 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 777
diff changeset
28 ;;; Code:
6fb68a1460a6 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 777
diff changeset
29
83014
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
30 (defvar frame-creation-function-alist
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
31 (list (cons nil
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
32 (if (fboundp 'tty-create-frame-with-faces)
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
33 'tty-create-frame-with-faces
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
34 (function
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
35 (lambda (parameters)
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
36 (error "Can't create multiple frames without a window system"))))))
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
37 "Alist of window-system dependent functions to call to create a new frame.
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
38 The window system startup file should add its frame creation
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
39 function to this list, which should take an alist of parameters
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
40 as its argument.")
83009
b2b37c85b00a Numerous bugfixes and small improvements.
Karoly Lorentey <lorentey@elte.hu>
parents: 83008
diff changeset
41
83110
43581c3f182f A simple implementation for display-local frame parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83065
diff changeset
42 (defvar window-system-default-frame-alist nil
43581c3f182f A simple implementation for display-local frame parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83065
diff changeset
43 "Alist of window-system dependent default frame parameters.
43581c3f182f A simple implementation for display-local frame parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83065
diff changeset
44 These may be set in your init file, like this:
43581c3f182f A simple implementation for display-local frame parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83065
diff changeset
45
43581c3f182f A simple implementation for display-local frame parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83065
diff changeset
46 ;; Disable menubar and toolbar on the console, but enable them under X.
43581c3f182f A simple implementation for display-local frame parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83065
diff changeset
47 (setq window-system-default-frame-alist
43581c3f182f A simple implementation for display-local frame parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83065
diff changeset
48 '((x (menu-bar-lines . 1) (tool-bar-lines . 1))
43581c3f182f A simple implementation for display-local frame parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83065
diff changeset
49 (nil (menu-bar-lines . 0) (tool-bar-lines . 0))))
43581c3f182f A simple implementation for display-local frame parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83065
diff changeset
50
43581c3f182f A simple implementation for display-local frame parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83065
diff changeset
51 Also see `default-frame-alist'.")
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
52
39846
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
53 ;; The initial value given here used to ask for a minibuffer.
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
54 ;; But that's not necessary, because the default is to have one.
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
55 ;; By not specifying it here, we let an X resource specify it.
23745
43927e2a5899 (initial-frame-alist): Add defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 22232
diff changeset
56 (defcustom initial-frame-alist nil
24926
4cb7e7beea27 (minibuffer-frame-alist): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 24207
diff changeset
57 "*Alist of frame parameters for creating the initial X window frame.
1974
94e4f619080b These changes were actually made by Richard; I stole his RCS lock.
Jim Blandy <jimb@redhat.com>
parents: 1881
diff changeset
58 You can set this in your `.emacs' file; for example,
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
59 (setq initial-frame-alist '((top . 1) (left . 1) (width . 80) (height . 55)))
8129
aa25c6ea397d (initial-frame-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8072
diff changeset
60 Parameters specified here supersede the values given in `default-frame-alist'.
aa25c6ea397d (initial-frame-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8072
diff changeset
61
aa25c6ea397d (initial-frame-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8072
diff changeset
62 If the value calls for a frame without a minibuffer, and you have not created
aa25c6ea397d (initial-frame-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8072
diff changeset
63 a minibuffer frame on your own, one is created according to
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
64 `minibuffer-frame-alist'.
8129
aa25c6ea397d (initial-frame-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8072
diff changeset
65
aa25c6ea397d (initial-frame-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8072
diff changeset
66 You can specify geometry-related options for just the initial frame
aa25c6ea397d (initial-frame-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8072
diff changeset
67 by setting this variable in your `.emacs' file; however, they won't
10557
87b3ab910738 Fix typos.
Karl Heuer <kwzh@gnu.org>
parents: 10192
diff changeset
68 take effect until Emacs reads `.emacs', which happens after first creating
8129
aa25c6ea397d (initial-frame-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8072
diff changeset
69 the frame. If you want the frame to have the proper geometry as soon
aa25c6ea397d (initial-frame-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8072
diff changeset
70 as it appears, you need to use this three-step process:
aa25c6ea397d (initial-frame-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8072
diff changeset
71 * Specify X resources to give the geometry you want.
aa25c6ea397d (initial-frame-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8072
diff changeset
72 * Set `default-frame-alist' to override these options so that they
aa25c6ea397d (initial-frame-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8072
diff changeset
73 don't affect subsequent frames.
aa25c6ea397d (initial-frame-alist): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 8072
diff changeset
74 * Set `initial-frame-alist' in a way that matches the X resources,
23745
43927e2a5899 (initial-frame-alist): Add defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 22232
diff changeset
75 to override what you put in `default-frame-alist'."
43927e2a5899 (initial-frame-alist): Add defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 22232
diff changeset
76 :type '(repeat (cons :format "%v"
43927e2a5899 (initial-frame-alist): Add defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 22232
diff changeset
77 (symbol :tag "Parameter")
43927e2a5899 (initial-frame-alist): Add defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 22232
diff changeset
78 (sexp :tag "Value")))
43927e2a5899 (initial-frame-alist): Add defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 22232
diff changeset
79 :group 'frames)
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
80
24926
4cb7e7beea27 (minibuffer-frame-alist): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 24207
diff changeset
81 (defcustom minibuffer-frame-alist '((width . 80) (height . 2))
4cb7e7beea27 (minibuffer-frame-alist): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 24207
diff changeset
82 "*Alist of frame parameters for initially creating a minibuffer frame.
1974
94e4f619080b These changes were actually made by Richard; I stole his RCS lock.
Jim Blandy <jimb@redhat.com>
parents: 1881
diff changeset
83 You can set this in your `.emacs' file; for example,
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
84 (setq minibuffer-frame-alist
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
85 '((top . 1) (left . 1) (width . 80) (height . 2)))
1974
94e4f619080b These changes were actually made by Richard; I stole his RCS lock.
Jim Blandy <jimb@redhat.com>
parents: 1881
diff changeset
86 Parameters specified here supersede the values given in
24926
4cb7e7beea27 (minibuffer-frame-alist): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 24207
diff changeset
87 `default-frame-alist', for a minibuffer frame."
4cb7e7beea27 (minibuffer-frame-alist): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 24207
diff changeset
88 :type '(repeat (cons :format "%v"
4cb7e7beea27 (minibuffer-frame-alist): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 24207
diff changeset
89 (symbol :tag "Parameter")
4cb7e7beea27 (minibuffer-frame-alist): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 24207
diff changeset
90 (sexp :tag "Value")))
4cb7e7beea27 (minibuffer-frame-alist): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 24207
diff changeset
91 :group 'frames)
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
92
24926
4cb7e7beea27 (minibuffer-frame-alist): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 24207
diff changeset
93 (defcustom pop-up-frame-alist nil
4cb7e7beea27 (minibuffer-frame-alist): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 24207
diff changeset
94 "*Alist of frame parameters used when creating pop-up frames.
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
95 Pop-up frames are used for completions, help, and the like.
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
96 This variable can be set in your init file, like this:
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
97 (setq pop-up-frame-alist '((width . 80) (height . 20)))
24926
4cb7e7beea27 (minibuffer-frame-alist): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 24207
diff changeset
98 These supersede the values given in `default-frame-alist',
4cb7e7beea27 (minibuffer-frame-alist): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 24207
diff changeset
99 for pop-up frames."
4cb7e7beea27 (minibuffer-frame-alist): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 24207
diff changeset
100 :type '(repeat (cons :format "%v"
4cb7e7beea27 (minibuffer-frame-alist): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 24207
diff changeset
101 (symbol :tag "Parameter")
4cb7e7beea27 (minibuffer-frame-alist): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 24207
diff changeset
102 (sexp :tag "Value")))
4cb7e7beea27 (minibuffer-frame-alist): Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 24207
diff changeset
103 :group 'frames)
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
104
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
105 (setq pop-up-frame-function
53406
45cc6f8abd8d (pop-up-frame-function): Use quote, not `function'.
Richard M. Stallman <rms@gnu.org>
parents: 52614
diff changeset
106 ;; Using `function' here caused some sort of problem.
45cc6f8abd8d (pop-up-frame-function): Use quote, not `function'.
Richard M. Stallman <rms@gnu.org>
parents: 52614
diff changeset
107 '(lambda ()
45cc6f8abd8d (pop-up-frame-function): Use quote, not `function'.
Richard M. Stallman <rms@gnu.org>
parents: 52614
diff changeset
108 (make-frame pop-up-frame-alist)))
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
109
17665
b11021ca3525 Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17523
diff changeset
110 (defcustom special-display-frame-alist
7057
7102dd374da4 (special-display-frame-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7020
diff changeset
111 '((height . 14) (width . 80) (unsplittable . t))
7102dd374da4 (special-display-frame-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7020
diff changeset
112 "*Alist of frame parameters used when creating special frames.
7102dd374da4 (special-display-frame-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7020
diff changeset
113 Special frames are used for buffers whose names are in
7102dd374da4 (special-display-frame-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7020
diff changeset
114 `special-display-buffer-names' and for buffers whose names match
7102dd374da4 (special-display-frame-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7020
diff changeset
115 one of the regular expressions in `special-display-regexps'.
7102dd374da4 (special-display-frame-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7020
diff changeset
116 This variable can be set in your init file, like this:
7102dd374da4 (special-display-frame-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7020
diff changeset
117 (setq special-display-frame-alist '((width . 80) (height . 20)))
17665
b11021ca3525 Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17523
diff changeset
118 These supersede the values given in `default-frame-alist'."
b11021ca3525 Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17523
diff changeset
119 :type '(repeat (cons :format "%v"
b11021ca3525 Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17523
diff changeset
120 (symbol :tag "Parameter")
b11021ca3525 Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17523
diff changeset
121 (sexp :tag "Value")))
b11021ca3525 Use defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 17523
diff changeset
122 :group 'frames)
7057
7102dd374da4 (special-display-frame-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7020
diff changeset
123
8993
c6572fa27df3 (special-display-popup-frame): Rename new arg to ARGS.
Richard M. Stallman <rms@gnu.org>
parents: 8990
diff changeset
124 (defun special-display-popup-frame (buffer &optional args)
25139
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
125 "Display BUFFER in its own frame, reusing an existing window if any.
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
126 Return the window chosen.
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
127 Currently we do not insist on selecting the window within its frame.
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
128 If ARGS is an alist, use it as a list of frame parameter specs.
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
129 If ARGS is a list whose car is a symbol,
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
130 use (car ARGS) as a function to do the work.
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
131 Pass it BUFFER as first arg, and (cdr ARGS) gives the rest of the args."
8993
c6572fa27df3 (special-display-popup-frame): Rename new arg to ARGS.
Richard M. Stallman <rms@gnu.org>
parents: 8990
diff changeset
132 (if (and args (symbolp (car args)))
c6572fa27df3 (special-display-popup-frame): Rename new arg to ARGS.
Richard M. Stallman <rms@gnu.org>
parents: 8990
diff changeset
133 (apply (car args) buffer (cdr args))
55086
2c9194855ec9 (special-display-popup-frame, next-multiframe-window)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 53406
diff changeset
134 (let ((window (get-buffer-window buffer 0)))
39846
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
135 (or
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
136 ;; If we have a window already, make it visible.
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
137 (when window
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
138 (let ((frame (window-frame window)))
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
139 (make-frame-visible frame)
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
140 (raise-frame frame)
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
141 window))
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
142 ;; Reuse the current window if the user requested it.
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
143 (when (cdr (assq 'same-window args))
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
144 (condition-case nil
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
145 (progn (switch-to-buffer buffer) (selected-window))
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
146 (error nil)))
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
147 ;; Stay on the same frame if requested.
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
148 (when (or (cdr (assq 'same-frame args)) (cdr (assq 'same-window args)))
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
149 (let* ((pop-up-frames nil) (pop-up-windows t)
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
150 special-display-regexps special-display-buffer-names
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
151 (window (display-buffer buffer)))
55086
2c9194855ec9 (special-display-popup-frame, next-multiframe-window)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 53406
diff changeset
152 ;; Only do it if this is a new window:
39846
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
153 ;; (set-window-dedicated-p window t)
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
154 window))
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
155 ;; If no window yet, make one in a new frame.
59996
aac0a33f5772 Change release version from 21.4 to 22.1 throughout.
Kim F. Storm <storm@cua.dk>
parents: 57541
diff changeset
156 (let ((frame
57541
841073f11023 (special-display-popup-frame): Make the buffer current as its frame is created.
Richard M. Stallman <rms@gnu.org>
parents: 56759
diff changeset
157 (with-current-buffer buffer
841073f11023 (special-display-popup-frame): Make the buffer current as its frame is created.
Richard M. Stallman <rms@gnu.org>
parents: 56759
diff changeset
158 (make-frame (append args special-display-frame-alist)))))
39846
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
159 (set-window-buffer (frame-selected-window frame) buffer)
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
160 (set-window-dedicated-p (frame-selected-window frame) t)
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
161 (frame-selected-window frame))))))
7057
7102dd374da4 (special-display-frame-alist): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 7020
diff changeset
162
9175
df2f1773aa06 (handle-delete-frame): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8993
diff changeset
163 (defun handle-delete-frame (event)
25139
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
164 "Handle delete-frame events from the X server."
9175
df2f1773aa06 (handle-delete-frame): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8993
diff changeset
165 (interactive "e")
df2f1773aa06 (handle-delete-frame): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8993
diff changeset
166 (let ((frame (posn-window (event-start event)))
df2f1773aa06 (handle-delete-frame): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8993
diff changeset
167 (i 0)
df2f1773aa06 (handle-delete-frame): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8993
diff changeset
168 (tail (frame-list)))
df2f1773aa06 (handle-delete-frame): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8993
diff changeset
169 (while tail
df2f1773aa06 (handle-delete-frame): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8993
diff changeset
170 (and (frame-visible-p (car tail))
df2f1773aa06 (handle-delete-frame): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8993
diff changeset
171 (not (eq (car tail) frame))
df2f1773aa06 (handle-delete-frame): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8993
diff changeset
172 (setq i (1+ i)))
df2f1773aa06 (handle-delete-frame): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8993
diff changeset
173 (setq tail (cdr tail)))
df2f1773aa06 (handle-delete-frame): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8993
diff changeset
174 (if (> i 0)
df2f1773aa06 (handle-delete-frame): New function.
Richard M. Stallman <rms@gnu.org>
parents: 8993
diff changeset
175 (delete-frame frame t)
14701
ea592092c43c (handle-delete-frame): Use save-buffers-kill-emacs.
Richard M. Stallman <rms@gnu.org>
parents: 14169
diff changeset
176 ;; Gildea@x.org says it is ok to ask questions before terminating.
ea592092c43c (handle-delete-frame): Use save-buffers-kill-emacs.
Richard M. Stallman <rms@gnu.org>
parents: 14169
diff changeset
177 (save-buffers-kill-emacs))))
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
178
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
179 ;;;; Arrangement of frames at startup
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
180
39846
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
181 ;; 1) Load the window system startup file from the lisp library and read the
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
182 ;; high-priority arguments (-q and the like). The window system startup
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
183 ;; file should create any frames specified in the window system defaults.
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
184 ;;
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
185 ;; 2) If no frames have been opened, we open an initial text frame.
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
186 ;;
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
187 ;; 3) Once the init file is done, we apply any newly set parameters
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
188 ;; in initial-frame-alist to the frame.
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
189
10557
87b3ab910738 Fix typos.
Karl Heuer <kwzh@gnu.org>
parents: 10192
diff changeset
190 ;; These are now called explicitly at the proper times,
2763
a93e407bf41c Don't put frame-initialize and frame-notice-user-settings on hooks.
Richard M. Stallman <rms@gnu.org>
parents: 2571
diff changeset
191 ;; since that is easier to understand.
a93e407bf41c Don't put frame-initialize and frame-notice-user-settings on hooks.
Richard M. Stallman <rms@gnu.org>
parents: 2571
diff changeset
192 ;; Actually using hooks within Emacs is bad for future maintenance. --rms.
a93e407bf41c Don't put frame-initialize and frame-notice-user-settings on hooks.
Richard M. Stallman <rms@gnu.org>
parents: 2571
diff changeset
193 ;; (add-hook 'before-init-hook 'frame-initialize)
a93e407bf41c Don't put frame-initialize and frame-notice-user-settings on hooks.
Richard M. Stallman <rms@gnu.org>
parents: 2571
diff changeset
194 ;; (add-hook 'window-setup-hook 'frame-notice-user-settings)
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
195
39846
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
196 ;; If we create the initial frame, this is it.
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
197 (defvar frame-initial-frame nil)
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
198
4305
a39dcf68a29c (frame-notice-user-settings): Don't reapply a parm
Richard M. Stallman <rms@gnu.org>
parents: 3971
diff changeset
199 ;; Record the parameters used in frame-initialize to make the initial frame.
a39dcf68a29c (frame-notice-user-settings): Don't reapply a parm
Richard M. Stallman <rms@gnu.org>
parents: 3971
diff changeset
200 (defvar frame-initial-frame-alist)
a39dcf68a29c (frame-notice-user-settings): Don't reapply a parm
Richard M. Stallman <rms@gnu.org>
parents: 3971
diff changeset
201
7343
81f9ad98c323 (frame-notice-user-settings): When replacing the first
Richard M. Stallman <rms@gnu.org>
parents: 7322
diff changeset
202 (defvar frame-initial-geometry-arguments nil)
81f9ad98c323 (frame-notice-user-settings): When replacing the first
Richard M. Stallman <rms@gnu.org>
parents: 7322
diff changeset
203
39846
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
204 ;; startup.el calls this function before loading the user's init
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
205 ;; file - if there is no frame with a minibuffer open now, create
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
206 ;; one to display messages while loading the init file.
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
207 (defun frame-initialize ()
35697
6f48576daf85 (frame-initialize): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 35512
diff changeset
208 "Create an initial frame if necessary."
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
209 ;; Are we actually running under a window system at all?
83014
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
210 (if (and initial-window-system
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
211 (not noninteractive)
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
212 (not (eq initial-window-system 'pc)))
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
213 (progn
9737
1368ece6ec04 (frame-initialize): Set special-display-function here,
Richard M. Stallman <rms@gnu.org>
parents: 9687
diff changeset
214 ;; Turn on special-display processing only if there's a window system.
1368ece6ec04 (frame-initialize): Set special-display-function here,
Richard M. Stallman <rms@gnu.org>
parents: 9687
diff changeset
215 (setq special-display-function 'special-display-popup-frame)
1368ece6ec04 (frame-initialize): Set special-display-function here,
Richard M. Stallman <rms@gnu.org>
parents: 9687
diff changeset
216
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
217 ;; If there is no frame with a minibuffer besides the terminal
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
218 ;; frame, then we need to create the opening frame. Make sure
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
219 ;; it has a minibuffer, but let initial-frame-alist omit the
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
220 ;; minibuffer spec.
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
221 (or (delq terminal-frame (minibuffer-frame-list))
3050
8e2472cd4409 (frame-initialize): Handle `reverse' as parameter.
Richard M. Stallman <rms@gnu.org>
parents: 2870
diff changeset
222 (progn
4305
a39dcf68a29c (frame-notice-user-settings): Don't reapply a parm
Richard M. Stallman <rms@gnu.org>
parents: 3971
diff changeset
223 (setq frame-initial-frame-alist
35735
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
224 (append initial-frame-alist default-frame-alist nil))
7660
d47966265080 (frame-initialize): Record in frame-initial-frame-alist
Richard M. Stallman <rms@gnu.org>
parents: 7436
diff changeset
225 (or (assq 'horizontal-scroll-bars frame-initial-frame-alist)
d47966265080 (frame-initialize): Record in frame-initial-frame-alist
Richard M. Stallman <rms@gnu.org>
parents: 7436
diff changeset
226 (setq frame-initial-frame-alist
d47966265080 (frame-initialize): Record in frame-initial-frame-alist
Richard M. Stallman <rms@gnu.org>
parents: 7436
diff changeset
227 (cons '(horizontal-scroll-bars . t)
d47966265080 (frame-initialize): Record in frame-initial-frame-alist
Richard M. Stallman <rms@gnu.org>
parents: 7436
diff changeset
228 frame-initial-frame-alist)))
83014
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
229 (setq frame-initial-frame-alist
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
230 (cons (cons 'window-system initial-window-system)
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
231 frame-initial-frame-alist))
3050
8e2472cd4409 (frame-initialize): Handle `reverse' as parameter.
Richard M. Stallman <rms@gnu.org>
parents: 2870
diff changeset
232 (setq default-minibuffer-frame
8e2472cd4409 (frame-initialize): Handle `reverse' as parameter.
Richard M. Stallman <rms@gnu.org>
parents: 2870
diff changeset
233 (setq frame-initial-frame
18892
fb7337970b45 (frame-initialize): Don't alter vertical-scroll-bars
Richard M. Stallman <rms@gnu.org>
parents: 18481
diff changeset
234 (make-frame frame-initial-frame-alist)))
3433
2f5a9b79edf7 (frame-initialize): Delete geometry parms from initial-frame-alist.
Richard M. Stallman <rms@gnu.org>
parents: 3183
diff changeset
235 ;; Delete any specifications for window geometry parameters
2f5a9b79edf7 (frame-initialize): Delete geometry parms from initial-frame-alist.
Richard M. Stallman <rms@gnu.org>
parents: 3183
diff changeset
236 ;; so that we won't reapply them in frame-notice-user-settings.
2f5a9b79edf7 (frame-initialize): Delete geometry parms from initial-frame-alist.
Richard M. Stallman <rms@gnu.org>
parents: 3183
diff changeset
237 ;; It would be wrong to reapply them then,
2f5a9b79edf7 (frame-initialize): Delete geometry parms from initial-frame-alist.
Richard M. Stallman <rms@gnu.org>
parents: 3183
diff changeset
238 ;; because that would override explicit user resizing.
3971
6e7afc0a7fbc * frame.el (frame-remove-geometry-params): New function.
Jim Blandy <jimb@redhat.com>
parents: 3966
diff changeset
239 (setq initial-frame-alist
7309
beb9070c6fec (frame-initialize): Delete the code for reverse-video.
Richard M. Stallman <rms@gnu.org>
parents: 7300
diff changeset
240 (frame-remove-geometry-params initial-frame-alist))))
10557
87b3ab910738 Fix typos.
Karl Heuer <kwzh@gnu.org>
parents: 10192
diff changeset
241 ;; At this point, we know that we have a frame open, so we
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
242 ;; can delete the terminal frame.
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
243 (delete-frame terminal-frame)
83014
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
244 (setq terminal-frame nil))))
10557
87b3ab910738 Fix typos.
Karl Heuer <kwzh@gnu.org>
parents: 10192
diff changeset
245
27319
a896ba4a496b (frame-notice-user-settings): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 26332
diff changeset
246 (defvar frame-notice-user-settings t
a896ba4a496b (frame-notice-user-settings): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 26332
diff changeset
247 "Non-nil means function `frame-notice-user-settings' wasn't run yet.")
a896ba4a496b (frame-notice-user-settings): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 26332
diff changeset
248
39846
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
249 ;; startup.el calls this function after loading the user's init
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
250 ;; file. Now default-frame-alist and initial-frame-alist contain
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
251 ;; information to which we must react; do what needs to be done.
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
252 (defun frame-notice-user-settings ()
25139
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
253 "Act on user's init file settings of frame parameters.
83360
0036e612aaef Apply settings in `window-system-default-frame-alist' to the initial frame as well.
Karoly Lorentey <lorentey@elte.hu>
parents: 83353
diff changeset
254 React to settings of `initial-frame-alist',
0036e612aaef Apply settings in `window-system-default-frame-alist' to the initial frame as well.
Karoly Lorentey <lorentey@elte.hu>
parents: 83353
diff changeset
255 `window-system-default-frame-alist' and `default-frame-alist'
0036e612aaef Apply settings in `window-system-default-frame-alist' to the initial frame as well.
Karoly Lorentey <lorentey@elte.hu>
parents: 83353
diff changeset
256 there (in decreasing order of priority)."
8056
1c5fd2cdfb36 (frame-notice-user-settings): Make menu-bar-mode
Richard M. Stallman <rms@gnu.org>
parents: 7712
diff changeset
257 ;; Make menu-bar-mode and default-frame-alist consistent.
31899
ce212cd0463f (frame-notice-user-settings): Make tool-bar-mode and
Gerd Moellmann <gerd@gnu.org>
parents: 31771
diff changeset
258 (when (boundp 'menu-bar-mode)
ce212cd0463f (frame-notice-user-settings): Make tool-bar-mode and
Gerd Moellmann <gerd@gnu.org>
parents: 31771
diff changeset
259 (let ((default (assq 'menu-bar-lines default-frame-alist)))
ce212cd0463f (frame-notice-user-settings): Make tool-bar-mode and
Gerd Moellmann <gerd@gnu.org>
parents: 31771
diff changeset
260 (if default
ce212cd0463f (frame-notice-user-settings): Make tool-bar-mode and
Gerd Moellmann <gerd@gnu.org>
parents: 31771
diff changeset
261 (setq menu-bar-mode (not (eq (cdr default) 0)))
ce212cd0463f (frame-notice-user-settings): Make tool-bar-mode and
Gerd Moellmann <gerd@gnu.org>
parents: 31771
diff changeset
262 (setq default-frame-alist
ce212cd0463f (frame-notice-user-settings): Make tool-bar-mode and
Gerd Moellmann <gerd@gnu.org>
parents: 31771
diff changeset
263 (cons (cons 'menu-bar-lines (if menu-bar-mode 1 0))
ce212cd0463f (frame-notice-user-settings): Make tool-bar-mode and
Gerd Moellmann <gerd@gnu.org>
parents: 31771
diff changeset
264 default-frame-alist)))))
41579
bab6e8eba0e1 comments indented properly
Sam Steingold <sds@gnu.org>
parents: 40673
diff changeset
265
31910
b54fba72959b (frame-notice-user-settings): Don't add a
Gerd Moellmann <gerd@gnu.org>
parents: 31899
diff changeset
266 ;; Make tool-bar-mode and default-frame-alist consistent. Don't do
b54fba72959b (frame-notice-user-settings): Don't add a
Gerd Moellmann <gerd@gnu.org>
parents: 31899
diff changeset
267 ;; it in batch mode since that would leave a tool-bar-lines
b54fba72959b (frame-notice-user-settings): Don't add a
Gerd Moellmann <gerd@gnu.org>
parents: 31899
diff changeset
268 ;; parameter in default-frame-alist in a dumped Emacs, which is not
35735
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
269 ;; what we want.
31910
b54fba72959b (frame-notice-user-settings): Don't add a
Gerd Moellmann <gerd@gnu.org>
parents: 31899
diff changeset
270 (when (and (boundp 'tool-bar-mode)
b54fba72959b (frame-notice-user-settings): Don't add a
Gerd Moellmann <gerd@gnu.org>
parents: 31899
diff changeset
271 (not noninteractive))
31899
ce212cd0463f (frame-notice-user-settings): Make tool-bar-mode and
Gerd Moellmann <gerd@gnu.org>
parents: 31771
diff changeset
272 (let ((default (assq 'tool-bar-lines default-frame-alist)))
ce212cd0463f (frame-notice-user-settings): Make tool-bar-mode and
Gerd Moellmann <gerd@gnu.org>
parents: 31771
diff changeset
273 (if default
ce212cd0463f (frame-notice-user-settings): Make tool-bar-mode and
Gerd Moellmann <gerd@gnu.org>
parents: 31771
diff changeset
274 (setq tool-bar-mode (not (eq (cdr default) 0)))
ce212cd0463f (frame-notice-user-settings): Make tool-bar-mode and
Gerd Moellmann <gerd@gnu.org>
parents: 31771
diff changeset
275 (setq default-frame-alist
ce212cd0463f (frame-notice-user-settings): Make tool-bar-mode and
Gerd Moellmann <gerd@gnu.org>
parents: 31771
diff changeset
276 (cons (cons 'tool-bar-lines (if tool-bar-mode 1 0))
ce212cd0463f (frame-notice-user-settings): Make tool-bar-mode and
Gerd Moellmann <gerd@gnu.org>
parents: 31771
diff changeset
277 default-frame-alist)))))
8056
1c5fd2cdfb36 (frame-notice-user-settings): Make menu-bar-mode
Richard M. Stallman <rms@gnu.org>
parents: 7712
diff changeset
278
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
279 ;; Creating and deleting frames may shift the selected frame around,
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
280 ;; and thus the current buffer. Protect against that. We don't
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
281 ;; want to use save-excursion here, because that may also try to set
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
282 ;; the buffer of the selected window, which fails when the selected
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
283 ;; window is the minibuffer.
83360
0036e612aaef Apply settings in `window-system-default-frame-alist' to the initial frame as well.
Karoly Lorentey <lorentey@elte.hu>
parents: 83353
diff changeset
284 (let ((old-buffer (current-buffer))
0036e612aaef Apply settings in `window-system-default-frame-alist' to the initial frame as well.
Karoly Lorentey <lorentey@elte.hu>
parents: 83353
diff changeset
285 (window-system-frame-alist (cdr (assq initial-window-system
0036e612aaef Apply settings in `window-system-default-frame-alist' to the initial frame as well.
Karoly Lorentey <lorentey@elte.hu>
parents: 83353
diff changeset
286 window-system-default-frame-alist))))
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
287
27319
a896ba4a496b (frame-notice-user-settings): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 26332
diff changeset
288 (when (and frame-notice-user-settings
a896ba4a496b (frame-notice-user-settings): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 26332
diff changeset
289 (null frame-initial-frame))
33009
e7cb49941cb1 (frame-notice-user-settings): Don't apply
Eli Zaretskii <eliz@gnu.org>
parents: 32752
diff changeset
290 ;; This case happens when we don't have a window system, and
e7cb49941cb1 (frame-notice-user-settings): Don't apply
Eli Zaretskii <eliz@gnu.org>
parents: 32752
diff changeset
291 ;; also for MS-DOS frames.
27319
a896ba4a496b (frame-notice-user-settings): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 26332
diff changeset
292 (let ((parms (frame-parameters frame-initial-frame)))
a896ba4a496b (frame-notice-user-settings): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 26332
diff changeset
293 ;; Don't change the frame names.
a896ba4a496b (frame-notice-user-settings): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 26332
diff changeset
294 (setq parms (delq (assq 'name parms) parms))
a896ba4a496b (frame-notice-user-settings): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 26332
diff changeset
295 ;; Can't modify the minibuffer parameter, so don't try.
a896ba4a496b (frame-notice-user-settings): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 26332
diff changeset
296 (setq parms (delq (assq 'minibuffer parms) parms))
a896ba4a496b (frame-notice-user-settings): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 26332
diff changeset
297 (modify-frame-parameters nil
83014
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
298 (if (null initial-window-system)
33009
e7cb49941cb1 (frame-notice-user-settings): Don't apply
Eli Zaretskii <eliz@gnu.org>
parents: 32752
diff changeset
299 (append initial-frame-alist
83360
0036e612aaef Apply settings in `window-system-default-frame-alist' to the initial frame as well.
Karoly Lorentey <lorentey@elte.hu>
parents: 83353
diff changeset
300 window-system-frame-alist
33009
e7cb49941cb1 (frame-notice-user-settings): Don't apply
Eli Zaretskii <eliz@gnu.org>
parents: 32752
diff changeset
301 default-frame-alist
e7cb49941cb1 (frame-notice-user-settings): Don't apply
Eli Zaretskii <eliz@gnu.org>
parents: 32752
diff changeset
302 parms
e7cb49941cb1 (frame-notice-user-settings): Don't apply
Eli Zaretskii <eliz@gnu.org>
parents: 32752
diff changeset
303 nil)
e7cb49941cb1 (frame-notice-user-settings): Don't apply
Eli Zaretskii <eliz@gnu.org>
parents: 32752
diff changeset
304 ;; initial-frame-alist and
e7cb49941cb1 (frame-notice-user-settings): Don't apply
Eli Zaretskii <eliz@gnu.org>
parents: 32752
diff changeset
305 ;; default-frame-alist were already
e7cb49941cb1 (frame-notice-user-settings): Don't apply
Eli Zaretskii <eliz@gnu.org>
parents: 32752
diff changeset
306 ;; applied in pc-win.el.
e7cb49941cb1 (frame-notice-user-settings): Don't apply
Eli Zaretskii <eliz@gnu.org>
parents: 32752
diff changeset
307 parms))
83014
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
308 (if (null initial-window-system) ;; MS-DOS does this differently in pc-win.el
33009
e7cb49941cb1 (frame-notice-user-settings): Don't apply
Eli Zaretskii <eliz@gnu.org>
parents: 32752
diff changeset
309 (let ((newparms (frame-parameters))
e7cb49941cb1 (frame-notice-user-settings): Don't apply
Eli Zaretskii <eliz@gnu.org>
parents: 32752
diff changeset
310 (frame (selected-frame)))
e7cb49941cb1 (frame-notice-user-settings): Don't apply
Eli Zaretskii <eliz@gnu.org>
parents: 32752
diff changeset
311 (tty-handle-reverse-video frame newparms)
e7cb49941cb1 (frame-notice-user-settings): Don't apply
Eli Zaretskii <eliz@gnu.org>
parents: 32752
diff changeset
312 ;; If we changed the background color, we need to update
e7cb49941cb1 (frame-notice-user-settings): Don't apply
Eli Zaretskii <eliz@gnu.org>
parents: 32752
diff changeset
313 ;; the background-mode parameter, and maybe some faces,
e7cb49941cb1 (frame-notice-user-settings): Don't apply
Eli Zaretskii <eliz@gnu.org>
parents: 32752
diff changeset
314 ;; too.
e7cb49941cb1 (frame-notice-user-settings): Don't apply
Eli Zaretskii <eliz@gnu.org>
parents: 32752
diff changeset
315 (when (assq 'background-color newparms)
e7cb49941cb1 (frame-notice-user-settings): Don't apply
Eli Zaretskii <eliz@gnu.org>
parents: 32752
diff changeset
316 (unless (or (assq 'background-mode initial-frame-alist)
e7cb49941cb1 (frame-notice-user-settings): Don't apply
Eli Zaretskii <eliz@gnu.org>
parents: 32752
diff changeset
317 (assq 'background-mode default-frame-alist))
e7cb49941cb1 (frame-notice-user-settings): Don't apply
Eli Zaretskii <eliz@gnu.org>
parents: 32752
diff changeset
318 (frame-set-background-mode frame))
e7cb49941cb1 (frame-notice-user-settings): Don't apply
Eli Zaretskii <eliz@gnu.org>
parents: 32752
diff changeset
319 (face-set-after-frame-default frame))))))
27319
a896ba4a496b (frame-notice-user-settings): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 26332
diff changeset
320
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
321 ;; If the initial frame is still around, apply initial-frame-alist
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
322 ;; and default-frame-alist to it.
35735
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
323 (when (frame-live-p frame-initial-frame)
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
324
35735
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
325 ;; When tool-bar has been switched off, correct the frame size
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
326 ;; by the lines added in x-create-frame for the tool-bar and
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
327 ;; switch `tool-bar-mode' off.
35856
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
328 (when (display-graphic-p)
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
329 (let ((tool-bar-lines (or (assq 'tool-bar-lines initial-frame-alist)
83360
0036e612aaef Apply settings in `window-system-default-frame-alist' to the initial frame as well.
Karoly Lorentey <lorentey@elte.hu>
parents: 83353
diff changeset
330 (assq 'tool-bar-lines window-system-frame-alist)
35856
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
331 (assq 'tool-bar-lines default-frame-alist))))
36317
34ffe86aeeae (frame-notice-user-settings): Only adjust frame height
Jason Rumney <jasonr@gnu.org>
parents: 36257
diff changeset
332 (when (and tool-bar-originally-present
34ffe86aeeae (frame-notice-user-settings): Only adjust frame height
Jason Rumney <jasonr@gnu.org>
parents: 36257
diff changeset
333 (or (null tool-bar-lines)
34ffe86aeeae (frame-notice-user-settings): Only adjust frame height
Jason Rumney <jasonr@gnu.org>
parents: 36257
diff changeset
334 (null (cdr tool-bar-lines))
34ffe86aeeae (frame-notice-user-settings): Only adjust frame height
Jason Rumney <jasonr@gnu.org>
parents: 36257
diff changeset
335 (eq 0 (cdr tool-bar-lines))))
35856
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
336 (let* ((char-height (frame-char-height frame-initial-frame))
36317
34ffe86aeeae (frame-notice-user-settings): Only adjust frame height
Jason Rumney <jasonr@gnu.org>
parents: 36257
diff changeset
337 (image-height tool-bar-images-pixel-height)
35856
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
338 (margin (cond ((and (consp tool-bar-button-margin)
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
339 (integerp (cdr tool-bar-button-margin))
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
340 (> tool-bar-button-margin 0))
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
341 (cdr tool-bar-button-margin))
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
342 ((and (integerp tool-bar-button-margin)
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
343 (> tool-bar-button-margin 0))
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
344 tool-bar-button-margin)
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
345 (t 0)))
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
346 (relief (if (and (integerp tool-bar-button-relief)
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
347 (> tool-bar-button-relief 0))
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
348 tool-bar-button-relief 3))
41579
bab6e8eba0e1 comments indented properly
Sam Steingold <sds@gnu.org>
parents: 40673
diff changeset
349 (lines (/ (+ image-height
35856
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
350 (* 2 margin)
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
351 (* 2 relief)
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
352 (1- char-height))
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
353 char-height))
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
354 (height (frame-parameter frame-initial-frame 'height))
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
355 (newparms (list (cons 'height (- height lines))))
41579
bab6e8eba0e1 comments indented properly
Sam Steingold <sds@gnu.org>
parents: 40673
diff changeset
356 (initial-top (cdr (assq 'top
35856
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
357 frame-initial-geometry-arguments)))
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
358 (top (frame-parameter frame-initial-frame 'top)))
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
359 (when (and (consp initial-top) (eq '- (car initial-top)))
53406
45cc6f8abd8d (pop-up-frame-function): Use quote, not `function'.
Richard M. Stallman <rms@gnu.org>
parents: 52614
diff changeset
360 (let ((adjusted-top
45cc6f8abd8d (pop-up-frame-function): Use quote, not `function'.
Richard M. Stallman <rms@gnu.org>
parents: 52614
diff changeset
361 (cond ((and (consp top)
45cc6f8abd8d (pop-up-frame-function): Use quote, not `function'.
Richard M. Stallman <rms@gnu.org>
parents: 52614
diff changeset
362 (eq '+ (car top)))
45cc6f8abd8d (pop-up-frame-function): Use quote, not `function'.
Richard M. Stallman <rms@gnu.org>
parents: 52614
diff changeset
363 (list '+
45cc6f8abd8d (pop-up-frame-function): Use quote, not `function'.
Richard M. Stallman <rms@gnu.org>
parents: 52614
diff changeset
364 (+ (cadr top)
45cc6f8abd8d (pop-up-frame-function): Use quote, not `function'.
Richard M. Stallman <rms@gnu.org>
parents: 52614
diff changeset
365 (* lines char-height))))
45cc6f8abd8d (pop-up-frame-function): Use quote, not `function'.
Richard M. Stallman <rms@gnu.org>
parents: 52614
diff changeset
366 ((and (consp top)
45cc6f8abd8d (pop-up-frame-function): Use quote, not `function'.
Richard M. Stallman <rms@gnu.org>
parents: 52614
diff changeset
367 (eq '- (car top)))
45cc6f8abd8d (pop-up-frame-function): Use quote, not `function'.
Richard M. Stallman <rms@gnu.org>
parents: 52614
diff changeset
368 (list '-
45cc6f8abd8d (pop-up-frame-function): Use quote, not `function'.
Richard M. Stallman <rms@gnu.org>
parents: 52614
diff changeset
369 (- (cadr top)
45cc6f8abd8d (pop-up-frame-function): Use quote, not `function'.
Richard M. Stallman <rms@gnu.org>
parents: 52614
diff changeset
370 (* lines char-height))))
45cc6f8abd8d (pop-up-frame-function): Use quote, not `function'.
Richard M. Stallman <rms@gnu.org>
parents: 52614
diff changeset
371 (t (+ top (* lines char-height))))))
45cc6f8abd8d (pop-up-frame-function): Use quote, not `function'.
Richard M. Stallman <rms@gnu.org>
parents: 52614
diff changeset
372 (setq newparms
45cc6f8abd8d (pop-up-frame-function): Use quote, not `function'.
Richard M. Stallman <rms@gnu.org>
parents: 52614
diff changeset
373 (append newparms
45cc6f8abd8d (pop-up-frame-function): Use quote, not `function'.
Richard M. Stallman <rms@gnu.org>
parents: 52614
diff changeset
374 `((top . ,adjusted-top))
45cc6f8abd8d (pop-up-frame-function): Use quote, not `function'.
Richard M. Stallman <rms@gnu.org>
parents: 52614
diff changeset
375 nil))))
35856
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
376 (modify-frame-parameters frame-initial-frame newparms)
41652bd90468 (frame-notice-user-settings): When resizing the initial
Gerd Moellmann <gerd@gnu.org>
parents: 35738
diff changeset
377 (tool-bar-mode -1)))))
35735
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
378
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
379 ;; The initial frame we create above always has a minibuffer.
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
380 ;; If the user wants to remove it, or make it a minibuffer-only
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
381 ;; frame, then we'll have to delete the current frame and make a
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
382 ;; new one; you can't remove or add a root window to/from an
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
383 ;; existing frame.
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
384 ;;
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
385 ;; NOTE: default-frame-alist was nil when we created the
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
386 ;; existing frame. We need to explicitly include
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
387 ;; default-frame-alist in the parameters of the screen we
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
388 ;; create here, so that its new value, gleaned from the user's
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
389 ;; .emacs file, will be applied to the existing screen.
35738
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
390 (if (not (eq (cdr (or (assq 'minibuffer initial-frame-alist)
83360
0036e612aaef Apply settings in `window-system-default-frame-alist' to the initial frame as well.
Karoly Lorentey <lorentey@elte.hu>
parents: 83353
diff changeset
391 (assq 'minibuffer window-system-frame-alist)
35738
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
392 (assq 'minibuffer default-frame-alist)
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
393 '(minibuffer . t)))
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
394 t))
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
395 ;; Create the new frame.
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
396 (let (parms new)
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
397 ;; If the frame isn't visible yet, wait till it is.
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
398 ;; If the user has to position the window,
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
399 ;; Emacs doesn't know its real position until
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
400 ;; the frame is seen to be visible.
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
401 (while (not (cdr (assq 'visibility
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
402 (frame-parameters frame-initial-frame))))
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
403 (sleep-for 1))
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
404 (setq parms (frame-parameters frame-initial-frame))
35735
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
405
41579
bab6e8eba0e1 comments indented properly
Sam Steingold <sds@gnu.org>
parents: 40673
diff changeset
406 ;; Get rid of `name' unless it was specified explicitly before.
35738
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
407 (or (assq 'name frame-initial-frame-alist)
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
408 (setq parms (delq (assq 'name parms) parms)))
35735
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
409
35738
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
410 (setq parms (append initial-frame-alist
83360
0036e612aaef Apply settings in `window-system-default-frame-alist' to the initial frame as well.
Karoly Lorentey <lorentey@elte.hu>
parents: 83353
diff changeset
411 window-system-frame-alist
35738
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
412 default-frame-alist
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
413 parms
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
414 nil))
35735
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
415
35738
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
416 ;; Get rid of `reverse', because that was handled
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
417 ;; when we first made the frame.
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
418 (setq parms (cons '(reverse) (delq (assq 'reverse parms) parms)))
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
419
35738
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
420 (if (assq 'height frame-initial-geometry-arguments)
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
421 (setq parms (assq-delete-all 'height parms)))
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
422 (if (assq 'width frame-initial-geometry-arguments)
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
423 (setq parms (assq-delete-all 'width parms)))
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
424 (if (assq 'left frame-initial-geometry-arguments)
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
425 (setq parms (assq-delete-all 'left parms)))
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
426 (if (assq 'top frame-initial-geometry-arguments)
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
427 (setq parms (assq-delete-all 'top parms)))
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
428 (setq new
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
429 (make-frame
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
430 ;; Use the geometry args that created the existing
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
431 ;; frame, rather than the parms we get for it.
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
432 (append frame-initial-geometry-arguments
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
433 '((user-size . t) (user-position . t))
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
434 parms)))
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
435 ;; The initial frame, which we are about to delete, may be
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
436 ;; the only frame with a minibuffer. If it is, create a
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
437 ;; new one.
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
438 (or (delq frame-initial-frame (minibuffer-frame-list))
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
439 (make-initial-minibuffer-frame nil))
35735
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
440
35738
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
441 ;; If the initial frame is serving as a surrogate
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
442 ;; minibuffer frame for any frames, we need to wean them
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
443 ;; onto a new frame. The default-minibuffer-frame
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
444 ;; variable must be handled similarly.
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
445 (let ((users-of-initial
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
446 (filtered-frame-list
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
447 (function (lambda (frame)
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
448 (and (not (eq frame frame-initial-frame))
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
449 (eq (window-frame
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
450 (minibuffer-window frame))
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
451 frame-initial-frame)))))))
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
452 (if (or users-of-initial
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
453 (eq default-minibuffer-frame frame-initial-frame))
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
454
35738
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
455 ;; Choose an appropriate frame. Prefer frames which
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
456 ;; are only minibuffers.
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
457 (let* ((new-surrogate
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
458 (car
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
459 (or (filtered-frame-list
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
460 (function
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
461 (lambda (frame)
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
462 (eq (cdr (assq 'minibuffer
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
463 (frame-parameters frame)))
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
464 'only))))
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
465 (minibuffer-frame-list))))
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
466 (new-minibuffer (minibuffer-window new-surrogate)))
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
467
35738
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
468 (if (eq default-minibuffer-frame frame-initial-frame)
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
469 (setq default-minibuffer-frame new-surrogate))
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
470
35738
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
471 ;; Wean the frames using frame-initial-frame as
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
472 ;; their minibuffer frame.
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
473 (mapcar
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
474 (function
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
475 (lambda (frame)
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
476 (modify-frame-parameters
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
477 frame (list (cons 'minibuffer new-minibuffer)))))
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
478 users-of-initial))))
1113
0ffcf74fb8ad entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 958
diff changeset
479
35738
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
480 ;; Redirect events enqueued at this frame to the new frame.
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
481 ;; Is this a good idea?
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
482 (redirect-frame-focus frame-initial-frame new)
1113
0ffcf74fb8ad entered into RCS
Jim Blandy <jimb@redhat.com>
parents: 958
diff changeset
483
35738
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
484 ;; Finally, get rid of the old frame.
7b487e845547 (frame-notice-user-settings): Do the tool-bar
Gerd Moellmann <gerd@gnu.org>
parents: 35735
diff changeset
485 (delete-frame frame-initial-frame t))
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
486
35735
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
487 ;; Otherwise, we don't need all that rigamarole; just apply
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
488 ;; the new parameters.
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
489 (let (newparms allparms tail)
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
490 (setq allparms (append initial-frame-alist
83360
0036e612aaef Apply settings in `window-system-default-frame-alist' to the initial frame as well.
Karoly Lorentey <lorentey@elte.hu>
parents: 83353
diff changeset
491 window-system-frame-alist
35735
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
492 default-frame-alist nil))
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
493 (if (assq 'height frame-initial-geometry-arguments)
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
494 (setq allparms (assq-delete-all 'height allparms)))
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
495 (if (assq 'width frame-initial-geometry-arguments)
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
496 (setq allparms (assq-delete-all 'width allparms)))
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
497 (if (assq 'left frame-initial-geometry-arguments)
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
498 (setq allparms (assq-delete-all 'left allparms)))
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
499 (if (assq 'top frame-initial-geometry-arguments)
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
500 (setq allparms (assq-delete-all 'top allparms)))
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
501 (setq tail allparms)
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
502 ;; Find just the parms that have changed since we first
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
503 ;; made this frame. Those are the ones actually set by
41579
bab6e8eba0e1 comments indented properly
Sam Steingold <sds@gnu.org>
parents: 40673
diff changeset
504 ;; the init file. For those parms whose values we already knew
35735
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
505 ;; (such as those spec'd by command line options)
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
506 ;; it is undesirable to specify the parm again
41579
bab6e8eba0e1 comments indented properly
Sam Steingold <sds@gnu.org>
parents: 40673
diff changeset
507 ;; once the user has seen the frame and been able to alter it
35735
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
508 ;; manually.
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
509 (while tail
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
510 (let (newval oldval)
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
511 (setq oldval (assq (car (car tail))
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
512 frame-initial-frame-alist))
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
513 (setq newval (cdr (assq (car (car tail)) allparms)))
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
514 (or (and oldval (eq (cdr oldval) newval))
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
515 (setq newparms
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
516 (cons (cons (car (car tail)) newval) newparms))))
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
517 (setq tail (cdr tail)))
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
518 (setq newparms (nreverse newparms))
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
519 (modify-frame-parameters frame-initial-frame
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
520 newparms)
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
521 ;; If we changed the background color,
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
522 ;; we need to update the background-mode parameter
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
523 ;; and maybe some faces too.
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
524 (when (assq 'background-color newparms)
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
525 (unless (assq 'background-mode newparms)
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
526 (frame-set-background-mode frame-initial-frame))
e20f7bc75418 (frame-initialize): Create initial frame visible.
Gerd Moellmann <gerd@gnu.org>
parents: 35697
diff changeset
527 (face-set-after-frame-default frame-initial-frame)))))
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
528
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
529 ;; Restore the original buffer.
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
530 (set-buffer old-buffer)
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
531
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
532 ;; Make sure the initial frame can be GC'd if it is ever deleted.
2870
cd270fa53052 * frame.el (frame-notice-user-settings): Don't make
Jim Blandy <jimb@redhat.com>
parents: 2846
diff changeset
533 ;; Make sure frame-notice-user-settings does nothing if called twice.
27319
a896ba4a496b (frame-notice-user-settings): New variable.
Gerd Moellmann <gerd@gnu.org>
parents: 26332
diff changeset
534 (setq frame-notice-user-settings nil)
2870
cd270fa53052 * frame.el (frame-notice-user-settings): Don't make
Jim Blandy <jimb@redhat.com>
parents: 2846
diff changeset
535 (setq frame-initial-frame nil)))
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
536
12012
26aeed5ef544 (make-initial-minibuffer-frame): New function.
Karl Heuer <kwzh@gnu.org>
parents: 11485
diff changeset
537 (defun make-initial-minibuffer-frame (display)
26aeed5ef544 (make-initial-minibuffer-frame): New function.
Karl Heuer <kwzh@gnu.org>
parents: 11485
diff changeset
538 (let ((parms (append minibuffer-frame-alist '((minibuffer . only)))))
26aeed5ef544 (make-initial-minibuffer-frame): New function.
Karl Heuer <kwzh@gnu.org>
parents: 11485
diff changeset
539 (if display
26aeed5ef544 (make-initial-minibuffer-frame): New function.
Karl Heuer <kwzh@gnu.org>
parents: 11485
diff changeset
540 (make-frame-on-display display parms)
26aeed5ef544 (make-initial-minibuffer-frame): New function.
Karl Heuer <kwzh@gnu.org>
parents: 11485
diff changeset
541 (make-frame parms))))
26aeed5ef544 (make-initial-minibuffer-frame): New function.
Karl Heuer <kwzh@gnu.org>
parents: 11485
diff changeset
542
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
543 ;;;; Creation of additional frames, and other frame miscellanea
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
544
51901
48f24a9d5a64 (modify-all-frames-parameters): Reinstall (copyright papers received).
Juanma Barranquero <lekktu@gmail.com>
parents: 51507
diff changeset
545 (defun modify-all-frames-parameters (alist)
56507
8a0830a6f469 (modify-all-frames-parameters): Minor doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56491
diff changeset
546 "Modify all current and future frames' parameters according to ALIST.
51901
48f24a9d5a64 (modify-all-frames-parameters): Reinstall (copyright papers received).
Juanma Barranquero <lekktu@gmail.com>
parents: 51507
diff changeset
547 This changes `default-frame-alist' and possibly `initial-frame-alist'.
48f24a9d5a64 (modify-all-frames-parameters): Reinstall (copyright papers received).
Juanma Barranquero <lekktu@gmail.com>
parents: 51507
diff changeset
548 See help of `modify-frame-parameters' for more information."
48f24a9d5a64 (modify-all-frames-parameters): Reinstall (copyright papers received).
Juanma Barranquero <lekktu@gmail.com>
parents: 51507
diff changeset
549 (let (element) ;; temp
48f24a9d5a64 (modify-all-frames-parameters): Reinstall (copyright papers received).
Juanma Barranquero <lekktu@gmail.com>
parents: 51507
diff changeset
550 (dolist (frame (frame-list))
48f24a9d5a64 (modify-all-frames-parameters): Reinstall (copyright papers received).
Juanma Barranquero <lekktu@gmail.com>
parents: 51507
diff changeset
551 (modify-frame-parameters frame alist))
48f24a9d5a64 (modify-all-frames-parameters): Reinstall (copyright papers received).
Juanma Barranquero <lekktu@gmail.com>
parents: 51507
diff changeset
552
48f24a9d5a64 (modify-all-frames-parameters): Reinstall (copyright papers received).
Juanma Barranquero <lekktu@gmail.com>
parents: 51507
diff changeset
553 (dolist (pair alist) ;; conses to add/replace
48f24a9d5a64 (modify-all-frames-parameters): Reinstall (copyright papers received).
Juanma Barranquero <lekktu@gmail.com>
parents: 51507
diff changeset
554 ;; initial-frame-alist needs setting only when
48f24a9d5a64 (modify-all-frames-parameters): Reinstall (copyright papers received).
Juanma Barranquero <lekktu@gmail.com>
parents: 51507
diff changeset
555 ;; frame-notice-user-settings is true
48f24a9d5a64 (modify-all-frames-parameters): Reinstall (copyright papers received).
Juanma Barranquero <lekktu@gmail.com>
parents: 51507
diff changeset
556 (and frame-notice-user-settings
48f24a9d5a64 (modify-all-frames-parameters): Reinstall (copyright papers received).
Juanma Barranquero <lekktu@gmail.com>
parents: 51507
diff changeset
557 (setq element (assoc (car pair) initial-frame-alist))
48f24a9d5a64 (modify-all-frames-parameters): Reinstall (copyright papers received).
Juanma Barranquero <lekktu@gmail.com>
parents: 51507
diff changeset
558 (setq initial-frame-alist (delq element initial-frame-alist)))
48f24a9d5a64 (modify-all-frames-parameters): Reinstall (copyright papers received).
Juanma Barranquero <lekktu@gmail.com>
parents: 51507
diff changeset
559 (and (setq element (assoc (car pair) default-frame-alist))
48f24a9d5a64 (modify-all-frames-parameters): Reinstall (copyright papers received).
Juanma Barranquero <lekktu@gmail.com>
parents: 51507
diff changeset
560 (setq default-frame-alist (delq element default-frame-alist)))))
48f24a9d5a64 (modify-all-frames-parameters): Reinstall (copyright papers received).
Juanma Barranquero <lekktu@gmail.com>
parents: 51507
diff changeset
561 (and frame-notice-user-settings
48f24a9d5a64 (modify-all-frames-parameters): Reinstall (copyright papers received).
Juanma Barranquero <lekktu@gmail.com>
parents: 51507
diff changeset
562 (setq initial-frame-alist (append initial-frame-alist alist)))
48f24a9d5a64 (modify-all-frames-parameters): Reinstall (copyright papers received).
Juanma Barranquero <lekktu@gmail.com>
parents: 51507
diff changeset
563 (setq default-frame-alist (append default-frame-alist alist)))
48f24a9d5a64 (modify-all-frames-parameters): Reinstall (copyright papers received).
Juanma Barranquero <lekktu@gmail.com>
parents: 51507
diff changeset
564
827
731cb9bcbad0 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 826
diff changeset
565 (defun get-other-frame ()
25139
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
566 "Return some frame other than the current frame.
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
567 Create one if necessary. Note that the minibuffer frame, if separate,
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
568 is not considered (see `next-frame')."
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
569 (let ((s (if (equal (next-frame (selected-frame)) (selected-frame))
7322
1f3536445289 (frame-notice-user-settings): Discard `reverse' when
Richard M. Stallman <rms@gnu.org>
parents: 7309
diff changeset
570 (make-frame)
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
571 (next-frame (selected-frame)))))
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
572 s))
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
573
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
574 (defun next-multiframe-window ()
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
575 "Select the next window, regardless of which frame it is on."
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
576 (interactive)
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
577 (select-window (next-window (selected-window)
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
578 (> (minibuffer-depth) 0)
55086
2c9194855ec9 (special-display-popup-frame, next-multiframe-window)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 53406
diff changeset
579 0))
38781
c20b98060a6d (select-frame-set-input-focus): New function
Gerd Moellmann <gerd@gnu.org>
parents: 38469
diff changeset
580 (select-frame-set-input-focus (selected-frame)))
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
581
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
582 (defun previous-multiframe-window ()
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
583 "Select the previous window, regardless of which frame it is on."
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
584 (interactive)
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
585 (select-window (previous-window (selected-window)
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
586 (> (minibuffer-depth) 0)
55086
2c9194855ec9 (special-display-popup-frame, next-multiframe-window)
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 53406
diff changeset
587 0))
38781
c20b98060a6d (select-frame-set-input-focus): New function
Gerd Moellmann <gerd@gnu.org>
parents: 38469
diff changeset
588 (select-frame-set-input-focus (selected-frame)))
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
589
9687
1048e2d032e6 (make-frame-on-display): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9175
diff changeset
590 (defun make-frame-on-display (display &optional parameters)
83167
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
591 "Make a frame on X display DISPLAY.
9687
1048e2d032e6 (make-frame-on-display): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9175
diff changeset
592 The optional second argument PARAMETERS specifies additional frame parameters."
1048e2d032e6 (make-frame-on-display): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9175
diff changeset
593 (interactive "sMake frame on display: ")
22232
96217e8a9b7f (make-frame-on-display): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 22224
diff changeset
594 (or (string-match "\\`[^:]*:[0-9]+\\(\\.[0-9]+\\)?\\'" display)
96217e8a9b7f (make-frame-on-display): Fix previous change.
Richard M. Stallman <rms@gnu.org>
parents: 22224
diff changeset
595 (error "Invalid display, not HOST:SERVER or HOST:SERVER.SCREEN"))
83246
5bc762f84335 Prevent emacsclient errors when Emacs is compiled without X support.
Karoly Lorentey <lorentey@elte.hu>
parents: 83221
diff changeset
596 (when (and (boundp 'x-initialized) (not x-initialized))
83018
1465425fe2d3 Romain Francoise's and Ami Fischman's bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83016
diff changeset
597 (setq x-display-name display)
1465425fe2d3 Romain Francoise's and Ami Fischman's bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83016
diff changeset
598 (x-initialize-window-system))
83014
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
599 (make-frame `((window-system . x) (display . ,display) . ,parameters)))
9687
1048e2d032e6 (make-frame-on-display): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9175
diff changeset
600
53233
fe9b37bee5f7 Fully eliminated global tty state variables.
Karoly Lorentey <lorentey@elte.hu>
parents: 52614
diff changeset
601 (defun make-frame-on-tty (device type &optional parameters)
fe9b37bee5f7 Fully eliminated global tty state variables.
Karoly Lorentey <lorentey@elte.hu>
parents: 52614
diff changeset
602 "Make a frame on terminal DEVICE which is of type TYPE (e.g., \"xterm\").
83014
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
603 The optional third argument PARAMETERS specifies additional frame parameters."
83004
7900111db01c Converted display hooks to be display-local. Plus many bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 82990
diff changeset
604 (interactive "fOpen frame on tty device: \nsTerminal type of %s: ")
53233
fe9b37bee5f7 Fully eliminated global tty state variables.
Karoly Lorentey <lorentey@elte.hu>
parents: 52614
diff changeset
605 (unless device
fe9b37bee5f7 Fully eliminated global tty state variables.
Karoly Lorentey <lorentey@elte.hu>
parents: 52614
diff changeset
606 (error "Invalid terminal device"))
fe9b37bee5f7 Fully eliminated global tty state variables.
Karoly Lorentey <lorentey@elte.hu>
parents: 52614
diff changeset
607 (unless type
fe9b37bee5f7 Fully eliminated global tty state variables.
Karoly Lorentey <lorentey@elte.hu>
parents: 52614
diff changeset
608 (error "Invalid terminal type"))
83014
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
609 (make-frame `((window-system . nil) (tty . ,device) (tty-type . ,type) . ,parameters)))
9687
1048e2d032e6 (make-frame-on-display): New function.
Richard M. Stallman <rms@gnu.org>
parents: 9175
diff changeset
610
15347
3885819ed860 (make-frame-command): New function.
Richard M. Stallman <rms@gnu.org>
parents: 14701
diff changeset
611 (defun make-frame-command ()
3885819ed860 (make-frame-command): New function.
Richard M. Stallman <rms@gnu.org>
parents: 14701
diff changeset
612 "Make a new frame, and select it if the terminal displays only one frame."
3885819ed860 (make-frame-command): New function.
Richard M. Stallman <rms@gnu.org>
parents: 14701
diff changeset
613 (interactive)
15364
a4e1db62f693 (make-frame-command): Treat msdos like no window system.
Richard M. Stallman <rms@gnu.org>
parents: 15347
diff changeset
614 (if (and window-system (not (eq window-system 'pc)))
15347
3885819ed860 (make-frame-command): New function.
Richard M. Stallman <rms@gnu.org>
parents: 14701
diff changeset
615 (make-frame)
3885819ed860 (make-frame-command): New function.
Richard M. Stallman <rms@gnu.org>
parents: 14701
diff changeset
616 (select-frame (make-frame))))
3885819ed860 (make-frame-command): New function.
Richard M. Stallman <rms@gnu.org>
parents: 14701
diff changeset
617
17163
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
618 (defvar before-make-frame-hook nil
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
619 "Functions to run before a frame is created.")
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
620
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
621 (defvar after-make-frame-functions nil
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
622 "Functions to run after a frame is created.
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
623 The functions are run with one arg, the newly created frame.")
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
624
33186
c63d52fc1eb7 (after-setting-font-hook): Rename hooks -> hook.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33009
diff changeset
625 (defvar after-setting-font-hook nil
24982
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
626 "Functions to run after a frame's font has been changed.")
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
627
2246
1f0d48f7e583 (make-frame): Renamed from new-frame.
Richard M. Stallman <rms@gnu.org>
parents: 2202
diff changeset
628 ;; Alias, kept temporarily.
64543
f1a7394cf1a7 (set-frame-font, cursor-in-non-selected-windows): Fix typo in docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 64298
diff changeset
629 (define-obsolete-function-alias 'new-frame 'make-frame "22.1")
17163
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
630
2246
1f0d48f7e583 (make-frame): Renamed from new-frame.
Richard M. Stallman <rms@gnu.org>
parents: 2202
diff changeset
631 (defun make-frame (&optional parameters)
17163
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
632 "Return a newly created frame displaying the current buffer.
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
633 Optional argument PARAMETERS is an alist of parameters for the new frame.
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
634 Each element of PARAMETERS should have the form (NAME . VALUE), for example:
10574
132a846eba8e (make-frame): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 10557
diff changeset
635
17163
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
636 (name . STRING) The frame should be named STRING.
542
119ba212b686 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 539
diff changeset
637
17163
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
638 (width . NUMBER) The frame should be NUMBER characters in width.
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
639 (height . NUMBER) The frame should be NUMBER text lines high.
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
640
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
641 You cannot specify either `width' or `height', you must use neither or both.
542
119ba212b686 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 539
diff changeset
642
17163
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
643 (minibuffer . t) The frame should have a minibuffer.
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
644 (minibuffer . nil) The frame should have no minibuffer.
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
645 (minibuffer . only) The frame should contain only a minibuffer.
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
646 (minibuffer . WINDOW) The frame should use WINDOW as its minibuffer window.
542
119ba212b686 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 539
diff changeset
647
83014
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
648 (window-system . nil) The frame should be displayed on a terminal device.
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
649 (window-system . x) The frame should be displayed in an X window.
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
650
83342
9216636c02fc Rename `struct display' to `struct device'. Update function, parameter and variable names accordingly.
Karoly Lorentey <lorentey@elte.hu>
parents: 83335
diff changeset
651 (device . ID) The frame should use the display device identified by ID.
83167
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
652
83014
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
653 Before the frame is created (via `frame-creation-function-alist'), functions on the
17163
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
654 hook `before-make-frame-hook' are run. After the frame is created, functions
56528
b1b127f6d343 (make-frame): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56507
diff changeset
655 on `after-make-frame-functions' are run with one arg, the newly created frame.
b1b127f6d343 (make-frame): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56507
diff changeset
656
b1b127f6d343 (make-frame): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56507
diff changeset
657 This function itself does not make the new frame the selected frame.
b1b127f6d343 (make-frame): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56507
diff changeset
658 The previously selected frame remains selected. However, the
b1b127f6d343 (make-frame): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56507
diff changeset
659 window system may select the new frame for its own reasons, for
b1b127f6d343 (make-frame): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56507
diff changeset
660 instance if the frame appears under the mouse pointer and your
b1b127f6d343 (make-frame): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56507
diff changeset
661 setup is for focus to follow the pointer."
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
662 (interactive)
83167
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
663 (let* ((w (cond
83342
9216636c02fc Rename `struct display' to `struct device'. Update function, parameter and variable names accordingly.
Karoly Lorentey <lorentey@elte.hu>
parents: 83335
diff changeset
664 ((assq 'device parameters)
9216636c02fc Rename `struct display' to `struct device'. Update function, parameter and variable names accordingly.
Karoly Lorentey <lorentey@elte.hu>
parents: 83335
diff changeset
665 (let ((type (display-live-p (cdr (assq 'device parameters)))))
83167
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
666 (cond
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
667 ((eq type t) nil)
83342
9216636c02fc Rename `struct display' to `struct device'. Update function, parameter and variable names accordingly.
Karoly Lorentey <lorentey@elte.hu>
parents: 83335
diff changeset
668 ((eq type nil) (error "Display %s does not exist" (cdr (assq 'device parameters))))
83167
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
669 (t type))))
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
670 ((assq 'window-system parameters)
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
671 (cdr (assq 'window-system parameters)))
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
672 (t window-system)))
83014
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
673 (frame-creation-function (cdr (assq w frame-creation-function-alist)))
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
674 frame)
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
675 (unless frame-creation-function
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
676 (error "Don't know how to create a frame on window system %s" w))
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
677 (run-hooks 'before-make-frame-hook)
83349
3d2bd2e4c7b7 Don't let window-system-default-frame-alist override parameters specified manually.
Karoly Lorentey <lorentey@elte.hu>
parents: 83342
diff changeset
678 (setq frame (funcall frame-creation-function (append parameters (cdr (assq w window-system-default-frame-alist)))))
17163
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
679 (run-hook-with-args 'after-make-frame-functions frame)
a63a326604ae defvar before- and after- make frame vars; use properly in make-frame.
Simon Marshall <simon@gnu.org>
parents: 16963
diff changeset
680 frame))
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
681
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
682 (defun filtered-frame-list (predicate)
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
683 "Return a list of all live frames which satisfy PREDICATE."
31450
82556406aa45 (filtered-frame-list): Reduce consing.
Gerd Moellmann <gerd@gnu.org>
parents: 31400
diff changeset
684 (let* ((frames (frame-list))
82556406aa45 (filtered-frame-list): Reduce consing.
Gerd Moellmann <gerd@gnu.org>
parents: 31400
diff changeset
685 (list frames))
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
686 (while (consp frames)
31450
82556406aa45 (filtered-frame-list): Reduce consing.
Gerd Moellmann <gerd@gnu.org>
parents: 31400
diff changeset
687 (unless (funcall predicate (car frames))
82556406aa45 (filtered-frame-list): Reduce consing.
Gerd Moellmann <gerd@gnu.org>
parents: 31400
diff changeset
688 (setcar frames nil))
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
689 (setq frames (cdr frames)))
31450
82556406aa45 (filtered-frame-list): Reduce consing.
Gerd Moellmann <gerd@gnu.org>
parents: 31400
diff changeset
690 (delq nil list)))
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
691
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
692 (defun minibuffer-frame-list ()
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
693 "Return a list of all frames with their own minibuffers."
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
694 (filtered-frame-list
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
695 (function (lambda (frame)
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
696 (eq frame (window-frame (minibuffer-window frame)))))))
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
697
27570
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
698 (defun frames-on-display-list (&optional display)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
699 "Return a list of all frames on DISPLAY.
83167
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
700
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
701 DISPLAY should be a display identifier (an integer), but it may
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
702 also be a name of a display, a string of the form HOST:SERVER.SCREEN.
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
703
27570
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
704 If DISPLAY is omitted or nil, it defaults to the selected frame's display."
83167
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
705 (let* ((display (or display (frame-display)))
31450
82556406aa45 (filtered-frame-list): Reduce consing.
Gerd Moellmann <gerd@gnu.org>
parents: 31400
diff changeset
706 (func #'(lambda (frame)
83167
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
707 (or (eq (frame-display frame) display)
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
708 (equal (frame-parameter frame 'display) display)))))
27570
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
709 (filtered-frame-list func)))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
710
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
711 (defun framep-on-display (&optional display)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
712 "Return the type of frames on DISPLAY.
83167
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
713 DISPLAY may be a display id, a display name or a frame. If it is
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
714 a frame, its type is returned.
27570
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
715 If DISPLAY is omitted or nil, it defaults to the selected frame's display.
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
716 All frames on a given display are of the same type."
83167
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
717 (or (display-live-p display)
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
718 (framep display)
27570
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
719 (framep (car (frames-on-display-list display)))))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
720
3971
6e7afc0a7fbc * frame.el (frame-remove-geometry-params): New function.
Jim Blandy <jimb@redhat.com>
parents: 3966
diff changeset
721 (defun frame-remove-geometry-params (param-list)
6e7afc0a7fbc * frame.el (frame-remove-geometry-params): New function.
Jim Blandy <jimb@redhat.com>
parents: 3966
diff changeset
722 "Return the parameter list PARAM-LIST, but with geometry specs removed.
6e7afc0a7fbc * frame.el (frame-remove-geometry-params): New function.
Jim Blandy <jimb@redhat.com>
parents: 3966
diff changeset
723 This deletes all bindings in PARAM-LIST for `top', `left', `width',
7343
81f9ad98c323 (frame-notice-user-settings): When replacing the first
Richard M. Stallman <rms@gnu.org>
parents: 7322
diff changeset
724 `height', `user-size' and `user-position' parameters.
3971
6e7afc0a7fbc * frame.el (frame-remove-geometry-params): New function.
Jim Blandy <jimb@redhat.com>
parents: 3966
diff changeset
725 Emacs uses this to avoid overriding explicit moves and resizings from
6e7afc0a7fbc * frame.el (frame-remove-geometry-params): New function.
Jim Blandy <jimb@redhat.com>
parents: 3966
diff changeset
726 the user during startup."
6e7afc0a7fbc * frame.el (frame-remove-geometry-params): New function.
Jim Blandy <jimb@redhat.com>
parents: 3966
diff changeset
727 (setq param-list (cons nil param-list))
6e7afc0a7fbc * frame.el (frame-remove-geometry-params): New function.
Jim Blandy <jimb@redhat.com>
parents: 3966
diff changeset
728 (let ((tail param-list))
6e7afc0a7fbc * frame.el (frame-remove-geometry-params): New function.
Jim Blandy <jimb@redhat.com>
parents: 3966
diff changeset
729 (while (consp (cdr tail))
6e7afc0a7fbc * frame.el (frame-remove-geometry-params): New function.
Jim Blandy <jimb@redhat.com>
parents: 3966
diff changeset
730 (if (and (consp (car (cdr tail)))
7343
81f9ad98c323 (frame-notice-user-settings): When replacing the first
Richard M. Stallman <rms@gnu.org>
parents: 7322
diff changeset
731 (memq (car (car (cdr tail)))
81f9ad98c323 (frame-notice-user-settings): When replacing the first
Richard M. Stallman <rms@gnu.org>
parents: 7322
diff changeset
732 '(height width top left user-position user-size)))
81f9ad98c323 (frame-notice-user-settings): When replacing the first
Richard M. Stallman <rms@gnu.org>
parents: 7322
diff changeset
733 (progn
81f9ad98c323 (frame-notice-user-settings): When replacing the first
Richard M. Stallman <rms@gnu.org>
parents: 7322
diff changeset
734 (setq frame-initial-geometry-arguments
81f9ad98c323 (frame-notice-user-settings): When replacing the first
Richard M. Stallman <rms@gnu.org>
parents: 7322
diff changeset
735 (cons (car (cdr tail)) frame-initial-geometry-arguments))
81f9ad98c323 (frame-notice-user-settings): When replacing the first
Richard M. Stallman <rms@gnu.org>
parents: 7322
diff changeset
736 (setcdr tail (cdr (cdr tail))))
3971
6e7afc0a7fbc * frame.el (frame-remove-geometry-params): New function.
Jim Blandy <jimb@redhat.com>
parents: 3966
diff changeset
737 (setq tail (cdr tail)))))
7436
b20221c93fbb (frame-remove-geometry-params): Reverse the computed list, to preserve the
Karl Heuer <kwzh@gnu.org>
parents: 7357
diff changeset
738 (setq frame-initial-geometry-arguments
b20221c93fbb (frame-remove-geometry-params): Reverse the computed list, to preserve the
Karl Heuer <kwzh@gnu.org>
parents: 7357
diff changeset
739 (nreverse frame-initial-geometry-arguments))
3971
6e7afc0a7fbc * frame.el (frame-remove-geometry-params): New function.
Jim Blandy <jimb@redhat.com>
parents: 3966
diff changeset
740 (cdr param-list))
6e7afc0a7fbc * frame.el (frame-remove-geometry-params): New function.
Jim Blandy <jimb@redhat.com>
parents: 3966
diff changeset
741
21215
2702850b72d6 (focus-follows-mouse): Make it defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 21214
diff changeset
742 (defcustom focus-follows-mouse t
43545
731c6d3cea6c (focus-follows-mouse): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 43434
diff changeset
743 "*Non-nil if window system changes focus when you move the mouse.
731c6d3cea6c (focus-follows-mouse): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 43434
diff changeset
744 You should set this variable to tell Emacs how your window manager
731c6d3cea6c (focus-follows-mouse): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 43434
diff changeset
745 handles focus, since there is no way in general for Emacs to find out
731c6d3cea6c (focus-follows-mouse): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 43434
diff changeset
746 automatically."
21215
2702850b72d6 (focus-follows-mouse): Make it defcustom.
Richard M. Stallman <rms@gnu.org>
parents: 21214
diff changeset
747 :type 'boolean
21669
9861518505cb *** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents: 21216
diff changeset
748 :group 'frames
9861518505cb *** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents: 21216
diff changeset
749 :version "20.3")
21214
7a873226ee07 (focus-follows-mouse): New variable.
Richard M. Stallman <rms@gnu.org>
parents: 20386
diff changeset
750
38781
c20b98060a6d (select-frame-set-input-focus): New function
Gerd Moellmann <gerd@gnu.org>
parents: 38469
diff changeset
751 (defun select-frame-set-input-focus (frame)
c20b98060a6d (select-frame-set-input-focus): New function
Gerd Moellmann <gerd@gnu.org>
parents: 38469
diff changeset
752 "Select FRAME, raise it, and set input focus, if possible."
c20b98060a6d (select-frame-set-input-focus): New function
Gerd Moellmann <gerd@gnu.org>
parents: 38469
diff changeset
753 (select-frame frame)
c20b98060a6d (select-frame-set-input-focus): New function
Gerd Moellmann <gerd@gnu.org>
parents: 38469
diff changeset
754 (raise-frame frame)
c20b98060a6d (select-frame-set-input-focus): New function
Gerd Moellmann <gerd@gnu.org>
parents: 38469
diff changeset
755 ;; Ensure, if possible, that frame gets input focus.
83009
b2b37c85b00a Numerous bugfixes and small improvements.
Karoly Lorentey <lorentey@elte.hu>
parents: 83008
diff changeset
756 (cond ((eq (window-system frame) 'x)
47016
876e9026e464 (select-frame-by-name, select-frame-set-input-focus):
Richard M. Stallman <rms@gnu.org>
parents: 44547
diff changeset
757 (x-focus-frame frame))
83009
b2b37c85b00a Numerous bugfixes and small improvements.
Karoly Lorentey <lorentey@elte.hu>
parents: 83008
diff changeset
758 ((eq (window-system frame) 'w32)
47016
876e9026e464 (select-frame-by-name, select-frame-set-input-focus):
Richard M. Stallman <rms@gnu.org>
parents: 44547
diff changeset
759 (w32-focus-frame frame)))
38781
c20b98060a6d (select-frame-set-input-focus): New function
Gerd Moellmann <gerd@gnu.org>
parents: 38469
diff changeset
760 (cond (focus-follows-mouse
47016
876e9026e464 (select-frame-by-name, select-frame-set-input-focus):
Richard M. Stallman <rms@gnu.org>
parents: 44547
diff changeset
761 (set-mouse-position (selected-frame) (1- (frame-width)) 0))))
38781
c20b98060a6d (select-frame-set-input-focus): New function
Gerd Moellmann <gerd@gnu.org>
parents: 38469
diff changeset
762
4425
1b48826df9cb (other-frame): New function, analogous to other-window.
Roland McGrath <roland@gnu.org>
parents: 4360
diff changeset
763 (defun other-frame (arg)
39505
b7d5e9ab6f93 (select-frame-by-name, other-frame): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 38812
diff changeset
764 "Select the ARG'th different visible frame on current display, and raise it.
4425
1b48826df9cb (other-frame): New function, analogous to other-window.
Roland McGrath <roland@gnu.org>
parents: 4360
diff changeset
765 All frames are arranged in a cyclic order.
1b48826df9cb (other-frame): New function, analogous to other-window.
Roland McGrath <roland@gnu.org>
parents: 4360
diff changeset
766 This command selects the frame ARG steps away in that order.
43434
d1a09152b7b5 (other-frame): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 42952
diff changeset
767 A negative ARG moves in the opposite order.
d1a09152b7b5 (other-frame): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 42952
diff changeset
768
d1a09152b7b5 (other-frame): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 42952
diff changeset
769 To make this command work properly, you must tell Emacs
d1a09152b7b5 (other-frame): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 42952
diff changeset
770 how the system (or the window manager) generally handles
d1a09152b7b5 (other-frame): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 42952
diff changeset
771 focus-switching between windows. If moving the mouse onto a window
d1a09152b7b5 (other-frame): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 42952
diff changeset
772 selects it (gives it focus), set `focus-follows-mouse' to t.
d1a09152b7b5 (other-frame): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 42952
diff changeset
773 Otherwise, that variable should be nil."
4425
1b48826df9cb (other-frame): New function, analogous to other-window.
Roland McGrath <roland@gnu.org>
parents: 4360
diff changeset
774 (interactive "p")
1b48826df9cb (other-frame): New function, analogous to other-window.
Roland McGrath <roland@gnu.org>
parents: 4360
diff changeset
775 (let ((frame (selected-frame)))
1b48826df9cb (other-frame): New function, analogous to other-window.
Roland McGrath <roland@gnu.org>
parents: 4360
diff changeset
776 (while (> arg 0)
4431
2fe6adb8a82f (other-frame): Skip iconified and invisible frames.
Roland McGrath <roland@gnu.org>
parents: 4425
diff changeset
777 (setq frame (next-frame frame))
2fe6adb8a82f (other-frame): Skip iconified and invisible frames.
Roland McGrath <roland@gnu.org>
parents: 4425
diff changeset
778 (while (not (eq (frame-visible-p frame) t))
2fe6adb8a82f (other-frame): Skip iconified and invisible frames.
Roland McGrath <roland@gnu.org>
parents: 4425
diff changeset
779 (setq frame (next-frame frame)))
2fe6adb8a82f (other-frame): Skip iconified and invisible frames.
Roland McGrath <roland@gnu.org>
parents: 4425
diff changeset
780 (setq arg (1- arg)))
4425
1b48826df9cb (other-frame): New function, analogous to other-window.
Roland McGrath <roland@gnu.org>
parents: 4360
diff changeset
781 (while (< arg 0)
4431
2fe6adb8a82f (other-frame): Skip iconified and invisible frames.
Roland McGrath <roland@gnu.org>
parents: 4425
diff changeset
782 (setq frame (previous-frame frame))
2fe6adb8a82f (other-frame): Skip iconified and invisible frames.
Roland McGrath <roland@gnu.org>
parents: 4425
diff changeset
783 (while (not (eq (frame-visible-p frame) t))
2fe6adb8a82f (other-frame): Skip iconified and invisible frames.
Roland McGrath <roland@gnu.org>
parents: 4425
diff changeset
784 (setq frame (previous-frame frame)))
4553
ceb140c16ad2 (other-frame): Fix error in loop counting.
Richard M. Stallman <rms@gnu.org>
parents: 4431
diff changeset
785 (setq arg (1+ arg)))
38781
c20b98060a6d (select-frame-set-input-focus): New function
Gerd Moellmann <gerd@gnu.org>
parents: 38469
diff changeset
786 (select-frame-set-input-focus frame)))
20386
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
787
51180
8444fb4d51cf (iconify-or-deiconify-frame): Move from term/x-win.el.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50533
diff changeset
788 (defun iconify-or-deiconify-frame ()
8444fb4d51cf (iconify-or-deiconify-frame): Move from term/x-win.el.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50533
diff changeset
789 "Iconify the selected frame, or deiconify if it's currently an icon."
8444fb4d51cf (iconify-or-deiconify-frame): Move from term/x-win.el.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50533
diff changeset
790 (interactive)
8444fb4d51cf (iconify-or-deiconify-frame): Move from term/x-win.el.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50533
diff changeset
791 (if (eq (cdr (assq 'visibility (frame-parameters))) t)
8444fb4d51cf (iconify-or-deiconify-frame): Move from term/x-win.el.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50533
diff changeset
792 (iconify-frame)
8444fb4d51cf (iconify-or-deiconify-frame): Move from term/x-win.el.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50533
diff changeset
793 (make-frame-visible)))
8444fb4d51cf (iconify-or-deiconify-frame): Move from term/x-win.el.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 50533
diff changeset
794
83065
a871be7b26a5 Implemented suspending of emacsclient frames.
Karoly Lorentey <lorentey@elte.hu>
parents: 83018
diff changeset
795 (defun suspend-frame ()
a871be7b26a5 Implemented suspending of emacsclient frames.
Karoly Lorentey <lorentey@elte.hu>
parents: 83018
diff changeset
796 "Do whatever is right to suspend the current frame.
a871be7b26a5 Implemented suspending of emacsclient frames.
Karoly Lorentey <lorentey@elte.hu>
parents: 83018
diff changeset
797 Calls `suspend-emacs' if invoked from the controlling terminal,
a871be7b26a5 Implemented suspending of emacsclient frames.
Karoly Lorentey <lorentey@elte.hu>
parents: 83018
diff changeset
798 `suspend-tty' from a secondary terminal, and
a871be7b26a5 Implemented suspending of emacsclient frames.
Karoly Lorentey <lorentey@elte.hu>
parents: 83018
diff changeset
799 `iconify-or-deiconify-frame' from an X frame."
a871be7b26a5 Implemented suspending of emacsclient frames.
Karoly Lorentey <lorentey@elte.hu>
parents: 83018
diff changeset
800 (interactive)
a871be7b26a5 Implemented suspending of emacsclient frames.
Karoly Lorentey <lorentey@elte.hu>
parents: 83018
diff changeset
801 (let ((type (framep (selected-frame))))
a871be7b26a5 Implemented suspending of emacsclient frames.
Karoly Lorentey <lorentey@elte.hu>
parents: 83018
diff changeset
802 (cond
a871be7b26a5 Implemented suspending of emacsclient frames.
Karoly Lorentey <lorentey@elte.hu>
parents: 83018
diff changeset
803 ((eq type 'x) (iconify-or-deiconify-frame))
a871be7b26a5 Implemented suspending of emacsclient frames.
Karoly Lorentey <lorentey@elte.hu>
parents: 83018
diff changeset
804 ((eq type t)
83173
6b4b299e2cd5 Fix suspend-frame on the controlling tty (reported by Dan Nicolaescu).
Karoly Lorentey <lorentey@elte.hu>
parents: 83167
diff changeset
805 (if (display-controlling-tty-p)
6b4b299e2cd5 Fix suspend-frame on the controlling tty (reported by Dan Nicolaescu).
Karoly Lorentey <lorentey@elte.hu>
parents: 83167
diff changeset
806 (suspend-emacs)
6b4b299e2cd5 Fix suspend-frame on the controlling tty (reported by Dan Nicolaescu).
Karoly Lorentey <lorentey@elte.hu>
parents: 83167
diff changeset
807 (suspend-tty)))
83065
a871be7b26a5 Implemented suspending of emacsclient frames.
Karoly Lorentey <lorentey@elte.hu>
parents: 83018
diff changeset
808 (t (suspend-emacs)))))
a871be7b26a5 Implemented suspending of emacsclient frames.
Karoly Lorentey <lorentey@elte.hu>
parents: 83018
diff changeset
809
a871be7b26a5 Implemented suspending of emacsclient frames.
Karoly Lorentey <lorentey@elte.hu>
parents: 83018
diff changeset
810
20386
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
811 (defun make-frame-names-alist ()
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
812 (let* ((current-frame (selected-frame))
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
813 (falist
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
814 (cons
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
815 (cons (frame-parameter current-frame 'name) current-frame) nil))
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
816 (frame (next-frame nil t)))
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
817 (while (not (eq frame current-frame))
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
818 (progn
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
819 (setq falist (cons (cons (frame-parameter frame 'name) frame) falist))
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
820 (setq frame (next-frame frame t))))
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
821 falist))
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
822
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
823 (defvar frame-name-history nil)
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
824 (defun select-frame-by-name (name)
39505
b7d5e9ab6f93 (select-frame-by-name, other-frame): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents: 38812
diff changeset
825 "Select the frame on the current terminal whose name is NAME and raise it.
20386
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
826 If there is no frame by that name, signal an error."
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
827 (interactive
21730
efa1c31f068c (frame-name-alist): Remove this variable.
Richard M. Stallman <rms@gnu.org>
parents: 21669
diff changeset
828 (let* ((frame-names-alist (make-frame-names-alist))
efa1c31f068c (frame-name-alist): Remove this variable.
Richard M. Stallman <rms@gnu.org>
parents: 21669
diff changeset
829 (default (car (car frame-names-alist)))
efa1c31f068c (frame-name-alist): Remove this variable.
Richard M. Stallman <rms@gnu.org>
parents: 21669
diff changeset
830 (input (completing-read
efa1c31f068c (frame-name-alist): Remove this variable.
Richard M. Stallman <rms@gnu.org>
parents: 21669
diff changeset
831 (format "Select Frame (default %s): " default)
efa1c31f068c (frame-name-alist): Remove this variable.
Richard M. Stallman <rms@gnu.org>
parents: 21669
diff changeset
832 frame-names-alist nil t nil 'frame-name-history)))
20386
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
833 (if (= (length input) 0)
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
834 (list default)
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
835 (list input))))
21730
efa1c31f068c (frame-name-alist): Remove this variable.
Richard M. Stallman <rms@gnu.org>
parents: 21669
diff changeset
836 (let* ((frame-names-alist (make-frame-names-alist))
efa1c31f068c (frame-name-alist): Remove this variable.
Richard M. Stallman <rms@gnu.org>
parents: 21669
diff changeset
837 (frame (cdr (assoc name frame-names-alist))))
20386
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
838 (or frame
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
839 (error "There is no frame named `%s'" name))
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
840 (make-frame-visible frame)
25ca60b3ca09 (make-frame-names-alist, select-frame-by-name): New
Eli Zaretskii <eliz@gnu.org>
parents: 20281
diff changeset
841 (raise-frame frame)
24207
69b4c339845d (select-frame-by-name): Obey focus-follows-mouse.
Andrew Innes <andrewi@gnu.org>
parents: 23763
diff changeset
842 (select-frame frame)
69b4c339845d (select-frame-by-name): Obey focus-follows-mouse.
Andrew Innes <andrewi@gnu.org>
parents: 23763
diff changeset
843 ;; Ensure, if possible, that frame gets input focus.
83014
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
844 (cond ((eq (window-system frame) 'x)
47016
876e9026e464 (select-frame-by-name, select-frame-set-input-focus):
Richard M. Stallman <rms@gnu.org>
parents: 44547
diff changeset
845 (x-focus-frame frame))
83014
f5cadabb36dd Support for opening X frames from a tty session.
Karoly Lorentey <lorentey@elte.hu>
parents: 83009
diff changeset
846 ((eq (window-system frame) 'w32)
47016
876e9026e464 (select-frame-by-name, select-frame-set-input-focus):
Richard M. Stallman <rms@gnu.org>
parents: 44547
diff changeset
847 (w32-focus-frame frame)))
876e9026e464 (select-frame-by-name, select-frame-set-input-focus):
Richard M. Stallman <rms@gnu.org>
parents: 44547
diff changeset
848 (when focus-follows-mouse
876e9026e464 (select-frame-by-name, select-frame-set-input-focus):
Richard M. Stallman <rms@gnu.org>
parents: 44547
diff changeset
849 (set-mouse-position frame (1- (frame-width frame)) 0))))
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
850
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
851 ;;;; Frame configurations
756
0276f8eb306f *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 727
diff changeset
852
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
853 (defun current-frame-configuration ()
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
854 "Return a list describing the positions and states of all frames.
2202
081afcef5e85 Make frame configurations start with a distinctive symbol.
Jim Blandy <jimb@redhat.com>
parents: 2069
diff changeset
855 Its car is `frame-configuration'.
081afcef5e85 Make frame configurations start with a distinctive symbol.
Jim Blandy <jimb@redhat.com>
parents: 2069
diff changeset
856 Each element of the cdr is a list of the form (FRAME ALIST WINDOW-CONFIG),
081afcef5e85 Make frame configurations start with a distinctive symbol.
Jim Blandy <jimb@redhat.com>
parents: 2069
diff changeset
857 where
081afcef5e85 Make frame configurations start with a distinctive symbol.
Jim Blandy <jimb@redhat.com>
parents: 2069
diff changeset
858 FRAME is a frame object,
081afcef5e85 Make frame configurations start with a distinctive symbol.
Jim Blandy <jimb@redhat.com>
parents: 2069
diff changeset
859 ALIST is an association list specifying some of FRAME's parameters, and
081afcef5e85 Make frame configurations start with a distinctive symbol.
Jim Blandy <jimb@redhat.com>
parents: 2069
diff changeset
860 WINDOW-CONFIG is a window configuration object for FRAME."
081afcef5e85 Make frame configurations start with a distinctive symbol.
Jim Blandy <jimb@redhat.com>
parents: 2069
diff changeset
861 (cons 'frame-configuration
081afcef5e85 Make frame configurations start with a distinctive symbol.
Jim Blandy <jimb@redhat.com>
parents: 2069
diff changeset
862 (mapcar (function
081afcef5e85 Make frame configurations start with a distinctive symbol.
Jim Blandy <jimb@redhat.com>
parents: 2069
diff changeset
863 (lambda (frame)
081afcef5e85 Make frame configurations start with a distinctive symbol.
Jim Blandy <jimb@redhat.com>
parents: 2069
diff changeset
864 (list frame
081afcef5e85 Make frame configurations start with a distinctive symbol.
Jim Blandy <jimb@redhat.com>
parents: 2069
diff changeset
865 (frame-parameters frame)
081afcef5e85 Make frame configurations start with a distinctive symbol.
Jim Blandy <jimb@redhat.com>
parents: 2069
diff changeset
866 (current-window-configuration frame))))
081afcef5e85 Make frame configurations start with a distinctive symbol.
Jim Blandy <jimb@redhat.com>
parents: 2069
diff changeset
867 (frame-list))))
756
0276f8eb306f *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 727
diff changeset
868
4670
e39967101d8b (set-frame-configuration): Take new optional arg NODELETE; if non-nil,
Roland McGrath <roland@gnu.org>
parents: 4625
diff changeset
869 (defun set-frame-configuration (configuration &optional nodelete)
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
870 "Restore the frames to the state described by CONFIGURATION.
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
871 Each frame listed in CONFIGURATION has its position, size, window
4670
e39967101d8b (set-frame-configuration): Take new optional arg NODELETE; if non-nil,
Roland McGrath <roland@gnu.org>
parents: 4625
diff changeset
872 configuration, and other parameters set as specified in CONFIGURATION.
56507
8a0830a6f469 (modify-all-frames-parameters): Minor doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56491
diff changeset
873 However, this function does not restore deleted frames.
8a0830a6f469 (modify-all-frames-parameters): Minor doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 56491
diff changeset
874
4919
3963d8a9f342 (set-frame-configuration): If NODELETE, make the unwanted frames invisible.
Richard M. Stallman <rms@gnu.org>
parents: 4911
diff changeset
875 Ordinarily, this function deletes all existing frames not
3963d8a9f342 (set-frame-configuration): If NODELETE, make the unwanted frames invisible.
Richard M. Stallman <rms@gnu.org>
parents: 4911
diff changeset
876 listed in CONFIGURATION. But if optional second argument NODELETE
4930
04dee67f86cf (set-frame-configuration): Iconify frames
Richard M. Stallman <rms@gnu.org>
parents: 4919
diff changeset
877 is given and non-nil, the unwanted frames are iconified instead."
2202
081afcef5e85 Make frame configurations start with a distinctive symbol.
Jim Blandy <jimb@redhat.com>
parents: 2069
diff changeset
878 (or (frame-configuration-p configuration)
081afcef5e85 Make frame configurations start with a distinctive symbol.
Jim Blandy <jimb@redhat.com>
parents: 2069
diff changeset
879 (signal 'wrong-type-argument
081afcef5e85 Make frame configurations start with a distinctive symbol.
Jim Blandy <jimb@redhat.com>
parents: 2069
diff changeset
880 (list 'frame-configuration-p configuration)))
081afcef5e85 Make frame configurations start with a distinctive symbol.
Jim Blandy <jimb@redhat.com>
parents: 2069
diff changeset
881 (let ((config-alist (cdr configuration))
081afcef5e85 Make frame configurations start with a distinctive symbol.
Jim Blandy <jimb@redhat.com>
parents: 2069
diff changeset
882 frames-to-delete)
756
0276f8eb306f *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 727
diff changeset
883 (mapcar (function
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
884 (lambda (frame)
2202
081afcef5e85 Make frame configurations start with a distinctive symbol.
Jim Blandy <jimb@redhat.com>
parents: 2069
diff changeset
885 (let ((parameters (assq frame config-alist)))
756
0276f8eb306f *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 727
diff changeset
886 (if parameters
0276f8eb306f *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 727
diff changeset
887 (progn
3764
d965878f294f * frame.el (set-frame-configuration): Don't try to set a frame's
Jim Blandy <jimb@redhat.com>
parents: 3647
diff changeset
888 (modify-frame-parameters
d965878f294f * frame.el (set-frame-configuration): Don't try to set a frame's
Jim Blandy <jimb@redhat.com>
parents: 3647
diff changeset
889 frame
10557
87b3ab910738 Fix typos.
Karl Heuer <kwzh@gnu.org>
parents: 10192
diff changeset
890 ;; Since we can't set a frame's minibuffer status,
3764
d965878f294f * frame.el (set-frame-configuration): Don't try to set a frame's
Jim Blandy <jimb@redhat.com>
parents: 3647
diff changeset
891 ;; we might as well omit the parameter altogether.
d965878f294f * frame.el (set-frame-configuration): Don't try to set a frame's
Jim Blandy <jimb@redhat.com>
parents: 3647
diff changeset
892 (let* ((parms (nth 1 parameters))
d965878f294f * frame.el (set-frame-configuration): Don't try to set a frame's
Jim Blandy <jimb@redhat.com>
parents: 3647
diff changeset
893 (mini (assq 'minibuffer parms)))
d965878f294f * frame.el (set-frame-configuration): Don't try to set a frame's
Jim Blandy <jimb@redhat.com>
parents: 3647
diff changeset
894 (if mini (setq parms (delq mini parms)))
d965878f294f * frame.el (set-frame-configuration): Don't try to set a frame's
Jim Blandy <jimb@redhat.com>
parents: 3647
diff changeset
895 parms))
756
0276f8eb306f *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 727
diff changeset
896 (set-window-configuration (nth 2 parameters)))
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
897 (setq frames-to-delete (cons frame frames-to-delete))))))
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
898 (frame-list))
4919
3963d8a9f342 (set-frame-configuration): If NODELETE, make the unwanted frames invisible.
Richard M. Stallman <rms@gnu.org>
parents: 4911
diff changeset
899 (if nodelete
4930
04dee67f86cf (set-frame-configuration): Iconify frames
Richard M. Stallman <rms@gnu.org>
parents: 4919
diff changeset
900 ;; Note: making frames invisible here was tried
04dee67f86cf (set-frame-configuration): Iconify frames
Richard M. Stallman <rms@gnu.org>
parents: 4919
diff changeset
901 ;; but led to some strange behavior--each time the frame
04dee67f86cf (set-frame-configuration): Iconify frames
Richard M. Stallman <rms@gnu.org>
parents: 4919
diff changeset
902 ;; was made visible again, the window manager asked afresh
04dee67f86cf (set-frame-configuration): Iconify frames
Richard M. Stallman <rms@gnu.org>
parents: 4919
diff changeset
903 ;; for where to put it.
04dee67f86cf (set-frame-configuration): Iconify frames
Richard M. Stallman <rms@gnu.org>
parents: 4919
diff changeset
904 (mapcar 'iconify-frame frames-to-delete)
4919
3963d8a9f342 (set-frame-configuration): If NODELETE, make the unwanted frames invisible.
Richard M. Stallman <rms@gnu.org>
parents: 4911
diff changeset
905 (mapcar 'delete-frame frames-to-delete))))
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
906
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
907 ;;;; Convenience functions for accessing and interactively changing
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
908 ;;;; frame parameters.
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
909
826
e9b9a1cff2c9 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 811
diff changeset
910 (defun frame-height (&optional frame)
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
911 "Return number of lines available for display on FRAME.
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
912 If FRAME is omitted, describe the currently selected frame."
826
e9b9a1cff2c9 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 811
diff changeset
913 (cdr (assq 'height (frame-parameters frame))))
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
914
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
915 (defun frame-width (&optional frame)
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
916 "Return number of columns available for display on FRAME.
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
917 If FRAME is omitted, describe the currently selected frame."
826
e9b9a1cff2c9 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 811
diff changeset
918 (cdr (assq 'width (frame-parameters frame))))
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
919
16963
7daaf9702c47 (set-frame-font): Renamed from set-default-font,
Richard M. Stallman <rms@gnu.org>
parents: 16516
diff changeset
920 (defalias 'set-default-font 'set-frame-font)
50522
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
921 (defun set-frame-font (font-name &optional keep-size)
25139
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
922 "Set the font of the selected frame to FONT-NAME.
16047
182b9268dbad Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 15399
diff changeset
923 When called interactively, prompt for the name of the font to use.
50522
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
924 To get the frame's current default font, use `frame-parameters'.
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
925
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
926 The default behavior is to keep the numbers of lines and columns in
64543
f1a7394cf1a7 (set-frame-font, cursor-in-non-selected-windows): Fix typo in docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 64298
diff changeset
927 the frame, thus may change its pixel size. If optional KEEP-SIZE is
50522
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
928 non-nil (interactively, prefix argument) the current frame size (in
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
929 pixels) is kept by adjusting the numbers of the lines and columns."
41579
bab6e8eba0e1 comments indented properly
Sam Steingold <sds@gnu.org>
parents: 40673
diff changeset
930 (interactive
50522
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
931 (let* ((completion-ignore-case t)
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
932 (font (completing-read "Font name: "
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
933 (mapcar #'list
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
934 ;; x-list-fonts will fail with an error
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
935 ;; if this frame doesn't support fonts.
51507
e4e1e9a6becf (set-frame-font): Default to frame's current default font.
Miles Bader <miles@gnu.org>
parents: 51180
diff changeset
936 (x-list-fonts "*" nil (selected-frame)))
e4e1e9a6becf (set-frame-font): Default to frame's current default font.
Miles Bader <miles@gnu.org>
parents: 51180
diff changeset
937 nil nil nil nil
e4e1e9a6becf (set-frame-font): Default to frame's current default font.
Miles Bader <miles@gnu.org>
parents: 51180
diff changeset
938 (frame-parameter nil 'font))))
50522
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
939 (list font current-prefix-arg)))
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
940 (let (fht fwd)
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
941 (if keep-size
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
942 (setq fht (* (frame-parameter nil 'height) (frame-char-height))
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
943 fwd (* (frame-parameter nil 'width) (frame-char-width))))
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
944 (modify-frame-parameters (selected-frame)
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
945 (list (cons 'font font-name)))
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
946 (if keep-size
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
947 (modify-frame-parameters
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
948 (selected-frame)
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
949 (list (cons 'height (round fht (frame-char-height)))
ac9f1c53789e (set-frame-font): Allow keeping frame size after changing font.
Juanma Barranquero <lekktu@gmail.com>
parents: 47738
diff changeset
950 (cons 'width (round fwd (frame-char-width)))))))
33186
c63d52fc1eb7 (after-setting-font-hook): Rename hooks -> hook.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 33009
diff changeset
951 (run-hooks 'after-setting-font-hook 'after-setting-font-hooks))
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
952
39846
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
953 (defun set-frame-parameter (frame parameter value)
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
954 (modify-frame-parameters frame (list (cons parameter value))))
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
955
1881
436edc3e74f6 (frame-initialize): Fix error syntax.
Richard M. Stallman <rms@gnu.org>
parents: 1863
diff changeset
956 (defun set-background-color (color-name)
25139
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
957 "Set the background color of the selected frame to COLOR-NAME.
16047
182b9268dbad Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 15399
diff changeset
958 When called interactively, prompt for the name of the color to use.
182b9268dbad Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 15399
diff changeset
959 To get the frame's current background color, use `frame-parameters'."
25139
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
960 (interactive (list (facemenu-read-color)))
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
961 (modify-frame-parameters (selected-frame)
40673
377344c6e1f1 (set-background-color, set-foreground-color): Call
Eli Zaretskii <eliz@gnu.org>
parents: 40467
diff changeset
962 (list (cons 'background-color color-name)))
377344c6e1f1 (set-background-color, set-foreground-color): Call
Eli Zaretskii <eliz@gnu.org>
parents: 40467
diff changeset
963 (or window-system
377344c6e1f1 (set-background-color, set-foreground-color): Call
Eli Zaretskii <eliz@gnu.org>
parents: 40467
diff changeset
964 (face-set-after-frame-default (selected-frame))))
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
965
1881
436edc3e74f6 (frame-initialize): Fix error syntax.
Richard M. Stallman <rms@gnu.org>
parents: 1863
diff changeset
966 (defun set-foreground-color (color-name)
25139
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
967 "Set the foreground color of the selected frame to COLOR-NAME.
16047
182b9268dbad Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 15399
diff changeset
968 When called interactively, prompt for the name of the color to use.
182b9268dbad Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 15399
diff changeset
969 To get the frame's current foreground color, use `frame-parameters'."
25139
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
970 (interactive (list (facemenu-read-color)))
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
971 (modify-frame-parameters (selected-frame)
40673
377344c6e1f1 (set-background-color, set-foreground-color): Call
Eli Zaretskii <eliz@gnu.org>
parents: 40467
diff changeset
972 (list (cons 'foreground-color color-name)))
377344c6e1f1 (set-background-color, set-foreground-color): Call
Eli Zaretskii <eliz@gnu.org>
parents: 40467
diff changeset
973 (or window-system
377344c6e1f1 (set-background-color, set-foreground-color): Call
Eli Zaretskii <eliz@gnu.org>
parents: 40467
diff changeset
974 (face-set-after-frame-default (selected-frame))))
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
975
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
976 (defun set-cursor-color (color-name)
25139
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
977 "Set the text cursor color of the selected frame to COLOR-NAME.
16047
182b9268dbad Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 15399
diff changeset
978 When called interactively, prompt for the name of the color to use.
182b9268dbad Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 15399
diff changeset
979 To get the frame's current cursor color, use `frame-parameters'."
25139
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
980 (interactive (list (facemenu-read-color)))
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
981 (modify-frame-parameters (selected-frame)
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
982 (list (cons 'cursor-color color-name))))
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
983
1974
94e4f619080b These changes were actually made by Richard; I stole his RCS lock.
Jim Blandy <jimb@redhat.com>
parents: 1881
diff changeset
984 (defun set-mouse-color (color-name)
25139
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
985 "Set the color of the mouse pointer of the selected frame to COLOR-NAME.
16047
182b9268dbad Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 15399
diff changeset
986 When called interactively, prompt for the name of the color to use.
182b9268dbad Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 15399
diff changeset
987 To get the frame's current mouse color, use `frame-parameters'."
25139
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
988 (interactive (list (facemenu-read-color)))
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
989 (modify-frame-parameters (selected-frame)
25074
2eca330f89d7 (set-mouse-color): If new color is nil,
Karl Heuer <kwzh@gnu.org>
parents: 24982
diff changeset
990 (list (cons 'mouse-color
2eca330f89d7 (set-mouse-color): If new color is nil,
Karl Heuer <kwzh@gnu.org>
parents: 24982
diff changeset
991 (or color-name
2eca330f89d7 (set-mouse-color): If new color is nil,
Karl Heuer <kwzh@gnu.org>
parents: 24982
diff changeset
992 (cdr (assq 'mouse-color
2eca330f89d7 (set-mouse-color): If new color is nil,
Karl Heuer <kwzh@gnu.org>
parents: 24982
diff changeset
993 (frame-parameters))))))))
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
994
1974
94e4f619080b These changes were actually made by Richard; I stole his RCS lock.
Jim Blandy <jimb@redhat.com>
parents: 1881
diff changeset
995 (defun set-border-color (color-name)
25139
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
996 "Set the color of the border of the selected frame to COLOR-NAME.
16047
182b9268dbad Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 15399
diff changeset
997 When called interactively, prompt for the name of the color to use.
182b9268dbad Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 15399
diff changeset
998 To get the frame's current border color, use `frame-parameters'."
25139
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
999 (interactive (list (facemenu-read-color)))
1974
94e4f619080b These changes were actually made by Richard; I stole his RCS lock.
Jim Blandy <jimb@redhat.com>
parents: 1881
diff changeset
1000 (modify-frame-parameters (selected-frame)
94e4f619080b These changes were actually made by Richard; I stole his RCS lock.
Jim Blandy <jimb@redhat.com>
parents: 1881
diff changeset
1001 (list (cons 'border-color color-name))))
94e4f619080b These changes were actually made by Richard; I stole his RCS lock.
Jim Blandy <jimb@redhat.com>
parents: 1881
diff changeset
1002
94e4f619080b These changes were actually made by Richard; I stole his RCS lock.
Jim Blandy <jimb@redhat.com>
parents: 1881
diff changeset
1003 (defun auto-raise-mode (arg)
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
1004 "Toggle whether or not the selected frame should auto-raise.
8072
48c81a052cea (auto-lower-mode, auto-raise-mode): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 8056
diff changeset
1005 With arg, turn auto-raise mode on if and only if arg is positive.
48c81a052cea (auto-lower-mode, auto-raise-mode): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 8056
diff changeset
1006 Note that this controls Emacs's own auto-raise feature.
48c81a052cea (auto-lower-mode, auto-raise-mode): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 8056
diff changeset
1007 Some window managers allow you to enable auto-raise for certain windows.
48c81a052cea (auto-lower-mode, auto-raise-mode): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 8056
diff changeset
1008 You can use that for Emacs windows if you wish, but if you do,
48c81a052cea (auto-lower-mode, auto-raise-mode): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 8056
diff changeset
1009 that is beyond the control of Emacs and this command has no effect on it."
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
1010 (interactive "P")
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
1011 (if (null arg)
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
1012 (setq arg
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
1013 (if (cdr (assq 'auto-raise (frame-parameters (selected-frame))))
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
1014 -1 1)))
26166
312839b8086d (auto-raise-mode): When enabling the mode,
Gerd Moellmann <gerd@gnu.org>
parents: 25266
diff changeset
1015 (if (> arg 0)
312839b8086d (auto-raise-mode): When enabling the mode,
Gerd Moellmann <gerd@gnu.org>
parents: 25266
diff changeset
1016 (raise-frame (selected-frame)))
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
1017 (modify-frame-parameters (selected-frame)
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
1018 (list (cons 'auto-raise (> arg 0)))))
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1019
1974
94e4f619080b These changes were actually made by Richard; I stole his RCS lock.
Jim Blandy <jimb@redhat.com>
parents: 1881
diff changeset
1020 (defun auto-lower-mode (arg)
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
1021 "Toggle whether or not the selected frame should auto-lower.
8072
48c81a052cea (auto-lower-mode, auto-raise-mode): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 8056
diff changeset
1022 With arg, turn auto-lower mode on if and only if arg is positive.
48c81a052cea (auto-lower-mode, auto-raise-mode): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 8056
diff changeset
1023 Note that this controls Emacs's own auto-lower feature.
48c81a052cea (auto-lower-mode, auto-raise-mode): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 8056
diff changeset
1024 Some window managers allow you to enable auto-lower for certain windows.
48c81a052cea (auto-lower-mode, auto-raise-mode): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 8056
diff changeset
1025 You can use that for Emacs windows if you wish, but if you do,
48c81a052cea (auto-lower-mode, auto-raise-mode): Doc fixes.
Richard M. Stallman <rms@gnu.org>
parents: 8056
diff changeset
1026 that is beyond the control of Emacs and this command has no effect on it."
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
1027 (interactive "P")
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
1028 (if (null arg)
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
1029 (setq arg
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
1030 (if (cdr (assq 'auto-lower (frame-parameters (selected-frame))))
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
1031 -1 1)))
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
1032 (modify-frame-parameters (selected-frame)
1863
6f55c76b5789 * frame.el: Clean up initialization code.
Jim Blandy <jimb@redhat.com>
parents: 1821
diff changeset
1033 (list (cons 'auto-lower (> arg 0)))))
20281
799de2d79c64 (set-frame-name): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 19681
diff changeset
1034 (defun set-frame-name (name)
799de2d79c64 (set-frame-name): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 19681
diff changeset
1035 "Set the name of the selected frame to NAME.
799de2d79c64 (set-frame-name): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 19681
diff changeset
1036 When called interactively, prompt for the name of the frame.
799de2d79c64 (set-frame-name): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 19681
diff changeset
1037 The frame name is displayed on the modeline if the terminal displays only
799de2d79c64 (set-frame-name): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 19681
diff changeset
1038 one frame, otherwise the name is displayed on the frame's caption bar."
799de2d79c64 (set-frame-name): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 19681
diff changeset
1039 (interactive "sFrame name: ")
799de2d79c64 (set-frame-name): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 19681
diff changeset
1040 (modify-frame-parameters (selected-frame)
799de2d79c64 (set-frame-name): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 19681
diff changeset
1041 (list (cons 'name name))))
52614
a77e35d5d0c2 (frame-current-scroll-bars): New defun.
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
1042
a77e35d5d0c2 (frame-current-scroll-bars): New defun.
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
1043 (defun frame-current-scroll-bars (&optional frame)
a77e35d5d0c2 (frame-current-scroll-bars): New defun.
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
1044 "Return the current scroll-bar settings in frame FRAME.
63178
69c18304e55e (frame-current-scroll-bars): Fix typos in docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 62521
diff changeset
1045 Value is a cons (VERTICAL . HORIZ0NTAL) where VERTICAL specifies the
52614
a77e35d5d0c2 (frame-current-scroll-bars): New defun.
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
1046 current location of the vertical scroll-bars (left, right, or nil),
63178
69c18304e55e (frame-current-scroll-bars): Fix typos in docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 62521
diff changeset
1047 and HORIZONTAL specifies the current location of the horizontal scroll
52614
a77e35d5d0c2 (frame-current-scroll-bars): New defun.
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
1048 bars (top, bottom, or nil)."
a77e35d5d0c2 (frame-current-scroll-bars): New defun.
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
1049 (let ((vert (frame-parameter frame 'vertical-scroll-bars))
a77e35d5d0c2 (frame-current-scroll-bars): New defun.
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
1050 (hor nil))
a77e35d5d0c2 (frame-current-scroll-bars): New defun.
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
1051 (unless (memq vert '(left right nil))
a77e35d5d0c2 (frame-current-scroll-bars): New defun.
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
1052 (setq vert default-frame-scroll-bars))
a77e35d5d0c2 (frame-current-scroll-bars): New defun.
Kim F. Storm <storm@cua.dk>
parents: 52401
diff changeset
1053 (cons vert hor)))
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1054
27570
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1055 ;;;; Frame/display capabilities.
83167
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
1056 (defun selected-display ()
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
1057 "Return the display that is now selected."
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
1058 (frame-display (selected-frame)))
69ebc75cb461 Implemented display ids for multiple emacsclients on the same tty. Plus assorted bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83162
diff changeset
1059
27570
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1060 (defun display-mouse-p (&optional display)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1061 "Return non-nil if DISPLAY has a mouse available.
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1062 DISPLAY can be a display name, a frame, or nil (meaning the selected
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1063 frame's display)."
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1064 (let ((frame-type (framep-on-display display)))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1065 (cond
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1066 ((eq frame-type 'pc)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1067 (msdos-mouse-p))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1068 ((eq system-type 'windows-nt)
56759
88d59be47588 (display-mouse-p, display-selections-p): Use with-no-warnings.
Richard M. Stallman <rms@gnu.org>
parents: 56528
diff changeset
1069 (with-no-warnings
88d59be47588 (display-mouse-p, display-selections-p): Use with-no-warnings.
Richard M. Stallman <rms@gnu.org>
parents: 56528
diff changeset
1070 (> w32-num-mouse-buttons 0)))
27570
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1071 ((memq frame-type '(x mac))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1072 t) ;; We assume X and Mac *always* have a pointing device
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1073 (t
27774
097c2dd9367a (display-mouse-p): Use variable xterm-mouse-mode and check for t-mouse
Dave Love <fx@gnu.org>
parents: 27570
diff changeset
1074 (or (and (featurep 'xt-mouse)
097c2dd9367a (display-mouse-p): Use variable xterm-mouse-mode and check for t-mouse
Dave Love <fx@gnu.org>
parents: 27570
diff changeset
1075 xterm-mouse-mode)
097c2dd9367a (display-mouse-p): Use variable xterm-mouse-mode and check for t-mouse
Dave Love <fx@gnu.org>
parents: 27570
diff changeset
1076 ;; t-mouse is distributed with the GPM package. It doesn't have
097c2dd9367a (display-mouse-p): Use variable xterm-mouse-mode and check for t-mouse
Dave Love <fx@gnu.org>
parents: 27570
diff changeset
1077 ;; a toggle.
097c2dd9367a (display-mouse-p): Use variable xterm-mouse-mode and check for t-mouse
Dave Love <fx@gnu.org>
parents: 27570
diff changeset
1078 (featurep 't-mouse))))))
27570
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1079
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1080 (defun display-popup-menus-p (&optional display)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1081 "Return non-nil if popup menus are supported on DISPLAY.
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1082 DISPLAY can be a display name, a frame, or nil (meaning the selected
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1083 frame's display).
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1084 Support for popup menus requires that the mouse be available."
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1085 (and
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1086 (let ((frame-type (framep-on-display display)))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1087 (memq frame-type '(x w32 pc mac)))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1088 (display-mouse-p display)))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1089
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1090 (defun display-graphic-p (&optional display)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1091 "Return non-nil if DISPLAY is a graphic display.
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1092 Graphical displays are those which are capable of displaying several
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1093 frames and several different fonts at once. This is true for displays
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1094 that use a window system such as X, and false for text-only terminals.
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1095 DISPLAY can be a display name, a frame, or nil (meaning the selected
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1096 frame's display)."
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1097 (not (null (memq (framep-on-display display) '(x w32 mac)))))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1098
38469
38c0279a4af4 (display-images-p): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 38412
diff changeset
1099 (defun display-images-p (&optional display)
38c0279a4af4 (display-images-p): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 38412
diff changeset
1100 "Return non-nil if DISPLAY can display images.
38c0279a4af4 (display-images-p): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 38412
diff changeset
1101
38c0279a4af4 (display-images-p): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 38412
diff changeset
1102 DISPLAY can be a display name, a frame, or nil (meaning the selected
38c0279a4af4 (display-images-p): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 38412
diff changeset
1103 frame's display)."
38c0279a4af4 (display-images-p): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 38412
diff changeset
1104 (and (display-graphic-p display)
38c0279a4af4 (display-images-p): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 38412
diff changeset
1105 (fboundp 'image-mask-p)
44049
770a1adcce3e (display-images-p): Do not explicitly check display type.
Jason Rumney <jasonr@gnu.org>
parents: 43661
diff changeset
1106 (fboundp 'image-size)))
38469
38c0279a4af4 (display-images-p): New function.
Eli Zaretskii <eliz@gnu.org>
parents: 38412
diff changeset
1107
29614
356975f21b18 (display-multi-frame-p, display-multi-font-p): New
Eli Zaretskii <eliz@gnu.org>
parents: 29354
diff changeset
1108 (defalias 'display-multi-frame-p 'display-graphic-p)
356975f21b18 (display-multi-frame-p, display-multi-font-p): New
Eli Zaretskii <eliz@gnu.org>
parents: 29354
diff changeset
1109 (defalias 'display-multi-font-p 'display-graphic-p)
356975f21b18 (display-multi-frame-p, display-multi-font-p): New
Eli Zaretskii <eliz@gnu.org>
parents: 29354
diff changeset
1110
27570
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1111 (defun display-selections-p (&optional display)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1112 "Return non-nil if DISPLAY supports selections.
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1113 A selection is a way to transfer text or other data between programs
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1114 via special system buffers called `selection' or `cut buffer' or
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1115 `clipboard'.
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1116 DISPLAY can be a display name, a frame, or nil (meaning the selected
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1117 frame's display)."
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1118 (let ((frame-type (framep-on-display display)))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1119 (cond
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1120 ((eq frame-type 'pc)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1121 ;; MS-DOG frames support selections when Emacs runs inside
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1122 ;; the Windows' DOS Box.
56759
88d59be47588 (display-mouse-p, display-selections-p): Use with-no-warnings.
Richard M. Stallman <rms@gnu.org>
parents: 56528
diff changeset
1123 (with-no-warnings
88d59be47588 (display-mouse-p, display-selections-p): Use with-no-warnings.
Richard M. Stallman <rms@gnu.org>
parents: 56528
diff changeset
1124 (not (null dos-windows-version))))
27570
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1125 ((memq frame-type '(x w32 mac))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1126 t) ;; FIXME?
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1127 (t
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1128 nil))))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1129
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1130 (defun display-screens (&optional display)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1131 "Return the number of screens associated with DISPLAY."
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1132 (let ((frame-type (framep-on-display display)))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1133 (cond
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1134 ((memq frame-type '(x w32))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1135 (x-display-screens display))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1136 (t ;; FIXME: is this correct for the Mac?
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1137 1))))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1138
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1139 (defun display-pixel-height (&optional display)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1140 "Return the height of DISPLAY's screen in pixels.
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1141 For character terminals, each character counts as a single pixel."
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1142 (let ((frame-type (framep-on-display display)))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1143 (cond
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1144 ((memq frame-type '(x w32 mac))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1145 (x-display-pixel-height display))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1146 (t
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1147 (frame-height (if (framep display) display (selected-frame)))))))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1148
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1149 (defun display-pixel-width (&optional display)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1150 "Return the width of DISPLAY's screen in pixels.
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1151 For character terminals, each character counts as a single pixel."
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1152 (let ((frame-type (framep-on-display display)))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1153 (cond
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1154 ((memq frame-type '(x w32 mac))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1155 (x-display-pixel-width display))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1156 (t
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1157 (frame-width (if (framep display) display (selected-frame)))))))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1158
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1159 (defun display-mm-height (&optional display)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1160 "Return the height of DISPLAY's screen in millimeters.
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1161 If the information is unavailable, value is nil."
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1162 (and (memq (framep-on-display display) '(x w32 mac))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1163 (x-display-mm-height display)))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1164
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1165 (defun display-mm-width (&optional display)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1166 "Return the width of DISPLAY's screen in millimeters.
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1167 If the information is unavailable, value is nil."
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1168 (and (memq (framep-on-display display) '(x w32 mac))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1169 (x-display-mm-width display)))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1170
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1171 (defun display-backing-store (&optional display)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1172 "Return the backing store capability of DISPLAY's screen.
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1173 The value may be `always', `when-mapped', `not-useful', or nil if
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1174 the question is inapplicable to a certain kind of display."
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1175 (let ((frame-type (framep-on-display display)))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1176 (cond
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1177 ((memq frame-type '(x w32 mac))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1178 (x-display-backing-store display))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1179 (t
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1180 'not-useful))))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1181
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1182 (defun display-save-under (&optional display)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1183 "Return non-nil if DISPLAY's screen supports the SaveUnder feature."
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1184 (let ((frame-type (framep-on-display display)))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1185 (cond
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1186 ((memq frame-type '(x w32 mac))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1187 (x-display-save-under display))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1188 (t
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1189 'not-useful))))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1190
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1191 (defun display-planes (&optional display)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1192 "Return the number of planes supported by DISPLAY."
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1193 (let ((frame-type (framep-on-display display)))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1194 (cond
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1195 ((memq frame-type '(x w32 mac))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1196 (x-display-planes display))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1197 ((eq frame-type 'pc)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1198 4)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1199 (t
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1200 (truncate (log (length (tty-color-alist)) 2))))))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1201
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1202 (defun display-color-cells (&optional display)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1203 "Return the number of color cells supported by DISPLAY."
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1204 (let ((frame-type (framep-on-display display)))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1205 (cond
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1206 ((memq frame-type '(x w32 mac))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1207 (x-display-color-cells display))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1208 ((eq frame-type 'pc)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1209 16)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1210 (t
83008
040dd41ed7d0 Hookified termcap devices, added bootstrap display device, plus many bugfixes.
Karoly Lorentey <lorentey@elte.hu>
parents: 83004
diff changeset
1211 (tty-display-color-cells display)))))
27570
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1212
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1213 (defun display-visual-class (&optional display)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1214 "Returns the visual class of DISPLAY.
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1215 The value is one of the symbols `static-gray', `gray-scale',
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1216 `static-color', `pseudo-color', `true-color', or `direct-color'."
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1217 (let ((frame-type (framep-on-display display)))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1218 (cond
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1219 ((memq frame-type '(x w32 mac))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1220 (x-display-visual-class display))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1221 ((and (memq frame-type '(pc t))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1222 (tty-display-color-p display))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1223 'static-color)
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1224 (t
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1225 'static-gray))))
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1226
33c77685f4a2 (frames-on-display-list, framep-on-display): New functions.
Eli Zaretskii <eliz@gnu.org>
parents: 27471
diff changeset
1227
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
1228 ;;;; Aliases for backward compatibility with Emacs 18.
64543
f1a7394cf1a7 (set-frame-font, cursor-in-non-selected-windows): Fix typo in docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 64298
diff changeset
1229 (define-obsolete-function-alias 'screen-height 'frame-height) ;before 19.15
f1a7394cf1a7 (set-frame-font, cursor-in-non-selected-windows): Fix typo in docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 64298
diff changeset
1230 (define-obsolete-function-alias 'screen-width 'frame-width) ;before 19.15
958
cc82116a8f1c *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 950
diff changeset
1231
cc82116a8f1c *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 950
diff changeset
1232 (defun set-screen-width (cols &optional pretend)
64543
f1a7394cf1a7 (set-frame-font, cursor-in-non-selected-windows): Fix typo in docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 64298
diff changeset
1233 "Change the size of the screen to COLS columns.
25139
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
1234 Optional second arg non-nil means that redisplay should use COLS columns
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
1235 but that the idea of the actual width of the frame should not be changed.
64543
f1a7394cf1a7 (set-frame-font, cursor-in-non-selected-windows): Fix typo in docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 64298
diff changeset
1236 This function is provided only for compatibility with Emacs 18."
958
cc82116a8f1c *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 950
diff changeset
1237 (set-frame-width (selected-frame) cols pretend))
cc82116a8f1c *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 950
diff changeset
1238
cc82116a8f1c *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 950
diff changeset
1239 (defun set-screen-height (lines &optional pretend)
64543
f1a7394cf1a7 (set-frame-font, cursor-in-non-selected-windows): Fix typo in docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 64298
diff changeset
1240 "Change the height of the screen to LINES lines.
25139
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
1241 Optional second arg non-nil means that redisplay should use LINES lines
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
1242 but that the idea of the actual height of the screen should not be changed.
64543
f1a7394cf1a7 (set-frame-font, cursor-in-non-selected-windows): Fix typo in docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 64298
diff changeset
1243 This function is provided only for compatibility with Emacs 18."
958
cc82116a8f1c *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 950
diff changeset
1244 (set-frame-height (selected-frame) lines pretend))
cc82116a8f1c *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 950
diff changeset
1245
27471
c64b8825af55 (delete-other-frames): New function.
Gerd Moellmann <gerd@gnu.org>
parents: 27319
diff changeset
1246 (defun delete-other-frames (&optional frame)
c64b8825af55 (delete-other-frames): New function.
Gerd Moellmann <gerd@gnu.org>
parents: 27319
diff changeset
1247 "Delete all frames except FRAME.
37360
7bee98ffa33b (delete-other-frames): Handle minibuffer-only frames.
Gerd Moellmann <gerd@gnu.org>
parents: 37132
diff changeset
1248 If FRAME uses another frame's minibuffer, the minibuffer frame is
7bee98ffa33b (delete-other-frames): Handle minibuffer-only frames.
Gerd Moellmann <gerd@gnu.org>
parents: 37132
diff changeset
1249 left untouched. FRAME nil or omitted means use the selected frame."
27471
c64b8825af55 (delete-other-frames): New function.
Gerd Moellmann <gerd@gnu.org>
parents: 27319
diff changeset
1250 (interactive)
c64b8825af55 (delete-other-frames): New function.
Gerd Moellmann <gerd@gnu.org>
parents: 27319
diff changeset
1251 (unless frame
c64b8825af55 (delete-other-frames): New function.
Gerd Moellmann <gerd@gnu.org>
parents: 27319
diff changeset
1252 (setq frame (selected-frame)))
37360
7bee98ffa33b (delete-other-frames): Handle minibuffer-only frames.
Gerd Moellmann <gerd@gnu.org>
parents: 37132
diff changeset
1253 (let* ((mini-frame (window-frame (minibuffer-window frame)))
7bee98ffa33b (delete-other-frames): Handle minibuffer-only frames.
Gerd Moellmann <gerd@gnu.org>
parents: 37132
diff changeset
1254 (frames (delq mini-frame (delq frame (frame-list)))))
7bee98ffa33b (delete-other-frames): Handle minibuffer-only frames.
Gerd Moellmann <gerd@gnu.org>
parents: 37132
diff changeset
1255 ;; Delete mon-minibuffer-only frames first, because `delete-frame'
7bee98ffa33b (delete-other-frames): Handle minibuffer-only frames.
Gerd Moellmann <gerd@gnu.org>
parents: 37132
diff changeset
1256 ;; signals an error when trying to delete a mini-frame that's
7bee98ffa33b (delete-other-frames): Handle minibuffer-only frames.
Gerd Moellmann <gerd@gnu.org>
parents: 37132
diff changeset
1257 ;; still in use by another frame.
7bee98ffa33b (delete-other-frames): Handle minibuffer-only frames.
Gerd Moellmann <gerd@gnu.org>
parents: 37132
diff changeset
1258 (dolist (frame frames)
7bee98ffa33b (delete-other-frames): Handle minibuffer-only frames.
Gerd Moellmann <gerd@gnu.org>
parents: 37132
diff changeset
1259 (unless (eq (frame-parameter frame 'minibuffer) 'only)
7bee98ffa33b (delete-other-frames): Handle minibuffer-only frames.
Gerd Moellmann <gerd@gnu.org>
parents: 37132
diff changeset
1260 (delete-frame frame)))
7bee98ffa33b (delete-other-frames): Handle minibuffer-only frames.
Gerd Moellmann <gerd@gnu.org>
parents: 37132
diff changeset
1261 ;; Delete minibuffer-only frames.
7bee98ffa33b (delete-other-frames): Handle minibuffer-only frames.
Gerd Moellmann <gerd@gnu.org>
parents: 37132
diff changeset
1262 (dolist (frame frames)
7bee98ffa33b (delete-other-frames): Handle minibuffer-only frames.
Gerd Moellmann <gerd@gnu.org>
parents: 37132
diff changeset
1263 (when (eq (frame-parameter frame 'minibuffer) 'only)
7bee98ffa33b (delete-other-frames): Handle minibuffer-only frames.
Gerd Moellmann <gerd@gnu.org>
parents: 37132
diff changeset
1264 (delete-frame frame)))))
27471
c64b8825af55 (delete-other-frames): New function.
Gerd Moellmann <gerd@gnu.org>
parents: 27319
diff changeset
1265
29354
4ed4a700358b Update calls to make-obsolete with a WHEN argument.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 28856
diff changeset
1266 (make-obsolete 'set-screen-width 'set-frame-width) ;before 19.15
4ed4a700358b Update calls to make-obsolete with a WHEN argument.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 28856
diff changeset
1267 (make-obsolete 'set-screen-height 'set-frame-height) ;before 19.15
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
1268
47738
f75902c4cbb5 (delete-frame-hook): Variable alias for
John Paul Wallington <jpw@pobox.com>
parents: 47016
diff changeset
1269 ;; miscellaneous obsolescence declarations
64543
f1a7394cf1a7 (set-frame-font, cursor-in-non-selected-windows): Fix typo in docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 64298
diff changeset
1270 (define-obsolete-variable-alias 'delete-frame-hook
f1a7394cf1a7 (set-frame-font, cursor-in-non-selected-windows): Fix typo in docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 64298
diff changeset
1271 'delete-frame-functions "22.1")
47738
f75902c4cbb5 (delete-frame-hook): Variable alias for
John Paul Wallington <jpw@pobox.com>
parents: 47016
diff changeset
1272
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
1273
39846
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
1274 ;; Highlighting trailing whitespace.
24982
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1275
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1276 (make-variable-buffer-local 'show-trailing-whitespace)
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1277
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1278 (defcustom show-trailing-whitespace nil
56162
de7deaab0320 (show-trailing-whitespace): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 55878
diff changeset
1279 "*Non-nil means highlight trailing whitespace.
de7deaab0320 (show-trailing-whitespace): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 55878
diff changeset
1280 This is done in the face `trailing-whitespace'."
24982
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1281 :tag "Highlight trailing whitespace."
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1282 :type 'boolean
62521
91bf7b558b82 (show-trailing-whitespace): In group `whitespace-faces'.
Richard M. Stallman <rms@gnu.org>
parents: 60398
diff changeset
1283 :group 'whitespace-faces)
24982
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1284
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1285
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1286
39846
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
1287 ;; Scrolling
28693
062f88e62612 (scrolling): New group.
Gerd Moellmann <gerd@gnu.org>
parents: 28182
diff changeset
1288
062f88e62612 (scrolling): New group.
Gerd Moellmann <gerd@gnu.org>
parents: 28182
diff changeset
1289 (defgroup scrolling nil
062f88e62612 (scrolling): New group.
Gerd Moellmann <gerd@gnu.org>
parents: 28182
diff changeset
1290 "Scrolling windows."
062f88e62612 (scrolling): New group.
Gerd Moellmann <gerd@gnu.org>
parents: 28182
diff changeset
1291 :version "21.1"
062f88e62612 (scrolling): New group.
Gerd Moellmann <gerd@gnu.org>
parents: 28182
diff changeset
1292 :group 'frames)
062f88e62612 (scrolling): New group.
Gerd Moellmann <gerd@gnu.org>
parents: 28182
diff changeset
1293
43661
9f8ac5084298 (auto-hscroll-mode): Renamed from automatic-hscrolling.
Eli Zaretskii <eliz@gnu.org>
parents: 43545
diff changeset
1294 (defcustom auto-hscroll-mode t
37823
7d2b56f9f9b4 (automatic-hscrolling): Fix a typo. From Pavel Janik <Pavel@Janik.cz>.
Eli Zaretskii <eliz@gnu.org>
parents: 37360
diff changeset
1295 "*Allow or disallow automatic scrolling windows horizontally.
28856
20f840aa2301 (automatic-hscrolling): Typo.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 28693
diff changeset
1296 If non-nil, windows are automatically scrolled horizontally to make
28693
062f88e62612 (scrolling): New group.
Gerd Moellmann <gerd@gnu.org>
parents: 28182
diff changeset
1297 point visible."
062f88e62612 (scrolling): New group.
Gerd Moellmann <gerd@gnu.org>
parents: 28182
diff changeset
1298 :version "21.1"
062f88e62612 (scrolling): New group.
Gerd Moellmann <gerd@gnu.org>
parents: 28182
diff changeset
1299 :type 'boolean
062f88e62612 (scrolling): New group.
Gerd Moellmann <gerd@gnu.org>
parents: 28182
diff changeset
1300 :group 'scrolling)
43661
9f8ac5084298 (auto-hscroll-mode): Renamed from automatic-hscrolling.
Eli Zaretskii <eliz@gnu.org>
parents: 43545
diff changeset
1301 (defvaralias 'automatic-hscrolling 'auto-hscroll-mode)
28693
062f88e62612 (scrolling): New group.
Gerd Moellmann <gerd@gnu.org>
parents: 28182
diff changeset
1302
062f88e62612 (scrolling): New group.
Gerd Moellmann <gerd@gnu.org>
parents: 28182
diff changeset
1303
39846
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
1304 ;; Blinking cursor
24982
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1305
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1306 (defgroup cursor nil
26284
6de035f92990 Many doc fixes.
Gerd Moellmann <gerd@gnu.org>
parents: 26278
diff changeset
1307 "Displaying text cursors."
25139
fde300f58ed8 Change comments to doc strings and other doc fixes.
Dave Love <fx@gnu.org>
parents: 25134
diff changeset
1308 :version "21.1"
24982
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1309 :group 'frames)
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1310
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1311 (defcustom blink-cursor-delay 0.5
26284
6de035f92990 Many doc fixes.
Gerd Moellmann <gerd@gnu.org>
parents: 26278
diff changeset
1312 "*Seconds of idle time after which cursor starts to blink."
24982
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1313 :tag "Delay in seconds."
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1314 :type 'number
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1315 :group 'cursor)
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1316
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1317 (defcustom blink-cursor-interval 0.5
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1318 "*Length of cursor blink interval in seconds."
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1319 :tag "Blink interval in seconds."
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1320 :type 'number
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1321 :group 'cursor)
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1322
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1323 (defvar blink-cursor-idle-timer nil
26284
6de035f92990 Many doc fixes.
Gerd Moellmann <gerd@gnu.org>
parents: 26278
diff changeset
1324 "Timer started after `blink-cursor-delay' seconds of Emacs idle time.
6de035f92990 Many doc fixes.
Gerd Moellmann <gerd@gnu.org>
parents: 26278
diff changeset
1325 The function `blink-cursor-start' is called when the timer fires.")
24982
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1326
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1327 (defvar blink-cursor-timer nil
26284
6de035f92990 Many doc fixes.
Gerd Moellmann <gerd@gnu.org>
parents: 26278
diff changeset
1328 "Timer started from `blink-cursor-start'.
60021
d751f08f4c04 (blink-cursor-timer): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59996
diff changeset
1329 This timer calls `blink-cursor-timer-function' every
d751f08f4c04 (blink-cursor-timer): Doc fix.
Luc Teirlinck <teirllm@auburn.edu>
parents: 59996
diff changeset
1330 `blink-cursor-interval' seconds.")
24982
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1331
60193
261ebd199f28 (blink-cursor-mode): Use define-minor-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60021
diff changeset
1332 (define-minor-mode blink-cursor-mode
24982
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1333 "Toggle blinking cursor mode.
34002
698d4ae0484c (blink-cursor-mode): Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 33784
diff changeset
1334 With a numeric argument, turn blinking cursor mode on iff ARG is positive.
24982
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1335 When blinking cursor mode is enabled, the cursor of the selected
40467
e9c66842eb07 (blink-cursor-mode): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 39846
diff changeset
1336 window blinks.
e9c66842eb07 (blink-cursor-mode): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 39846
diff changeset
1337
e9c66842eb07 (blink-cursor-mode): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 39846
diff changeset
1338 Note that this command is effective only when Emacs
e9c66842eb07 (blink-cursor-mode): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 39846
diff changeset
1339 displays through a window system, because then Emacs does its own
e9c66842eb07 (blink-cursor-mode): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents: 39846
diff changeset
1340 cursor display. On a text-only terminal, this is not implemented."
60193
261ebd199f28 (blink-cursor-mode): Use define-minor-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60021
diff changeset
1341 :init-value (not (or noninteractive
64298
acabc71be63b (blink-cursor-mode): Use `custom-initialize-safe-default' and simplify
Luc Teirlinck <teirllm@auburn.edu>
parents: 64256
diff changeset
1342 no-blinking-cursor
60193
261ebd199f28 (blink-cursor-mode): Use define-minor-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60021
diff changeset
1343 (eq system-type 'ms-dos)
83259
cf4b5d1da82f Merged from miles@gnu.org--gnu-2005 (patch 119)
Karoly Lorentey <lorentey@elte.hu>
parents: 83254 60193
diff changeset
1344 (not (memq initial-window-system '(x w32)))))
64298
acabc71be63b (blink-cursor-mode): Use `custom-initialize-safe-default' and simplify
Luc Teirlinck <teirllm@auburn.edu>
parents: 64256
diff changeset
1345 :initialize 'custom-initialize-safe-default
60237
e8f69f91a18b (blink-cursor-mode): Add :group keyword.
Luc Teirlinck <teirllm@auburn.edu>
parents: 60193
diff changeset
1346 :group 'cursor
60193
261ebd199f28 (blink-cursor-mode): Use define-minor-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60021
diff changeset
1347 :global t
261ebd199f28 (blink-cursor-mode): Use define-minor-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60021
diff changeset
1348 (if blink-cursor-idle-timer (cancel-timer blink-cursor-idle-timer))
261ebd199f28 (blink-cursor-mode): Use define-minor-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60021
diff changeset
1349 (if blink-cursor-timer (cancel-timer blink-cursor-timer))
261ebd199f28 (blink-cursor-mode): Use define-minor-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60021
diff changeset
1350 (setq blink-cursor-idle-timer nil
261ebd199f28 (blink-cursor-mode): Use define-minor-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60021
diff changeset
1351 blink-cursor-timer nil)
261ebd199f28 (blink-cursor-mode): Use define-minor-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60021
diff changeset
1352 (if blink-cursor-mode
261ebd199f28 (blink-cursor-mode): Use define-minor-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60021
diff changeset
1353 (progn
261ebd199f28 (blink-cursor-mode): Use define-minor-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60021
diff changeset
1354 ;; Hide the cursor.
261ebd199f28 (blink-cursor-mode): Use define-minor-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60021
diff changeset
1355 ;;(internal-show-cursor nil nil)
261ebd199f28 (blink-cursor-mode): Use define-minor-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60021
diff changeset
1356 (setq blink-cursor-idle-timer
261ebd199f28 (blink-cursor-mode): Use define-minor-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60021
diff changeset
1357 (run-with-idle-timer blink-cursor-delay
261ebd199f28 (blink-cursor-mode): Use define-minor-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60021
diff changeset
1358 blink-cursor-delay
261ebd199f28 (blink-cursor-mode): Use define-minor-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60021
diff changeset
1359 'blink-cursor-start)))
261ebd199f28 (blink-cursor-mode): Use define-minor-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60021
diff changeset
1360 (internal-show-cursor nil t)))
261ebd199f28 (blink-cursor-mode): Use define-minor-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60021
diff changeset
1361
64543
f1a7394cf1a7 (set-frame-font, cursor-in-non-selected-windows): Fix typo in docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 64298
diff changeset
1362 (define-obsolete-variable-alias 'blink-cursor 'blink-cursor-mode "22.1")
24982
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1363
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1364 (defun blink-cursor-start ()
26284
6de035f92990 Many doc fixes.
Gerd Moellmann <gerd@gnu.org>
parents: 26278
diff changeset
1365 "Timer function called from the timer `blink-cursor-idle-timer'.
6de035f92990 Many doc fixes.
Gerd Moellmann <gerd@gnu.org>
parents: 26278
diff changeset
1366 This starts the timer `blink-cursor-timer', which makes the cursor blink
6de035f92990 Many doc fixes.
Gerd Moellmann <gerd@gnu.org>
parents: 26278
diff changeset
1367 if appropriate. It also arranges to cancel that timer when the next
6de035f92990 Many doc fixes.
Gerd Moellmann <gerd@gnu.org>
parents: 26278
diff changeset
1368 command starts, by installing a pre-command hook."
24982
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1369 (when (null blink-cursor-timer)
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1370 (add-hook 'pre-command-hook 'blink-cursor-end)
55878
83ecae86dde6 (blink-cursor-start): Turn cursor off initially so blink
Kim F. Storm <storm@cua.dk>
parents: 55086
diff changeset
1371 (internal-show-cursor nil nil)
24982
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1372 (setq blink-cursor-timer
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1373 (run-with-timer blink-cursor-interval blink-cursor-interval
26332
37f66ea5d1a1 * frame.el (blink-cursor-mode, blink-cursor-end): Use
Gerd Moellmann <gerd@gnu.org>
parents: 26284
diff changeset
1374 'blink-cursor-timer-function))))
37f66ea5d1a1 * frame.el (blink-cursor-mode, blink-cursor-end): Use
Gerd Moellmann <gerd@gnu.org>
parents: 26284
diff changeset
1375
37f66ea5d1a1 * frame.el (blink-cursor-mode, blink-cursor-end): Use
Gerd Moellmann <gerd@gnu.org>
parents: 26284
diff changeset
1376 (defun blink-cursor-timer-function ()
37f66ea5d1a1 * frame.el (blink-cursor-mode, blink-cursor-end): Use
Gerd Moellmann <gerd@gnu.org>
parents: 26284
diff changeset
1377 "Timer function of timer `blink-cursor-timer'."
37f66ea5d1a1 * frame.el (blink-cursor-mode, blink-cursor-end): Use
Gerd Moellmann <gerd@gnu.org>
parents: 26284
diff changeset
1378 (internal-show-cursor nil (not (internal-show-cursor-p))))
24982
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1379
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1380 (defun blink-cursor-end ()
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1381 "Stop cursor blinking.
26284
6de035f92990 Many doc fixes.
Gerd Moellmann <gerd@gnu.org>
parents: 26278
diff changeset
1382 This is installed as a pre-command hook by `blink-cursor-start'.
41579
bab6e8eba0e1 comments indented properly
Sam Steingold <sds@gnu.org>
parents: 40673
diff changeset
1383 When run, it cancels the timer `blink-cursor-timer' and removes
26284
6de035f92990 Many doc fixes.
Gerd Moellmann <gerd@gnu.org>
parents: 26278
diff changeset
1384 itself as a pre-command hook."
24982
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1385 (remove-hook 'pre-command-hook 'blink-cursor-end)
26332
37f66ea5d1a1 * frame.el (blink-cursor-mode, blink-cursor-end): Use
Gerd Moellmann <gerd@gnu.org>
parents: 26284
diff changeset
1386 (internal-show-cursor nil t)
24982
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1387 (cancel-timer blink-cursor-timer)
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1388 (setq blink-cursor-timer nil))
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1389
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1390
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1391
39846
2e4007551cfd (special-display-popup-frame): Obey new specs `same-window' and `same-frame'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 39505
diff changeset
1392 ;; Hourglass pointer
24982
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1393
36257
620c4b282fce (display-hourglass): Renamed from busy-cursor.
Gerd Moellmann <gerd@gnu.org>
parents: 35856
diff changeset
1394 (defcustom display-hourglass t
620c4b282fce (display-hourglass): Renamed from busy-cursor.
Gerd Moellmann <gerd@gnu.org>
parents: 35856
diff changeset
1395 "*Non-nil means show an hourglass pointer when running under a window system."
620c4b282fce (display-hourglass): Renamed from busy-cursor.
Gerd Moellmann <gerd@gnu.org>
parents: 35856
diff changeset
1396 :tag "Hourglass pointer"
24982
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1397 :type 'boolean
36257
620c4b282fce (display-hourglass): Renamed from busy-cursor.
Gerd Moellmann <gerd@gnu.org>
parents: 35856
diff changeset
1398 :group 'cursor)
24982
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1399
36257
620c4b282fce (display-hourglass): Renamed from busy-cursor.
Gerd Moellmann <gerd@gnu.org>
parents: 35856
diff changeset
1400 (defcustom hourglass-delay 1
620c4b282fce (display-hourglass): Renamed from busy-cursor.
Gerd Moellmann <gerd@gnu.org>
parents: 35856
diff changeset
1401 "*Seconds to wait before displaying an hourglass pointer."
620c4b282fce (display-hourglass): Renamed from busy-cursor.
Gerd Moellmann <gerd@gnu.org>
parents: 35856
diff changeset
1402 :tag "Hourglass delay"
27916
3288a7cd4796 (busy-cursor-delay-seconds): Change type to `number'.
Gerd Moellmann <gerd@gnu.org>
parents: 27909
diff changeset
1403 :type 'number
36257
620c4b282fce (display-hourglass): Renamed from busy-cursor.
Gerd Moellmann <gerd@gnu.org>
parents: 35856
diff changeset
1404 :group 'cursor)
27865
490743da8567 (show-cursor-in-non-selected-windows): New option.
Gerd Moellmann <gerd@gnu.org>
parents: 27846
diff changeset
1405
27846
1ef6cae16192 (show-cursor-in-non-selected-windows): New option.
Gerd Moellmann <gerd@gnu.org>
parents: 27774
diff changeset
1406
37132
7d4fab575208 (cursor-in-non-selected-windows): Replaces
Gerd Moellmann <gerd@gnu.org>
parents: 36317
diff changeset
1407 (defcustom cursor-in-non-selected-windows t
64543
f1a7394cf1a7 (set-frame-font, cursor-in-non-selected-windows): Fix typo in docstring.
Juanma Barranquero <lekktu@gmail.com>
parents: 64298
diff changeset
1408 "*Non-nil means show a hollow box cursor in non-selected windows.
33784
086c757fef3e (show-cursor-in-non-selected-windows): Doc fix.
Gerd Moellmann <gerd@gnu.org>
parents: 33186
diff changeset
1409 If nil, don't show a cursor except in the selected window.
41579
bab6e8eba0e1 comments indented properly
Sam Steingold <sds@gnu.org>
parents: 40673
diff changeset
1410 Use Custom to set this variable to get the display updated."
27846
1ef6cae16192 (show-cursor-in-non-selected-windows): New option.
Gerd Moellmann <gerd@gnu.org>
parents: 27774
diff changeset
1411 :tag "Cursor in non-selected windows"
1ef6cae16192 (show-cursor-in-non-selected-windows): New option.
Gerd Moellmann <gerd@gnu.org>
parents: 27774
diff changeset
1412 :type 'boolean
1ef6cae16192 (show-cursor-in-non-selected-windows): New option.
Gerd Moellmann <gerd@gnu.org>
parents: 27774
diff changeset
1413 :group 'cursor
1ef6cae16192 (show-cursor-in-non-selected-windows): New option.
Gerd Moellmann <gerd@gnu.org>
parents: 27774
diff changeset
1414 :set #'(lambda (symbol value)
1ef6cae16192 (show-cursor-in-non-selected-windows): New option.
Gerd Moellmann <gerd@gnu.org>
parents: 27774
diff changeset
1415 (set-default symbol value)
1ef6cae16192 (show-cursor-in-non-selected-windows): New option.
Gerd Moellmann <gerd@gnu.org>
parents: 27774
diff changeset
1416 (force-mode-line-update t)))
41579
bab6e8eba0e1 comments indented properly
Sam Steingold <sds@gnu.org>
parents: 40673
diff changeset
1417
24982
c81447275ea3 (after-setting-font-hooks): New; from Eric Banchrow
Gerd Moellmann <gerd@gnu.org>
parents: 24926
diff changeset
1418
394
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1419 ;;;; Key bindings
5bd386d1a1cc Initial revision
Jim Blandy <jimb@redhat.com>
parents:
diff changeset
1420
15347
3885819ed860 (make-frame-command): New function.
Richard M. Stallman <rms@gnu.org>
parents: 14701
diff changeset
1421 (define-key ctl-x-5-map "2" 'make-frame-command)
27471
c64b8825af55 (delete-other-frames): New function.
Gerd Moellmann <gerd@gnu.org>
parents: 27319
diff changeset
1422 (define-key ctl-x-5-map "1" 'delete-other-frames)
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
1423 (define-key ctl-x-5-map "0" 'delete-frame)
4425
1b48826df9cb (other-frame): New function, analogous to other-window.
Roland McGrath <roland@gnu.org>
parents: 4360
diff changeset
1424 (define-key ctl-x-5-map "o" 'other-frame)
584
4cd7543be581 *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 542
diff changeset
1425
83065
a871be7b26a5 Implemented suspending of emacsclient frames.
Karoly Lorentey <lorentey@elte.hu>
parents: 83018
diff changeset
1426 (substitute-key-definition 'suspend-emacs 'suspend-frame global-map)
a871be7b26a5 Implemented suspending of emacsclient frames.
Karoly Lorentey <lorentey@elte.hu>
parents: 83018
diff changeset
1427
83333
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1428
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1429 (defun terminal-id (terminal)
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1430 "Return the numerical id of terminal TERMINAL.
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1431
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1432 TERMINAL can be a terminal id, a frame, or nil (meaning the
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1433 selected frame's terminal)."
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1434 (cond
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1435 ((integerp terminal)
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1436 terminal)
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1437 ((or (null terminal) (framep terminal))
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1438 (frame-display terminal))
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1439 (t
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1440 (error "Invalid argument %s in `terminal-id'" terminal))))
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1441
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1442 (defvar terminal-parameter-alist nil
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1443 "An alist of terminal parameter alists.")
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1444
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1445 (defun terminal-parameters (&optional terminal)
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1446 "Return the paramater-alist of terminal TERMINAL.
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1447 It is a list of elements of the form (PARM . VALUE), where PARM is a symbol.
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1448
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1449 TERMINAL can be a terminal id, a frame, or nil (meaning the
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1450 selected frame's terminal)."
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1451 (cdr (assq (terminal-id terminal) terminal-parameter-alist)))
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1452
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1453 (defun terminal-parameter (terminal parameter)
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1454 "Return TERMINAL's value for parameter PARAMETER.
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1455
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1456 TERMINAL can be a terminal id, a frame, or nil (meaning the
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1457 selected frame's terminal)."
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1458 (cdr (assq parameter (cdr (assq (terminal-id terminal) terminal-parameter-alist)))))
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1459
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1460 (defun set-terminal-parameter (terminal parameter value)
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1461 "Set TERMINAL's value for parameter PARAMETER to VALUE.
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1462 Returns the previous value of PARAMETER.
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1463
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1464 TERMINAL can be a terminal id, a frame, or nil (meaning the
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1465 selected frame's terminal)."
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1466 (setq terminal (terminal-id terminal))
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1467 (let* ((alist (assq terminal terminal-parameter-alist))
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1468 (pair (assq parameter (cdr alist)))
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1469 (result (cdr pair)))
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1470 (cond
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1471 (pair (setcdr pair value))
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1472 (alist (setcdr alist (cons (cons parameter value) (cdr alist))))
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1473 (t (setq terminal-parameter-alist
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1474 (cons (cons terminal
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1475 (cons (cons parameter value)
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1476 nil))
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1477 terminal-parameter-alist))))
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1478 result))
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1479
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1480 (defun terminal-handle-delete-frame (frame)
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1481 "Clean up terminal parameters of FRAME, if it's the last frame on its terminal."
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1482 ;; XXX We assume that the display is closed immediately after the
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1483 ;; last frame is deleted on it. It would be better to create a hook
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1484 ;; called `delete-display-functions', and use it instead.
83335
60208d3a0bb1 Handle and document that `delete-frame' may call functions in `delete-frame-functions' twice.
Karoly Lorentey <lorentey@elte.hu>
parents: 83333
diff changeset
1485 (when (and (frame-live-p frame)
60208d3a0bb1 Handle and document that `delete-frame' may call functions in `delete-frame-functions' twice.
Karoly Lorentey <lorentey@elte.hu>
parents: 83333
diff changeset
1486 (= 1 (length (frames-on-display-list (frame-display frame)))))
83333
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1487 (setq terminal-parameter-alist
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1488 (assq-delete-all (frame-display frame) terminal-parameter-alist))))
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1489
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1490 (add-hook 'delete-frame-functions 'terminal-handle-delete-frame)
40c0ee282254 Implement rudimentary Lisp-level terminal parameters.
Karoly Lorentey <lorentey@elte.hu>
parents: 83332
diff changeset
1491
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
1492 (provide 'frame)
658
7cbd4fcd8b0f *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 584
diff changeset
1493
60193
261ebd199f28 (blink-cursor-mode): Use define-minor-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 60021
diff changeset
1494 ;; arch-tag: 82979c70-b8f2-4306-b2ad-ddbd6b328b56
777
c99faf9381bb *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 756
diff changeset
1495 ;;; frame.el ends here