1993-03-12 19:53:22 +00:00
|
|
|
|
;;; x-win.el --- parse switches controlling interface with X window system
|
1996-01-14 09:58:28 +00:00
|
|
|
|
|
1994-05-03 22:46:37 +00:00
|
|
|
|
;; Copyright (C) 1993, 1994 Free Software Foundation, Inc.
|
1993-03-12 19:53:22 +00:00
|
|
|
|
|
|
|
|
|
;; Author: FSF
|
|
|
|
|
;; Keywords: terminals
|
|
|
|
|
|
1996-01-14 09:58:28 +00:00
|
|
|
|
;; This file is part of GNU Emacs.
|
|
|
|
|
|
|
|
|
|
;; GNU Emacs is free software; you can redistribute it and/or modify
|
|
|
|
|
;; it under the terms of the GNU General Public License as published by
|
|
|
|
|
;; the Free Software Foundation; either version 2, or (at your option)
|
|
|
|
|
;; any later version.
|
|
|
|
|
|
|
|
|
|
;; GNU Emacs is distributed in the hope that it will be useful,
|
|
|
|
|
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
;; GNU General Public License for more details.
|
|
|
|
|
|
|
|
|
|
;; You should have received a copy of the GNU General Public License
|
|
|
|
|
;; along with GNU Emacs; see the file COPYING. If not, write to the
|
|
|
|
|
;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
|
|
|
;; Boston, MA 02111-1307, USA.
|
1990-03-22 20:46:04 +00:00
|
|
|
|
|
1993-03-12 19:53:22 +00:00
|
|
|
|
;;; Commentary:
|
1990-03-22 20:46:04 +00:00
|
|
|
|
|
|
|
|
|
;; X-win.el: this file is loaded from ../lisp/startup.el when it recognizes
|
|
|
|
|
;; that X windows are to be used. Command line switches are parsed and those
|
|
|
|
|
;; pertaining to X are processed and removed from the command line. The
|
|
|
|
|
;; X display is opened and hooks are set for popping up the initial window.
|
|
|
|
|
|
|
|
|
|
;; startup.el will then examine startup files, and eventually call the hooks
|
|
|
|
|
;; which create the first window (s).
|
1993-03-12 19:53:22 +00:00
|
|
|
|
|
|
|
|
|
;;; Code:
|
1990-03-22 20:46:04 +00:00
|
|
|
|
|
|
|
|
|
;; These are the standard X switches from the Xt Initialize.c file of
|
|
|
|
|
;; Release 4.
|
|
|
|
|
|
|
|
|
|
;; Command line Resource Manager string
|
|
|
|
|
|
|
|
|
|
;; +rv *reverseVideo
|
|
|
|
|
;; +synchronous *synchronous
|
|
|
|
|
;; -background *background
|
|
|
|
|
;; -bd *borderColor
|
|
|
|
|
;; -bg *background
|
|
|
|
|
;; -bordercolor *borderColor
|
|
|
|
|
;; -borderwidth .borderWidth
|
|
|
|
|
;; -bw .borderWidth
|
|
|
|
|
;; -display .display
|
|
|
|
|
;; -fg *foreground
|
|
|
|
|
;; -fn *font
|
|
|
|
|
;; -font *font
|
|
|
|
|
;; -foreground *foreground
|
|
|
|
|
;; -geometry .geometry
|
1993-05-25 13:17:52 +00:00
|
|
|
|
;; -i .iconType
|
|
|
|
|
;; -itype .iconType
|
1990-03-22 20:46:04 +00:00
|
|
|
|
;; -iconic .iconic
|
|
|
|
|
;; -name .name
|
|
|
|
|
;; -reverse *reverseVideo
|
|
|
|
|
;; -rv *reverseVideo
|
|
|
|
|
;; -selectionTimeout .selectionTimeout
|
|
|
|
|
;; -synchronous *synchronous
|
|
|
|
|
;; -xrm
|
|
|
|
|
|
|
|
|
|
;; An alist of X options and the function which handles them. See
|
|
|
|
|
;; ../startup.el.
|
|
|
|
|
|
1991-05-17 00:15:22 +00:00
|
|
|
|
(if (not (eq window-system 'x))
|
1993-07-18 06:21:42 +00:00
|
|
|
|
(error "%s: Loading x-win.el but not compiled for X" (invocation-name)))
|
1991-05-17 00:15:22 +00:00
|
|
|
|
|
1992-07-15 03:24:58 +00:00
|
|
|
|
(require 'frame)
|
1991-12-20 08:26:25 +00:00
|
|
|
|
(require 'mouse)
|
1993-03-02 02:03:41 +00:00
|
|
|
|
(require 'scroll-bar)
|
1993-05-09 23:54:12 +00:00
|
|
|
|
(require 'faces)
|
|
|
|
|
(require 'select)
|
1993-05-15 21:19:18 +00:00
|
|
|
|
(require 'menu-bar)
|
1991-05-17 00:15:22 +00:00
|
|
|
|
|
1993-06-01 00:29:11 +00:00
|
|
|
|
(defvar x-invocation-args)
|
|
|
|
|
|
1993-05-25 16:21:12 +00:00
|
|
|
|
(defvar x-command-line-resources nil)
|
|
|
|
|
|
1990-03-22 20:46:04 +00:00
|
|
|
|
;; Handler for switches of the form "-switch value" or "-switch".
|
|
|
|
|
(defun x-handle-switch (switch)
|
1995-12-29 21:09:34 +00:00
|
|
|
|
(let ((aelt (assoc switch command-line-x-option-alist)))
|
1990-03-22 20:46:04 +00:00
|
|
|
|
(if aelt
|
1995-12-29 21:09:34 +00:00
|
|
|
|
(let ((param (nth 3 aelt))
|
|
|
|
|
(value (nth 4 aelt)))
|
|
|
|
|
(if value
|
|
|
|
|
(setq default-frame-alist
|
|
|
|
|
(cons (cons param value)
|
|
|
|
|
default-frame-alist))
|
1992-07-15 03:24:58 +00:00
|
|
|
|
(setq default-frame-alist
|
1995-12-29 21:09:34 +00:00
|
|
|
|
(cons (cons param
|
|
|
|
|
(car x-invocation-args))
|
|
|
|
|
default-frame-alist)
|
|
|
|
|
x-invocation-args (cdr x-invocation-args)))))))
|
|
|
|
|
|
|
|
|
|
;; Handler for switches of the form "-switch n"
|
|
|
|
|
(defun x-handle-numeric-switch (switch)
|
|
|
|
|
(let ((aelt (assoc switch command-line-x-option-alist)))
|
|
|
|
|
(if aelt
|
|
|
|
|
(let ((param (nth 3 aelt)))
|
1992-07-15 03:24:58 +00:00
|
|
|
|
(setq default-frame-alist
|
1995-12-29 21:09:34 +00:00
|
|
|
|
(cons (cons param
|
|
|
|
|
(string-to-int (car x-invocation-args)))
|
1992-07-15 03:24:58 +00:00
|
|
|
|
default-frame-alist)
|
1995-12-29 21:09:34 +00:00
|
|
|
|
x-invocation-args
|
|
|
|
|
(cdr x-invocation-args))))))
|
1990-03-22 20:46:04 +00:00
|
|
|
|
|
1993-07-27 08:38:00 +00:00
|
|
|
|
;; Make -iconic apply only to the initial frame!
|
|
|
|
|
(defun x-handle-iconic (switch)
|
|
|
|
|
(setq initial-frame-alist
|
|
|
|
|
(cons '(visibility . icon) initial-frame-alist)))
|
|
|
|
|
|
1993-07-18 06:21:42 +00:00
|
|
|
|
;; Handle the -xrm option.
|
|
|
|
|
(defun x-handle-xrm-switch (switch)
|
|
|
|
|
(or (consp x-invocation-args)
|
|
|
|
|
(error "%s: missing argument to `%s' option" (invocation-name) switch))
|
1993-05-25 16:21:12 +00:00
|
|
|
|
(setq x-command-line-resources (car x-invocation-args))
|
|
|
|
|
(setq x-invocation-args (cdr x-invocation-args)))
|
|
|
|
|
|
1990-03-22 20:46:04 +00:00
|
|
|
|
;; Handle the geometry option
|
|
|
|
|
(defun x-handle-geometry (switch)
|
1994-05-01 08:55:23 +00:00
|
|
|
|
(let ((geo (x-parse-geometry (car x-invocation-args))))
|
|
|
|
|
(setq initial-frame-alist
|
|
|
|
|
(append initial-frame-alist
|
|
|
|
|
(if (or (assq 'left geo) (assq 'top geo))
|
|
|
|
|
'((user-position . t)))
|
|
|
|
|
(if (or (assq 'height geo) (assq 'width geo))
|
|
|
|
|
'((user-size . t)))
|
|
|
|
|
geo)
|
|
|
|
|
x-invocation-args (cdr x-invocation-args))))
|
1990-03-22 20:46:04 +00:00
|
|
|
|
|
1993-07-18 06:21:42 +00:00
|
|
|
|
;; Handle the -name and -rn options. Set the variable x-resource-name
|
|
|
|
|
;; to the option's operand; if the switch was `-name', set the name of
|
|
|
|
|
;; the initial frame, too.
|
|
|
|
|
(defun x-handle-name-rn-switch (switch)
|
|
|
|
|
(or (consp x-invocation-args)
|
|
|
|
|
(error "%s: missing argument to `%s' option" (invocation-name) switch))
|
|
|
|
|
(setq x-resource-name (car x-invocation-args)
|
|
|
|
|
x-invocation-args (cdr x-invocation-args))
|
|
|
|
|
(if (string= switch "-name")
|
|
|
|
|
(setq initial-frame-alist (cons (cons 'name x-resource-name)
|
|
|
|
|
initial-frame-alist))))
|
|
|
|
|
|
1990-03-22 20:46:04 +00:00
|
|
|
|
(defvar x-display-name nil
|
1992-07-15 03:24:58 +00:00
|
|
|
|
"The X display name specifying server and X frame.")
|
1990-03-22 20:46:04 +00:00
|
|
|
|
|
|
|
|
|
(defun x-handle-display (switch)
|
|
|
|
|
(setq x-display-name (car x-invocation-args)
|
|
|
|
|
x-invocation-args (cdr x-invocation-args)))
|
|
|
|
|
|
1991-07-11 22:55:55 +00:00
|
|
|
|
(defun x-handle-args (args)
|
1994-04-06 04:51:37 +00:00
|
|
|
|
"Process the X-related command line options in ARGS.
|
|
|
|
|
This is done before the user's startup file is loaded. They are copied to
|
1995-12-29 21:09:34 +00:00
|
|
|
|
`x-invocation-args', from which the X-related things are extracted, first
|
1991-07-11 22:55:55 +00:00
|
|
|
|
the switch (e.g., \"-fg\") in the following code, and possible values
|
1994-05-22 22:14:17 +00:00
|
|
|
|
\(e.g., \"black\") in the option handler code (e.g., x-handle-switch).
|
1995-12-29 21:09:34 +00:00
|
|
|
|
This function returns ARGS minus the arguments that have been processed."
|
|
|
|
|
;; We use ARGS to accumulate the args that we don't handle here, to return.
|
1991-05-17 00:15:22 +00:00
|
|
|
|
(setq x-invocation-args args
|
|
|
|
|
args nil)
|
|
|
|
|
(while x-invocation-args
|
|
|
|
|
(let* ((this-switch (car x-invocation-args))
|
1994-11-19 20:33:22 +00:00
|
|
|
|
(orig-this-switch this-switch)
|
1995-12-29 21:09:34 +00:00
|
|
|
|
completion argval aelt handler)
|
1991-05-17 00:15:22 +00:00
|
|
|
|
(setq x-invocation-args (cdr x-invocation-args))
|
1994-11-19 20:33:22 +00:00
|
|
|
|
;; Check for long options with attached arguments
|
|
|
|
|
;; and separate out the attached option argument into argval.
|
|
|
|
|
(if (string-match "^--[^=]*=" this-switch)
|
|
|
|
|
(setq argval (substring this-switch (match-end 0))
|
|
|
|
|
this-switch (substring this-switch 0 (1- (match-end 0)))))
|
1995-12-29 21:09:34 +00:00
|
|
|
|
;; Complete names of long options.
|
|
|
|
|
(if (string-match "^--" this-switch)
|
|
|
|
|
(progn
|
|
|
|
|
(setq completion (try-completion this-switch command-line-x-option-alist))
|
|
|
|
|
(if (eq completion t)
|
|
|
|
|
;; Exact match for long option.
|
|
|
|
|
nil
|
|
|
|
|
(if (stringp completion)
|
|
|
|
|
(let ((elt (assoc completion command-line-x-option-alist)))
|
|
|
|
|
;; Check for abbreviated long option.
|
|
|
|
|
(or elt
|
|
|
|
|
(error "Option `%s' is ambiguous" this-switch))
|
|
|
|
|
(setq this-switch completion))))))
|
|
|
|
|
(setq aelt (assoc this-switch command-line-x-option-alist))
|
|
|
|
|
(if aelt (setq handler (nth 2 aelt)))
|
|
|
|
|
(if handler
|
1994-11-19 20:33:22 +00:00
|
|
|
|
(if argval
|
|
|
|
|
(let ((x-invocation-args
|
|
|
|
|
(cons argval x-invocation-args)))
|
1995-12-29 21:09:34 +00:00
|
|
|
|
(funcall handler this-switch))
|
|
|
|
|
(funcall handler this-switch))
|
|
|
|
|
(setq args (cons orig-this-switch args)))))
|
|
|
|
|
(nreverse args))
|
1990-03-22 20:46:04 +00:00
|
|
|
|
|
|
|
|
|
;;
|
|
|
|
|
;; Standard X cursor shapes, courtesy of Mr. Fox, who wanted ALL of them.
|
|
|
|
|
;;
|
|
|
|
|
|
|
|
|
|
(defconst x-pointer-X-cursor 0)
|
|
|
|
|
(defconst x-pointer-arrow 2)
|
|
|
|
|
(defconst x-pointer-based-arrow-down 4)
|
|
|
|
|
(defconst x-pointer-based-arrow-up 6)
|
|
|
|
|
(defconst x-pointer-boat 8)
|
|
|
|
|
(defconst x-pointer-bogosity 10)
|
|
|
|
|
(defconst x-pointer-bottom-left-corner 12)
|
|
|
|
|
(defconst x-pointer-bottom-right-corner 14)
|
|
|
|
|
(defconst x-pointer-bottom-side 16)
|
|
|
|
|
(defconst x-pointer-bottom-tee 18)
|
|
|
|
|
(defconst x-pointer-box-spiral 20)
|
|
|
|
|
(defconst x-pointer-center-ptr 22)
|
|
|
|
|
(defconst x-pointer-circle 24)
|
|
|
|
|
(defconst x-pointer-clock 26)
|
|
|
|
|
(defconst x-pointer-coffee-mug 28)
|
|
|
|
|
(defconst x-pointer-cross 30)
|
|
|
|
|
(defconst x-pointer-cross-reverse 32)
|
|
|
|
|
(defconst x-pointer-crosshair 34)
|
|
|
|
|
(defconst x-pointer-diamond-cross 36)
|
|
|
|
|
(defconst x-pointer-dot 38)
|
|
|
|
|
(defconst x-pointer-dotbox 40)
|
|
|
|
|
(defconst x-pointer-double-arrow 42)
|
|
|
|
|
(defconst x-pointer-draft-large 44)
|
|
|
|
|
(defconst x-pointer-draft-small 46)
|
|
|
|
|
(defconst x-pointer-draped-box 48)
|
|
|
|
|
(defconst x-pointer-exchange 50)
|
|
|
|
|
(defconst x-pointer-fleur 52)
|
|
|
|
|
(defconst x-pointer-gobbler 54)
|
|
|
|
|
(defconst x-pointer-gumby 56)
|
|
|
|
|
(defconst x-pointer-hand1 58)
|
|
|
|
|
(defconst x-pointer-hand2 60)
|
|
|
|
|
(defconst x-pointer-heart 62)
|
|
|
|
|
(defconst x-pointer-icon 64)
|
|
|
|
|
(defconst x-pointer-iron-cross 66)
|
|
|
|
|
(defconst x-pointer-left-ptr 68)
|
|
|
|
|
(defconst x-pointer-left-side 70)
|
|
|
|
|
(defconst x-pointer-left-tee 72)
|
|
|
|
|
(defconst x-pointer-leftbutton 74)
|
|
|
|
|
(defconst x-pointer-ll-angle 76)
|
|
|
|
|
(defconst x-pointer-lr-angle 78)
|
|
|
|
|
(defconst x-pointer-man 80)
|
|
|
|
|
(defconst x-pointer-middlebutton 82)
|
|
|
|
|
(defconst x-pointer-mouse 84)
|
|
|
|
|
(defconst x-pointer-pencil 86)
|
|
|
|
|
(defconst x-pointer-pirate 88)
|
|
|
|
|
(defconst x-pointer-plus 90)
|
|
|
|
|
(defconst x-pointer-question-arrow 92)
|
|
|
|
|
(defconst x-pointer-right-ptr 94)
|
|
|
|
|
(defconst x-pointer-right-side 96)
|
|
|
|
|
(defconst x-pointer-right-tee 98)
|
|
|
|
|
(defconst x-pointer-rightbutton 100)
|
|
|
|
|
(defconst x-pointer-rtl-logo 102)
|
|
|
|
|
(defconst x-pointer-sailboat 104)
|
|
|
|
|
(defconst x-pointer-sb-down-arrow 106)
|
|
|
|
|
(defconst x-pointer-sb-h-double-arrow 108)
|
|
|
|
|
(defconst x-pointer-sb-left-arrow 110)
|
|
|
|
|
(defconst x-pointer-sb-right-arrow 112)
|
|
|
|
|
(defconst x-pointer-sb-up-arrow 114)
|
|
|
|
|
(defconst x-pointer-sb-v-double-arrow 116)
|
|
|
|
|
(defconst x-pointer-shuttle 118)
|
|
|
|
|
(defconst x-pointer-sizing 120)
|
|
|
|
|
(defconst x-pointer-spider 122)
|
|
|
|
|
(defconst x-pointer-spraycan 124)
|
|
|
|
|
(defconst x-pointer-star 126)
|
|
|
|
|
(defconst x-pointer-target 128)
|
|
|
|
|
(defconst x-pointer-tcross 130)
|
|
|
|
|
(defconst x-pointer-top-left-arrow 132)
|
|
|
|
|
(defconst x-pointer-top-left-corner 134)
|
|
|
|
|
(defconst x-pointer-top-right-corner 136)
|
|
|
|
|
(defconst x-pointer-top-side 138)
|
|
|
|
|
(defconst x-pointer-top-tee 140)
|
|
|
|
|
(defconst x-pointer-trek 142)
|
|
|
|
|
(defconst x-pointer-ul-angle 144)
|
|
|
|
|
(defconst x-pointer-umbrella 146)
|
|
|
|
|
(defconst x-pointer-ur-angle 148)
|
|
|
|
|
(defconst x-pointer-watch 150)
|
|
|
|
|
(defconst x-pointer-xterm 152)
|
|
|
|
|
|
|
|
|
|
;;
|
|
|
|
|
;; Available colors
|
|
|
|
|
;;
|
|
|
|
|
|
|
|
|
|
(defvar x-colors '("aquamarine"
|
|
|
|
|
"Aquamarine"
|
|
|
|
|
"medium aquamarine"
|
|
|
|
|
"MediumAquamarine"
|
|
|
|
|
"black"
|
|
|
|
|
"Black"
|
|
|
|
|
"blue"
|
|
|
|
|
"Blue"
|
|
|
|
|
"cadet blue"
|
|
|
|
|
"CadetBlue"
|
|
|
|
|
"cornflower blue"
|
|
|
|
|
"CornflowerBlue"
|
|
|
|
|
"dark slate blue"
|
|
|
|
|
"DarkSlateBlue"
|
|
|
|
|
"light blue"
|
|
|
|
|
"LightBlue"
|
|
|
|
|
"light steel blue"
|
|
|
|
|
"LightSteelBlue"
|
|
|
|
|
"medium blue"
|
|
|
|
|
"MediumBlue"
|
|
|
|
|
"medium slate blue"
|
|
|
|
|
"MediumSlateBlue"
|
|
|
|
|
"midnight blue"
|
|
|
|
|
"MidnightBlue"
|
|
|
|
|
"navy blue"
|
|
|
|
|
"NavyBlue"
|
|
|
|
|
"navy"
|
|
|
|
|
"Navy"
|
|
|
|
|
"sky blue"
|
|
|
|
|
"SkyBlue"
|
|
|
|
|
"slate blue"
|
|
|
|
|
"SlateBlue"
|
|
|
|
|
"steel blue"
|
|
|
|
|
"SteelBlue"
|
|
|
|
|
"coral"
|
|
|
|
|
"Coral"
|
|
|
|
|
"cyan"
|
|
|
|
|
"Cyan"
|
|
|
|
|
"firebrick"
|
|
|
|
|
"Firebrick"
|
|
|
|
|
"brown"
|
|
|
|
|
"Brown"
|
|
|
|
|
"gold"
|
|
|
|
|
"Gold"
|
|
|
|
|
"goldenrod"
|
|
|
|
|
"Goldenrod"
|
|
|
|
|
"green"
|
|
|
|
|
"Green"
|
|
|
|
|
"dark green"
|
|
|
|
|
"DarkGreen"
|
|
|
|
|
"dark olive green"
|
|
|
|
|
"DarkOliveGreen"
|
|
|
|
|
"forest green"
|
|
|
|
|
"ForestGreen"
|
|
|
|
|
"lime green"
|
|
|
|
|
"LimeGreen"
|
|
|
|
|
"medium sea green"
|
|
|
|
|
"MediumSeaGreen"
|
|
|
|
|
"medium spring green"
|
|
|
|
|
"MediumSpringGreen"
|
|
|
|
|
"pale green"
|
|
|
|
|
"PaleGreen"
|
|
|
|
|
"sea green"
|
|
|
|
|
"SeaGreen"
|
|
|
|
|
"spring green"
|
|
|
|
|
"SpringGreen"
|
|
|
|
|
"yellow green"
|
|
|
|
|
"YellowGreen"
|
|
|
|
|
"dark slate grey"
|
|
|
|
|
"DarkSlateGrey"
|
|
|
|
|
"dark slate gray"
|
|
|
|
|
"DarkSlateGray"
|
|
|
|
|
"dim grey"
|
|
|
|
|
"DimGrey"
|
|
|
|
|
"dim gray"
|
|
|
|
|
"DimGray"
|
|
|
|
|
"light grey"
|
|
|
|
|
"LightGrey"
|
|
|
|
|
"light gray"
|
|
|
|
|
"LightGray"
|
|
|
|
|
"gray"
|
|
|
|
|
"grey"
|
|
|
|
|
"Gray"
|
|
|
|
|
"Grey"
|
|
|
|
|
"khaki"
|
|
|
|
|
"Khaki"
|
|
|
|
|
"magenta"
|
|
|
|
|
"Magenta"
|
|
|
|
|
"maroon"
|
|
|
|
|
"Maroon"
|
|
|
|
|
"orange"
|
|
|
|
|
"Orange"
|
|
|
|
|
"orchid"
|
|
|
|
|
"Orchid"
|
|
|
|
|
"dark orchid"
|
|
|
|
|
"DarkOrchid"
|
|
|
|
|
"medium orchid"
|
|
|
|
|
"MediumOrchid"
|
|
|
|
|
"pink"
|
|
|
|
|
"Pink"
|
|
|
|
|
"plum"
|
|
|
|
|
"Plum"
|
|
|
|
|
"red"
|
|
|
|
|
"Red"
|
|
|
|
|
"indian red"
|
|
|
|
|
"IndianRed"
|
|
|
|
|
"medium violet red"
|
|
|
|
|
"MediumVioletRed"
|
|
|
|
|
"orange red"
|
|
|
|
|
"OrangeRed"
|
|
|
|
|
"violet red"
|
|
|
|
|
"VioletRed"
|
|
|
|
|
"salmon"
|
|
|
|
|
"Salmon"
|
|
|
|
|
"sienna"
|
|
|
|
|
"Sienna"
|
|
|
|
|
"tan"
|
|
|
|
|
"Tan"
|
|
|
|
|
"thistle"
|
|
|
|
|
"Thistle"
|
|
|
|
|
"turquoise"
|
|
|
|
|
"Turquoise"
|
|
|
|
|
"dark turquoise"
|
|
|
|
|
"DarkTurquoise"
|
|
|
|
|
"medium turquoise"
|
|
|
|
|
"MediumTurquoise"
|
|
|
|
|
"violet"
|
|
|
|
|
"Violet"
|
|
|
|
|
"blue violet"
|
|
|
|
|
"BlueViolet"
|
|
|
|
|
"wheat"
|
|
|
|
|
"Wheat"
|
|
|
|
|
"white"
|
|
|
|
|
"White"
|
|
|
|
|
"yellow"
|
|
|
|
|
"Yellow"
|
|
|
|
|
"green yellow"
|
|
|
|
|
"GreenYellow")
|
1995-06-30 05:12:56 +00:00
|
|
|
|
"The list of X colors from the `rgb.txt' file.")
|
1990-03-22 20:46:04 +00:00
|
|
|
|
|
1995-04-16 04:17:36 +00:00
|
|
|
|
(defun x-defined-colors (&optional frame)
|
|
|
|
|
"Return a list of colors supported for a particular frame.
|
|
|
|
|
The argument FRAME specifies which frame to try.
|
|
|
|
|
The value may be different for frames on different X displays."
|
|
|
|
|
(or frame (setq frame (selected-frame)))
|
1990-03-22 20:46:04 +00:00
|
|
|
|
(let ((all-colors x-colors)
|
|
|
|
|
(this-color nil)
|
|
|
|
|
(defined-colors nil))
|
|
|
|
|
(while all-colors
|
|
|
|
|
(setq this-color (car all-colors)
|
|
|
|
|
all-colors (cdr all-colors))
|
1995-04-16 04:17:36 +00:00
|
|
|
|
(and (face-color-supported-p frame this-color t)
|
1990-03-22 20:46:04 +00:00
|
|
|
|
(setq defined-colors (cons this-color defined-colors))))
|
|
|
|
|
defined-colors))
|
|
|
|
|
|
1991-08-16 04:13:50 +00:00
|
|
|
|
;;;; Function keys
|
|
|
|
|
|
1993-07-27 21:58:54 +00:00
|
|
|
|
(defun iconify-or-deiconify-frame ()
|
|
|
|
|
"Iconify the selected frame, or deiconify if it's currently an icon."
|
|
|
|
|
(interactive)
|
|
|
|
|
(if (eq (cdr (assq 'visibility (frame-parameters))) t)
|
|
|
|
|
(iconify-frame)
|
1994-03-02 05:29:01 +00:00
|
|
|
|
(make-frame-visible)))
|
1993-07-27 21:58:54 +00:00
|
|
|
|
|
|
|
|
|
(substitute-key-definition 'suspend-emacs 'iconify-or-deiconify-frame
|
|
|
|
|
global-map)
|
1991-07-15 22:33:41 +00:00
|
|
|
|
|
1993-03-11 18:50:04 +00:00
|
|
|
|
;; Map certain keypad keys into ASCII characters
|
|
|
|
|
;; that people usually expect.
|
|
|
|
|
(define-key function-key-map [backspace] [127])
|
|
|
|
|
(define-key function-key-map [delete] [127])
|
|
|
|
|
(define-key function-key-map [tab] [?\t])
|
|
|
|
|
(define-key function-key-map [linefeed] [?\n])
|
1995-08-29 15:31:46 +00:00
|
|
|
|
(define-key function-key-map [clear] [?\C-l])
|
|
|
|
|
(define-key function-key-map [return] [?\C-m])
|
1993-03-11 18:50:04 +00:00
|
|
|
|
(define-key function-key-map [escape] [?\e])
|
|
|
|
|
(define-key function-key-map [M-backspace] [?\M-\d])
|
|
|
|
|
(define-key function-key-map [M-delete] [?\M-\d])
|
|
|
|
|
(define-key function-key-map [M-tab] [?\M-\t])
|
|
|
|
|
(define-key function-key-map [M-linefeed] [?\M-\n])
|
1995-08-29 15:31:46 +00:00
|
|
|
|
(define-key function-key-map [M-clear] [?\M-\C-l])
|
|
|
|
|
(define-key function-key-map [M-return] [?\M-\C-m])
|
1993-03-11 18:50:04 +00:00
|
|
|
|
(define-key function-key-map [M-escape] [?\M-\e])
|
|
|
|
|
|
|
|
|
|
;; These tell read-char how to convert
|
|
|
|
|
;; these special chars to ASCII.
|
|
|
|
|
(put 'backspace 'ascii-character 127)
|
|
|
|
|
(put 'delete 'ascii-character 127)
|
|
|
|
|
(put 'tab 'ascii-character ?\t)
|
|
|
|
|
(put 'linefeed 'ascii-character ?\n)
|
|
|
|
|
(put 'clear 'ascii-character 12)
|
|
|
|
|
(put 'return 'ascii-character 13)
|
|
|
|
|
(put 'escape 'ascii-character ?\e)
|
1994-01-08 14:36:57 +00:00
|
|
|
|
|
1995-05-15 23:19:13 +00:00
|
|
|
|
(defun vendor-specific-keysyms (vendor)
|
|
|
|
|
"Return the appropriate value of system-key-alist for VENDOR.
|
|
|
|
|
VENDOR is a string containing the name of the X Server's vendor,
|
|
|
|
|
as returned by (x-server-vendor)."
|
|
|
|
|
(cond ((string-equal vendor "Apollo Computer Inc.")
|
|
|
|
|
'((65280 . linedel)
|
|
|
|
|
(65281 . chardel)
|
|
|
|
|
(65282 . copy)
|
|
|
|
|
(65283 . cut)
|
|
|
|
|
(65284 . paste)
|
|
|
|
|
(65285 . move)
|
|
|
|
|
(65286 . grow)
|
|
|
|
|
(65287 . cmd)
|
|
|
|
|
(65288 . shell)
|
|
|
|
|
(65289 . leftbar)
|
|
|
|
|
(65290 . rightbar)
|
|
|
|
|
(65291 . leftbox)
|
|
|
|
|
(65292 . rightbox)
|
|
|
|
|
(65293 . upbox)
|
|
|
|
|
(65294 . downbox)
|
|
|
|
|
(65295 . pop)
|
|
|
|
|
(65296 . read)
|
|
|
|
|
(65297 . edit)
|
|
|
|
|
(65298 . save)
|
|
|
|
|
(65299 . exit)
|
|
|
|
|
(65300 . repeat)))
|
1995-05-24 04:59:27 +00:00
|
|
|
|
((or (string-equal vendor "Hewlett-Packard Incorporated")
|
|
|
|
|
(string-equal vendor "Hewlett-Packard Company"))
|
1995-05-15 23:19:13 +00:00
|
|
|
|
'(( 168 . mute-acute)
|
|
|
|
|
( 169 . mute-grave)
|
|
|
|
|
( 170 . mute-asciicircum)
|
|
|
|
|
( 171 . mute-diaeresis)
|
|
|
|
|
( 172 . mute-asciitilde)
|
|
|
|
|
( 175 . lira)
|
|
|
|
|
( 190 . guilder)
|
|
|
|
|
( 252 . block)
|
|
|
|
|
( 256 . longminus)
|
|
|
|
|
(65388 . reset)
|
|
|
|
|
(65389 . system)
|
|
|
|
|
(65390 . user)
|
|
|
|
|
(65391 . clearline)
|
|
|
|
|
(65392 . insertline)
|
|
|
|
|
(65393 . deleteline)
|
|
|
|
|
(65394 . insertchar)
|
|
|
|
|
(65395 . deletechar)
|
|
|
|
|
(65396 . backtab)
|
|
|
|
|
(65397 . kp-backtab)))
|
1995-06-02 01:03:43 +00:00
|
|
|
|
((or (string-equal vendor "X11/NeWS - Sun Microsystems Inc.")
|
|
|
|
|
(string-equal vendor "X Consortium"))
|
1995-07-17 22:49:37 +00:00
|
|
|
|
'((392976 . f36)
|
|
|
|
|
(392977 . f37)
|
1995-05-15 23:19:13 +00:00
|
|
|
|
(393056 . req)
|
|
|
|
|
;; These are for Sun under X11R6
|
|
|
|
|
(393072 . props)
|
|
|
|
|
(393073 . front)
|
|
|
|
|
(393074 . copy)
|
|
|
|
|
(393075 . open)
|
|
|
|
|
(393076 . paste)
|
|
|
|
|
(393077 . cut)))
|
|
|
|
|
(t
|
|
|
|
|
;; This is used by DEC's X server.
|
|
|
|
|
'((65280 . remove)))))
|
|
|
|
|
|
1992-11-05 04:28:10 +00:00
|
|
|
|
|
|
|
|
|
;;;; Selections and cut buffers
|
1992-05-12 05:26:53 +00:00
|
|
|
|
|
1992-06-24 05:09:26 +00:00
|
|
|
|
;;; We keep track of the last text selected here, so we can check the
|
|
|
|
|
;;; current selection against it, and avoid passing back our own text
|
|
|
|
|
;;; from x-cut-buffer-or-selection-value.
|
|
|
|
|
(defvar x-last-selected-text nil)
|
|
|
|
|
|
1993-07-25 20:30:04 +00:00
|
|
|
|
;;; It is said that overlarge strings are slow to put into the cut buffer.
|
1993-07-27 08:38:00 +00:00
|
|
|
|
;;; Note this value is overridden below.
|
|
|
|
|
(defvar x-cut-buffer-max 20000
|
1993-07-25 20:30:04 +00:00
|
|
|
|
"Max number of characters to put in the cut buffer.")
|
|
|
|
|
|
1994-04-06 04:51:37 +00:00
|
|
|
|
(defvar x-select-enable-clipboard nil
|
|
|
|
|
"Non-nil means cutting and pasting uses the clipboard.
|
|
|
|
|
This is in addition to the primary selection.")
|
|
|
|
|
|
1993-07-25 20:30:04 +00:00
|
|
|
|
;;; Make TEXT, a string, the primary X selection.
|
1992-06-10 02:47:07 +00:00
|
|
|
|
;;; Also, set the value of X cut buffer 0, for backward compatibility
|
1993-01-26 01:26:58 +00:00
|
|
|
|
;;; with older X applications.
|
1993-07-25 20:30:04 +00:00
|
|
|
|
;;; gildea@lcs.mit.edu says it's not desirable to put kills
|
|
|
|
|
;;; in the clipboard.
|
1993-05-24 21:19:42 +00:00
|
|
|
|
(defun x-select-text (text &optional push)
|
1993-07-23 01:43:39 +00:00
|
|
|
|
;; Don't send the cut buffer too much text.
|
|
|
|
|
;; It becomes slow, and if really big it causes errors.
|
|
|
|
|
(if (< (length text) x-cut-buffer-max)
|
1993-07-25 20:30:04 +00:00
|
|
|
|
(x-set-cut-buffer text push)
|
1993-07-23 17:24:45 +00:00
|
|
|
|
(x-set-cut-buffer "" push))
|
1993-03-25 04:37:38 +00:00
|
|
|
|
(x-set-selection 'PRIMARY text)
|
1994-04-06 04:51:37 +00:00
|
|
|
|
(if x-select-enable-clipboard
|
|
|
|
|
(x-set-selection 'CLIPBOARD text))
|
1992-06-24 05:09:26 +00:00
|
|
|
|
(setq x-last-selected-text text))
|
1992-06-10 02:47:07 +00:00
|
|
|
|
|
1994-03-18 03:38:25 +00:00
|
|
|
|
;;; Return the value of the current X selection.
|
|
|
|
|
;;; Consult the selection, then the cut buffer. Treat empty strings
|
|
|
|
|
;;; as if they were unset.
|
1992-06-10 02:47:07 +00:00
|
|
|
|
(defun x-cut-buffer-or-selection-value ()
|
1992-09-29 17:43:45 +00:00
|
|
|
|
(let (text)
|
|
|
|
|
|
1994-03-18 03:38:25 +00:00
|
|
|
|
;; Don't die if x-get-selection signals an error.
|
|
|
|
|
(condition-case c
|
|
|
|
|
(setq text (x-get-selection 'PRIMARY))
|
1996-01-09 23:20:39 +00:00
|
|
|
|
(error nil))
|
1992-09-29 17:43:45 +00:00
|
|
|
|
(if (string= text "") (setq text nil))
|
1994-04-06 04:51:37 +00:00
|
|
|
|
|
|
|
|
|
(if x-select-enable-clipboard
|
|
|
|
|
(condition-case c
|
|
|
|
|
(setq text (x-get-selection 'CLIPBOARD))
|
1996-01-09 23:20:39 +00:00
|
|
|
|
(error nil)))
|
1994-04-06 04:51:37 +00:00
|
|
|
|
(if (string= text "") (setq text nil))
|
1993-07-27 08:38:00 +00:00
|
|
|
|
(or text (setq text (x-get-cut-buffer 0)))
|
1993-07-25 20:30:04 +00:00
|
|
|
|
(if (string= text "") (setq text nil))
|
1992-09-29 17:43:45 +00:00
|
|
|
|
|
|
|
|
|
(cond
|
|
|
|
|
((not text) nil)
|
|
|
|
|
((eq text x-last-selected-text) nil)
|
|
|
|
|
((string= text x-last-selected-text)
|
|
|
|
|
;; Record the newer string, so subsequent calls can use the `eq' test.
|
|
|
|
|
(setq x-last-selected-text text)
|
|
|
|
|
nil)
|
|
|
|
|
(t
|
|
|
|
|
(setq x-last-selected-text text)))))
|
1992-06-10 02:47:07 +00:00
|
|
|
|
|
1992-11-05 04:28:10 +00:00
|
|
|
|
|
|
|
|
|
;;; Do the actual X Windows setup here; the above code just defines
|
|
|
|
|
;;; functions and variables that we use now.
|
|
|
|
|
|
|
|
|
|
(setq command-line-args (x-handle-args command-line-args))
|
1993-07-18 06:21:42 +00:00
|
|
|
|
|
|
|
|
|
;;; Make sure we have a valid resource name.
|
|
|
|
|
(or (stringp x-resource-name)
|
|
|
|
|
(let (i)
|
|
|
|
|
(setq x-resource-name (invocation-name))
|
|
|
|
|
|
|
|
|
|
;; Change any . or * characters in x-resource-name to hyphens,
|
|
|
|
|
;; so as not to choke when we use it in X resource queries.
|
|
|
|
|
(while (setq i (string-match "[.*]" x-resource-name))
|
|
|
|
|
(aset x-resource-name i ?-))))
|
|
|
|
|
|
1994-10-24 23:30:14 +00:00
|
|
|
|
;; For the benefit of older Emacses (19.27 and earlier) that are sharing
|
|
|
|
|
;; the same lisp directory, don't pass the third argument unless we seem
|
|
|
|
|
;; to have the multi-display support.
|
|
|
|
|
(if (fboundp 'x-close-connection)
|
|
|
|
|
(x-open-connection (or x-display-name
|
|
|
|
|
(setq x-display-name (getenv "DISPLAY")))
|
|
|
|
|
x-command-line-resources
|
|
|
|
|
;; Exit Emacs with fatal error if this fails.
|
|
|
|
|
t)
|
|
|
|
|
(x-open-connection (or x-display-name
|
|
|
|
|
(setq x-display-name (getenv "DISPLAY")))
|
|
|
|
|
x-command-line-resources))
|
1992-11-05 04:28:10 +00:00
|
|
|
|
|
1993-05-09 23:54:12 +00:00
|
|
|
|
(setq frame-creation-function 'x-create-frame-with-faces)
|
1993-03-11 18:50:04 +00:00
|
|
|
|
|
1993-07-27 08:38:00 +00:00
|
|
|
|
(setq x-cut-buffer-max (min (- (/ (x-server-max-request-size) 2) 100)
|
|
|
|
|
x-cut-buffer-max))
|
|
|
|
|
|
1994-04-10 08:56:50 +00:00
|
|
|
|
;; Sun expects the menu bar cut and paste commands to use the clipboard.
|
1994-11-23 04:46:14 +00:00
|
|
|
|
;; This has ,? to match both on Sunos and on Solaris.
|
1995-11-02 04:37:30 +00:00
|
|
|
|
(if (string-match "Sun Microsystems,? Inc\\."
|
1994-04-10 08:56:50 +00:00
|
|
|
|
(x-server-vendor))
|
|
|
|
|
(menu-bar-enable-clipboard))
|
|
|
|
|
|
1993-05-27 05:38:12 +00:00
|
|
|
|
;; Apply a geometry resource to the initial frame. Put it at the end
|
|
|
|
|
;; of the alist, so that anything specified on the command line takes
|
|
|
|
|
;; precedence.
|
1995-01-11 04:44:10 +00:00
|
|
|
|
(let* ((res-geometry (x-get-resource "geometry" "Geometry"))
|
|
|
|
|
parsed)
|
1993-05-27 05:38:12 +00:00
|
|
|
|
(if res-geometry
|
1995-01-11 04:44:10 +00:00
|
|
|
|
(progn
|
|
|
|
|
(setq parsed (x-parse-geometry res-geometry))
|
1995-05-15 23:19:13 +00:00
|
|
|
|
;; If the resource specifies a position,
|
|
|
|
|
;; call the position and size "user-specified".
|
|
|
|
|
(if (or (assq 'top parsed) (assq 'left parsed))
|
|
|
|
|
(setq parsed (cons '(user-position . t)
|
|
|
|
|
(cons '(user-size . t) parsed))))
|
1995-01-11 04:44:10 +00:00
|
|
|
|
;; All geometry parms apply to the initial frame.
|
|
|
|
|
(setq initial-frame-alist (append initial-frame-alist parsed))
|
|
|
|
|
;; The size parms apply to all frames.
|
|
|
|
|
(if (assq 'height parsed)
|
|
|
|
|
(setq default-frame-alist
|
|
|
|
|
(cons (cons 'height (cdr (assq 'height parsed)))
|
|
|
|
|
default-frame-alist)))
|
|
|
|
|
(if (assq 'width parsed)
|
|
|
|
|
(setq default-frame-alist
|
|
|
|
|
(cons (cons 'width (cdr (assq 'width parsed)))
|
|
|
|
|
default-frame-alist))))))
|
1993-05-27 05:38:12 +00:00
|
|
|
|
|
1993-07-03 10:17:56 +00:00
|
|
|
|
;; Check the reverseVideo resource.
|
1993-07-18 06:21:42 +00:00
|
|
|
|
(let ((case-fold-search t))
|
|
|
|
|
(let ((rv (x-get-resource "reverseVideo" "ReverseVideo")))
|
|
|
|
|
(if (and rv
|
|
|
|
|
(string-match "^\\(true\\|yes\\|on\\)$" rv))
|
|
|
|
|
(setq default-frame-alist
|
|
|
|
|
(cons '(reverse . t) default-frame-alist)))))
|
1993-07-03 10:17:56 +00:00
|
|
|
|
|
1993-06-05 08:39:42 +00:00
|
|
|
|
;; Set x-selection-timeout, measured in milliseconds.
|
|
|
|
|
(let ((res-selection-timeout
|
|
|
|
|
(x-get-resource "selectionTimeout" "SelectionTimeout")))
|
1993-07-25 22:32:07 +00:00
|
|
|
|
(setq x-selection-timeout 20000)
|
1993-06-05 08:39:42 +00:00
|
|
|
|
(if res-selection-timeout
|
|
|
|
|
(setq x-selection-timeout (string-to-number res-selection-timeout))))
|
|
|
|
|
|
1993-03-11 18:50:04 +00:00
|
|
|
|
(defun x-win-suspend-error ()
|
|
|
|
|
(error "Suspending an emacs running under X makes no sense"))
|
1993-03-25 04:37:38 +00:00
|
|
|
|
(add-hook 'suspend-hook 'x-win-suspend-error)
|
|
|
|
|
|
1992-06-10 02:47:07 +00:00
|
|
|
|
;;; Arrange for the kill and yank functions to set and check the clipboard.
|
|
|
|
|
(setq interprogram-cut-function 'x-select-text)
|
|
|
|
|
(setq interprogram-paste-function 'x-cut-buffer-or-selection-value)
|
1991-05-17 00:15:22 +00:00
|
|
|
|
|
1991-08-12 12:12:28 +00:00
|
|
|
|
;;; Turn off window-splitting optimization; X is usually fast enough
|
|
|
|
|
;;; that this is only annoying.
|
|
|
|
|
(setq split-window-keep-point t)
|
1993-03-12 19:53:22 +00:00
|
|
|
|
|
1995-04-08 02:51:37 +00:00
|
|
|
|
;; Don't show the frame name; that's redundant with X.
|
1995-04-09 03:51:32 +00:00
|
|
|
|
(setq-default mode-line-buffer-identification '("Emacs: %12b"))
|
1995-04-08 02:51:37 +00:00
|
|
|
|
|
1993-03-12 19:53:22 +00:00
|
|
|
|
;;; x-win.el ends here
|