annotate lwlib/xrdb-cpp.c @ 26007:774b2504710b

(insert-image): Copy the image spec and add an intangible property.
author Dave Love <fx@gnu.org>
date Wed, 13 Oct 1999 17:38:18 +0000
parents 648d04be6a9c
children e0d966fb548f
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
25842
Dave Love <fx@gnu.org>
parents:
diff changeset
1 /* A general interface to the widgets of different toolkits.
Dave Love <fx@gnu.org>
parents:
diff changeset
2 Copyright (C) 1992, 1993 Lucid, Inc.
Dave Love <fx@gnu.org>
parents:
diff changeset
3
Dave Love <fx@gnu.org>
parents:
diff changeset
4 This file is part of the Lucid Widget Library.
Dave Love <fx@gnu.org>
parents:
diff changeset
5
Dave Love <fx@gnu.org>
parents:
diff changeset
6 The Lucid Widget Library is free software; you can redistribute it and/or
Dave Love <fx@gnu.org>
parents:
diff changeset
7 modify it under the terms of the GNU General Public License as published by
Dave Love <fx@gnu.org>
parents:
diff changeset
8 the Free Software Foundation; either version 2, or (at your option)
Dave Love <fx@gnu.org>
parents:
diff changeset
9 any later version.
Dave Love <fx@gnu.org>
parents:
diff changeset
10
Dave Love <fx@gnu.org>
parents:
diff changeset
11 The Lucid Widget Library is distributed in the hope that it will be useful,
Dave Love <fx@gnu.org>
parents:
diff changeset
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
Dave Love <fx@gnu.org>
parents:
diff changeset
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
Dave Love <fx@gnu.org>
parents:
diff changeset
14 GNU General Public License for more details.
Dave Love <fx@gnu.org>
parents:
diff changeset
15
Dave Love <fx@gnu.org>
parents:
diff changeset
16 You should have received a copy of the GNU General Public License
Dave Love <fx@gnu.org>
parents:
diff changeset
17 along with GNU Emacs; see the file COPYING. If not, write to
Dave Love <fx@gnu.org>
parents:
diff changeset
18 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Dave Love <fx@gnu.org>
parents:
diff changeset
19 Boston, MA 02111-1307, USA. */
Dave Love <fx@gnu.org>
parents:
diff changeset
20
Dave Love <fx@gnu.org>
parents:
diff changeset
21 /* This code reads a resource database file and filters it through cpp
Dave Love <fx@gnu.org>
parents:
diff changeset
22 with the same set of preprocessor defines that `xrdb' uses.
Dave Love <fx@gnu.org>
parents:
diff changeset
23 Call lwlib_xrdb_initialize(dpy) once, and then call the function
Dave Love <fx@gnu.org>
parents:
diff changeset
24 lwlib_GetFileDatabase() instead of XrmGetFileDatabase(),
Dave Love <fx@gnu.org>
parents:
diff changeset
25 and lwlib_CombineFileDatabase() instead of XrmCombineFileDatabase().
Dave Love <fx@gnu.org>
parents:
diff changeset
26 */
Dave Love <fx@gnu.org>
parents:
diff changeset
27
Dave Love <fx@gnu.org>
parents:
diff changeset
28 #ifndef __STDC_EXTENDED__
Dave Love <fx@gnu.org>
parents:
diff changeset
29 #define __STDC_EXTENDED__
Dave Love <fx@gnu.org>
parents:
diff changeset
30 #endif
Dave Love <fx@gnu.org>
parents:
diff changeset
31
Dave Love <fx@gnu.org>
parents:
diff changeset
32 #include <stdio.h>
Dave Love <fx@gnu.org>
parents:
diff changeset
33 #include <ctype.h>
Dave Love <fx@gnu.org>
parents:
diff changeset
34 #include <X11/Xlib.h>
Dave Love <fx@gnu.org>
parents:
diff changeset
35 #include <X11/Xos.h>
Dave Love <fx@gnu.org>
parents:
diff changeset
36 #include <X11/Intrinsic.h>
Dave Love <fx@gnu.org>
parents:
diff changeset
37 #include <X11/Xmu/SysUtil.h>
Dave Love <fx@gnu.org>
parents:
diff changeset
38 #include <sys/stat.h>
Dave Love <fx@gnu.org>
parents:
diff changeset
39
Dave Love <fx@gnu.org>
parents:
diff changeset
40 extern char *index ();
Dave Love <fx@gnu.org>
parents:
diff changeset
41
Dave Love <fx@gnu.org>
parents:
diff changeset
42 static int
Dave Love <fx@gnu.org>
parents:
diff changeset
43 file_p (path)
Dave Love <fx@gnu.org>
parents:
diff changeset
44 char *path;
Dave Love <fx@gnu.org>
parents:
diff changeset
45 {
Dave Love <fx@gnu.org>
parents:
diff changeset
46 struct stat status;
Dave Love <fx@gnu.org>
parents:
diff changeset
47
Dave Love <fx@gnu.org>
parents:
diff changeset
48 return (access (path, R_OK) == 0 /* exists and is readable */
Dave Love <fx@gnu.org>
parents:
diff changeset
49 && stat (path, &status) == 0 /* get the status */
Dave Love <fx@gnu.org>
parents:
diff changeset
50 && (status.st_mode & S_IFDIR) == 0); /* not a directory */
Dave Love <fx@gnu.org>
parents:
diff changeset
51 }
Dave Love <fx@gnu.org>
parents:
diff changeset
52
Dave Love <fx@gnu.org>
parents:
diff changeset
53 #ifndef CPP_PROGRAM
Dave Love <fx@gnu.org>
parents:
diff changeset
54 #define CPP_PROGRAM "/lib/cpp"
Dave Love <fx@gnu.org>
parents:
diff changeset
55 #endif
Dave Love <fx@gnu.org>
parents:
diff changeset
56
Dave Love <fx@gnu.org>
parents:
diff changeset
57 static char cpp_string [BUFSIZ];
Dave Love <fx@gnu.org>
parents:
diff changeset
58 static char *cpp_file = 0;
Dave Love <fx@gnu.org>
parents:
diff changeset
59
Dave Love <fx@gnu.org>
parents:
diff changeset
60 #define Resolution(pixels, mm) ((((pixels) * 100000 / (mm)) + 50) / 100)
Dave Love <fx@gnu.org>
parents:
diff changeset
61
Dave Love <fx@gnu.org>
parents:
diff changeset
62 void
Dave Love <fx@gnu.org>
parents:
diff changeset
63 lwlib_xrdb_initialize (display)
Dave Love <fx@gnu.org>
parents:
diff changeset
64 Display *display;
Dave Love <fx@gnu.org>
parents:
diff changeset
65 {
Dave Love <fx@gnu.org>
parents:
diff changeset
66 Screen *screen;
Dave Love <fx@gnu.org>
parents:
diff changeset
67 Visual *visual;
Dave Love <fx@gnu.org>
parents:
diff changeset
68 char server [255];
Dave Love <fx@gnu.org>
parents:
diff changeset
69 char *colon, *s;
Dave Love <fx@gnu.org>
parents:
diff changeset
70
Dave Love <fx@gnu.org>
parents:
diff changeset
71 #define Push(str) \
Dave Love <fx@gnu.org>
parents:
diff changeset
72 (strncpy (s, str, sizeof(str)), s += (sizeof(str)-1))
Dave Love <fx@gnu.org>
parents:
diff changeset
73
Dave Love <fx@gnu.org>
parents:
diff changeset
74 #define Print(str, thing) \
Dave Love <fx@gnu.org>
parents:
diff changeset
75 (sprintf (s, str, thing), s = index (s, 0))
Dave Love <fx@gnu.org>
parents:
diff changeset
76
Dave Love <fx@gnu.org>
parents:
diff changeset
77 s = cpp_string;
Dave Love <fx@gnu.org>
parents:
diff changeset
78 Push (CPP_PROGRAM);
Dave Love <fx@gnu.org>
parents:
diff changeset
79
Dave Love <fx@gnu.org>
parents:
diff changeset
80 Push (" -DCLIENTHOST=");
Dave Love <fx@gnu.org>
parents:
diff changeset
81 XmuGetHostname (s, sizeof (cpp_string) - (s - cpp_string));
Dave Love <fx@gnu.org>
parents:
diff changeset
82 s = index (s, 0);
Dave Love <fx@gnu.org>
parents:
diff changeset
83 Push (" -DSERVERHOST=");
Dave Love <fx@gnu.org>
parents:
diff changeset
84 strcpy (s, XDisplayName (DisplayString (display)));
Dave Love <fx@gnu.org>
parents:
diff changeset
85 colon = index (s, ':');
Dave Love <fx@gnu.org>
parents:
diff changeset
86 if (colon == s)
Dave Love <fx@gnu.org>
parents:
diff changeset
87 {
Dave Love <fx@gnu.org>
parents:
diff changeset
88 XmuGetHostname (s, sizeof (cpp_string) - (s - cpp_string));
Dave Love <fx@gnu.org>
parents:
diff changeset
89 s = index (s, 0);
Dave Love <fx@gnu.org>
parents:
diff changeset
90 }
Dave Love <fx@gnu.org>
parents:
diff changeset
91 else if (colon)
Dave Love <fx@gnu.org>
parents:
diff changeset
92 s = colon;
Dave Love <fx@gnu.org>
parents:
diff changeset
93 else
Dave Love <fx@gnu.org>
parents:
diff changeset
94 s = index (s, 0);
Dave Love <fx@gnu.org>
parents:
diff changeset
95
Dave Love <fx@gnu.org>
parents:
diff changeset
96 Print (" -DVERSION=%d", ProtocolVersion(display));
Dave Love <fx@gnu.org>
parents:
diff changeset
97 Print (" -DREVISION=%d", ProtocolRevision(display));
Dave Love <fx@gnu.org>
parents:
diff changeset
98 Print (" -DVENDOR=\"%s\"", ServerVendor(display));
Dave Love <fx@gnu.org>
parents:
diff changeset
99 Print (" -DRELEASE=%d", VendorRelease(display));
Dave Love <fx@gnu.org>
parents:
diff changeset
100 screen = DefaultScreenOfDisplay(display);
Dave Love <fx@gnu.org>
parents:
diff changeset
101 visual = DefaultVisualOfScreen(screen);
Dave Love <fx@gnu.org>
parents:
diff changeset
102 Print (" -DWIDTH=%d", screen->width);
Dave Love <fx@gnu.org>
parents:
diff changeset
103 Print (" -DHEIGHT=%d", screen->height);
Dave Love <fx@gnu.org>
parents:
diff changeset
104 Print (" -DX_RESOLUTION=%d", Resolution(screen->width,screen->mwidth));
Dave Love <fx@gnu.org>
parents:
diff changeset
105 Print (" -DY_RESOLUTION=%d", Resolution(screen->height,screen->mheight));
Dave Love <fx@gnu.org>
parents:
diff changeset
106 Print (" -DPLANES=%d", DisplayPlanes(display, DefaultScreen(display)));
Dave Love <fx@gnu.org>
parents:
diff changeset
107 Print (" -DBITS_PER_RGB=%d", visual->bits_per_rgb);
Dave Love <fx@gnu.org>
parents:
diff changeset
108 switch(visual->class) {
Dave Love <fx@gnu.org>
parents:
diff changeset
109 case StaticGray: Print (" -DCLASS=%s", "StaticGray"); break;
Dave Love <fx@gnu.org>
parents:
diff changeset
110 case GrayScale: Print (" -DCLASS=%s", "GrayScale"); break;
Dave Love <fx@gnu.org>
parents:
diff changeset
111 case StaticColor: Print (" -DCLASS=%s", "StaticColor");
Dave Love <fx@gnu.org>
parents:
diff changeset
112 Print (" -DCOLOR", 0); break;
Dave Love <fx@gnu.org>
parents:
diff changeset
113 case PseudoColor: Print (" -DCLASS=%s", "PseudoColor");
Dave Love <fx@gnu.org>
parents:
diff changeset
114 Print (" -DCOLOR", 0); break;
Dave Love <fx@gnu.org>
parents:
diff changeset
115 case TrueColor: Print (" -DCLASS=%s", "TrueColor");
Dave Love <fx@gnu.org>
parents:
diff changeset
116 Print (" -DCOLOR", 0); break;
Dave Love <fx@gnu.org>
parents:
diff changeset
117 case DirectColor: Print (" -DCLASS=%s", "DirectColor");
Dave Love <fx@gnu.org>
parents:
diff changeset
118 Print (" -DCOLOR", 0); break;
Dave Love <fx@gnu.org>
parents:
diff changeset
119 default:
Dave Love <fx@gnu.org>
parents:
diff changeset
120 fprintf (stderr, "unexpected visual class=%d\n", visual->class);
Dave Love <fx@gnu.org>
parents:
diff changeset
121 exit (-1);
Dave Love <fx@gnu.org>
parents:
diff changeset
122 }
Dave Love <fx@gnu.org>
parents:
diff changeset
123 *s++ = ' ';
Dave Love <fx@gnu.org>
parents:
diff changeset
124 *s = 0;
Dave Love <fx@gnu.org>
parents:
diff changeset
125 cpp_file = s;
Dave Love <fx@gnu.org>
parents:
diff changeset
126 }
Dave Love <fx@gnu.org>
parents:
diff changeset
127
Dave Love <fx@gnu.org>
parents:
diff changeset
128 XrmDatabase
Dave Love <fx@gnu.org>
parents:
diff changeset
129 lwlib_GetFileDatabase (path)
Dave Love <fx@gnu.org>
parents:
diff changeset
130 char *path;
Dave Love <fx@gnu.org>
parents:
diff changeset
131 {
Dave Love <fx@gnu.org>
parents:
diff changeset
132 XrmDatabase db = 0;
Dave Love <fx@gnu.org>
parents:
diff changeset
133 char line [BUFSIZ];
Dave Love <fx@gnu.org>
parents:
diff changeset
134 char *s;
Dave Love <fx@gnu.org>
parents:
diff changeset
135 FILE *file;
Dave Love <fx@gnu.org>
parents:
diff changeset
136
Dave Love <fx@gnu.org>
parents:
diff changeset
137 if (! file_p (path))
Dave Love <fx@gnu.org>
parents:
diff changeset
138 return 0;
Dave Love <fx@gnu.org>
parents:
diff changeset
139
Dave Love <fx@gnu.org>
parents:
diff changeset
140 strcpy (cpp_file, path);
Dave Love <fx@gnu.org>
parents:
diff changeset
141 if (! (file = popen (cpp_string, "r")))
Dave Love <fx@gnu.org>
parents:
diff changeset
142 {
Dave Love <fx@gnu.org>
parents:
diff changeset
143 fprintf (stderr,
Dave Love <fx@gnu.org>
parents:
diff changeset
144 "couldn't execute %s; resource file %s file not munged.\n",
Dave Love <fx@gnu.org>
parents:
diff changeset
145 CPP_PROGRAM, path);
Dave Love <fx@gnu.org>
parents:
diff changeset
146 return XrmGetFileDatabase (path);
Dave Love <fx@gnu.org>
parents:
diff changeset
147 }
Dave Love <fx@gnu.org>
parents:
diff changeset
148 while (s = fgets (line, sizeof (line), file))
Dave Love <fx@gnu.org>
parents:
diff changeset
149 {
Dave Love <fx@gnu.org>
parents:
diff changeset
150 char ch, *tail;
Dave Love <fx@gnu.org>
parents:
diff changeset
151 if (*s == '!') continue;
Dave Love <fx@gnu.org>
parents:
diff changeset
152 for (; ((ch = *s) != '\n') && isspace(ch); s++);
Dave Love <fx@gnu.org>
parents:
diff changeset
153 if ((ch == '\0') || (ch == '\n') || (ch == '#')) continue;
Dave Love <fx@gnu.org>
parents:
diff changeset
154 tail = s + strlen (s);
Dave Love <fx@gnu.org>
parents:
diff changeset
155 if (tail - s < 3) continue; /* this would be syntactically incorrect */
Dave Love <fx@gnu.org>
parents:
diff changeset
156 while (*(tail-1) == '\n' && /* handle \ at end of line */
Dave Love <fx@gnu.org>
parents:
diff changeset
157 *(tail-2) == '\\')
Dave Love <fx@gnu.org>
parents:
diff changeset
158 {
Dave Love <fx@gnu.org>
parents:
diff changeset
159 if (! fgets (tail, sizeof (line) - (tail - line), file))
Dave Love <fx@gnu.org>
parents:
diff changeset
160 continue;
Dave Love <fx@gnu.org>
parents:
diff changeset
161 tail += strlen (tail);
Dave Love <fx@gnu.org>
parents:
diff changeset
162 }
Dave Love <fx@gnu.org>
parents:
diff changeset
163 XrmPutLineResource (&db, s);
Dave Love <fx@gnu.org>
parents:
diff changeset
164 }
Dave Love <fx@gnu.org>
parents:
diff changeset
165 pclose (file);
Dave Love <fx@gnu.org>
parents:
diff changeset
166 return db;
Dave Love <fx@gnu.org>
parents:
diff changeset
167 }
Dave Love <fx@gnu.org>
parents:
diff changeset
168
Dave Love <fx@gnu.org>
parents:
diff changeset
169 #ifdef THIS_IS_X11R5
Dave Love <fx@gnu.org>
parents:
diff changeset
170
Dave Love <fx@gnu.org>
parents:
diff changeset
171 int
Dave Love <fx@gnu.org>
parents:
diff changeset
172 lwlib_CombineFileDatabase (path, target_db, override)
Dave Love <fx@gnu.org>
parents:
diff changeset
173 char *path;
Dave Love <fx@gnu.org>
parents:
diff changeset
174 XrmDatabase *target_db;
Dave Love <fx@gnu.org>
parents:
diff changeset
175 Bool override;
Dave Love <fx@gnu.org>
parents:
diff changeset
176 {
Dave Love <fx@gnu.org>
parents:
diff changeset
177 XrmDatabase source_db = lwlib_GetFileDatabase (path);
Dave Love <fx@gnu.org>
parents:
diff changeset
178 if (! source_db)
Dave Love <fx@gnu.org>
parents:
diff changeset
179 return (! file_p (path));
Dave Love <fx@gnu.org>
parents:
diff changeset
180 XrmCombineDatabase (source_db, target_db, override);
Dave Love <fx@gnu.org>
parents:
diff changeset
181 return 1;
Dave Love <fx@gnu.org>
parents:
diff changeset
182 }
Dave Love <fx@gnu.org>
parents:
diff changeset
183
Dave Love <fx@gnu.org>
parents:
diff changeset
184 #endif /* r5 */