(U-0002531A): Use `->subsumptive'.
[chise/xemacs-chise.git.1] / lisp / msw-glyphs.el
1 ;;; msw-glyphs.el --- Support for glyphs in ms windows
2
3 ;; Copyright (C) 1994, 1997 Free Software Foundation, Inc.
4 ;; Copyright (C) 2002 Ben Wing.
5
6 ;; Author: Kirill M. Katsnelson <kkm@kis.ru>
7 ;; Maintainer: XEmacs Development Team
8 ;; Keywords: extensions, internal, dumped
9
10 ;; This file is part of XEmacs.
11
12 ;; XEmacs is free software; you can redistribute it and/or modify it
13 ;; under the terms of the GNU General Public License as published by
14 ;; the Free Software Foundation; either version 2, or (at your option)
15 ;; any later version.
16
17 ;; XEmacs is distributed in the hope that it will be useful, but
18 ;; WITHOUT ANY WARRANTY; without even the implied warranty of
19 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
20 ;; General Public License for more details.
21
22 ;; You should have received a copy of the GNU General Public License
23 ;; along with XEmacs; see the file COPYING.  If not, write to the 
24 ;; Free Software Foundation, 59 Temple Place - Suite 330,
25 ;; Boston, MA 02111-1307, USA.
26
27 ;;; Synched up with: Not in FSF.
28
29 ;;; Commentary:
30
31 ;; Initialization code for MS Windows glyphs.
32
33 ;; This file is dumped with XEmacs (when MS Windows support is
34 ;; compiled in). Make sure this is the first of msw-*.el files
35 ;; dumped.
36
37 ;;; Code:
38
39 (defun msgdi-device-p (&optional device)
40   "Return non-nil if DEVICE is a GDI device, that is 'mswindows or 'msprinter.
41 MS GDI devices are mutuially WYSIWIG-compatible, so that many common glyph,
42 color and font properties apply to them equally.
43
44 This function is also a predicate for 'msgdi device tag, matching this
45 device class."
46   (memq (device-type device) '(mswindows msprinter)))
47
48 (progn
49
50   (define-specifier-tag 'msgdi (function msgdi-device-p))
51
52   (set-console-type-image-conversion-list
53    'mswindows
54    `(("\\.bmp\\'" [bmp :file nil] 2)
55      ("\\`BM" [bmp :data nil] 2)
56      ,@(if (featurep 'xpm) '(("\\.xpm\\'" [xpm :file nil] 2)))
57      ("\\.xbm\\'" [xbm :file nil] 2)
58      ,@(if (featurep 'xpm) '(("\\`/\\* XPM \\*/" [xpm :data nil] 2)))
59      ,@(if (featurep 'gif) '(("\\.gif\\'" [gif :file nil] 2)
60                              ("\\`GIF8[79]" [gif :data nil] 2)))
61      ,@(if (featurep 'jpeg) '(("\\.jpe?g\\'" [jpeg :file nil] 2)))
62      ;; all of the JFIF-format JPEG's that I've seen begin with
63      ;; the following.  I have no idea if this is standard.
64      ,@(if (featurep 'jpeg) '(("\\`\377\330\377\340\000\020JFIF"
65                                [jpeg :data nil] 2)))
66      ,@(if (featurep 'png) '(("\\.png\\'" [png :file nil] 2)))
67      ,@(if (featurep 'png) '(("\\`\211PNG" [png :data nil] 2)))
68      ,@(if (featurep 'tiff) '(("\\.tif?f\\'" [tiff :file nil] 2)))
69      ("\\`X-Face:" [string :data "[xface]"])
70      ("\\`/\\* XPM \\*/" [string :data "[xpm]"])
71      ("" [string :data nil] 2)
72      ;; this last one is here for pointers and icons and such --
73      ;; strings are not allowed so they will be ignored.
74      ("" [nothing])))
75
76   (set-console-type-image-conversion-list
77    'msprinter (console-type-image-conversion-list 'mswindows))
78
79   (set-face-font 'border-glyph "WingDings:Regular:11::Symbol"
80                  'global 'msgdi)
81   (set-glyph-image continuation-glyph "\xC3" 'global 'msgdi)
82   (set-glyph-image truncation-glyph "\xF0" 'global 'msgdi)
83   (set-glyph-image hscroll-glyph "\xEF" 'global 'msgdi)
84   (set-glyph-contrib-p continuation-glyph nil)
85   (set-glyph-contrib-p truncation-glyph nil)
86   (set-glyph-contrib-p hscroll-glyph nil)
87
88   (set-glyph-image octal-escape-glyph "\\")
89   (set-glyph-image control-arrow-glyph "^")
90   (set-glyph-image invisible-text-glyph " ...")
91
92   (cond ((featurep 'xpm)
93          (set-glyph-image frame-icon-glyph
94                           (concat "../etc/" "xemacs-icon3.xpm")
95                           'global 'mswindows)
96          (set-glyph-image xemacs-logo
97                           (concat "../etc/"
98                                   (if emacs-beta-version
99                                       "xemacs-beta.xpm"
100                                     "xemacs.xpm"))
101                           'global 'msgdi))
102         (t
103          (set-glyph-image xemacs-logo
104                           "XEmacs <insert spiffy graphic logo here>"
105                           'global 'msgdi)))
106 )
107
108 ;;; msw-glyphs.el ends here