Fix permissions handling (CVE-2010-0825).
[emacs.git] / src / w32reg.c
blobf9687d1effe6beba768f7f5b22fb37688c012633
1 /* Emulate the X Resource Manager through the registry.
2 Copyright (C) 1990, 1993, 1994, 2001, 2002, 2003, 2004,
3 2005, 2006, 2007, 2008, 2009, 2010 Free Software Foundation, Inc.
5 This file is part of GNU Emacs.
7 GNU Emacs is free software: you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation, either version 3 of the License, or
10 (at your option) any later version.
12 GNU Emacs is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */
20 /* Written by Kevin Gallo */
22 #include <config.h>
23 #include <setjmp.h>
24 #include "lisp.h"
25 #include "w32term.h"
26 #include "blockinput.h"
28 #include <stdio.h>
29 #include <string.h>
31 #define REG_ROOT "SOFTWARE\\GNU\\Emacs"
33 /* Default system colors from the Display Control Panel settings. */
34 #define SYSTEM_DEFAULT_RESOURCES \
35 "emacs.foreground:SystemWindowText\0" \
36 "emacs.background:SystemWindow\0" \
37 "emacs.tooltip.attributeForeground:SystemInfoText\0" \
38 "emacs.tooltip.attributeBackground:SystemInfoWindow\0" \
39 "emacs.tool-bar.attributeForeground:SystemButtonText\0" \
40 "emacs.tool-bar.attributeBackground:SystemButtonFace\0" \
41 "emacs.menu.attributeForeground:SystemMenuText\0" \
42 "emacs.menu.attributeBackground:SystemMenu\0" \
43 "emacs.scroll-bar.attributeForeground:SystemScrollbar\0"
45 /* Other possibilities for default faces:
47 region: Could use SystemHilight, but interferes with our ability to
48 see most syntax highlighting through the region face.
50 modeline: Could use System(In)ActiveTitle, gradient versions (not
51 supported on 95 and NT), but modeline is more like a status bar
52 really (which don't appear to be configurable in Windows).
54 highlight: Could use SystemHotTrackingColor, but it is not supported
55 on Windows 95 or NT, and other apps only seem to use it for menus
56 anyway.
60 static char *
61 w32_get_rdb_resource (rdb, resource)
62 char *rdb;
63 char *resource;
65 char *value = rdb;
66 int len = strlen (resource);
68 while (*value)
70 /* Comparison is case-insensitive because registry searches are too. */
71 if ((strnicmp (value, resource, len) == 0) && (value[len] == ':'))
72 return xstrdup (&value[len + 1]);
74 value = strchr (value, '\0') + 1;
77 return NULL;
80 static LPBYTE
81 w32_get_string_resource (name, class, dwexptype)
82 char *name, *class;
83 DWORD dwexptype;
85 LPBYTE lpvalue = NULL;
86 HKEY hrootkey = NULL;
87 DWORD dwType;
88 DWORD cbData;
89 BOOL ok = FALSE;
90 HKEY hive = HKEY_CURRENT_USER;
92 trykey:
94 BLOCK_INPUT;
96 /* Check both the current user and the local machine to see if we have
97 any resources */
99 if (RegOpenKeyEx (hive, REG_ROOT, 0, KEY_READ, &hrootkey) == ERROR_SUCCESS)
101 char *keyname;
103 if (RegQueryValueEx (hrootkey, name, NULL, &dwType, NULL, &cbData) == ERROR_SUCCESS
104 && dwType == dwexptype)
106 keyname = name;
108 else if (RegQueryValueEx (hrootkey, class, NULL, &dwType, NULL, &cbData) == ERROR_SUCCESS
109 && dwType == dwexptype)
111 keyname = class;
113 else
115 keyname = NULL;
118 ok = (keyname
119 && (lpvalue = (LPBYTE) xmalloc (cbData)) != NULL
120 && RegQueryValueEx (hrootkey, keyname, NULL, NULL, lpvalue, &cbData) == ERROR_SUCCESS);
122 RegCloseKey (hrootkey);
125 UNBLOCK_INPUT;
127 if (!ok)
129 if (lpvalue)
131 xfree (lpvalue);
132 lpvalue = NULL;
134 if (hive == HKEY_CURRENT_USER)
136 hive = HKEY_LOCAL_MACHINE;
137 goto trykey;
140 /* Check if there are Windows specific defaults defined. */
141 return w32_get_rdb_resource (SYSTEM_DEFAULT_RESOURCES, name);
143 return (lpvalue);
146 /* Retrieve the string resource specified by NAME with CLASS from
147 database RDB. */
149 char *
150 x_get_string_resource (rdb, name, class)
151 XrmDatabase rdb;
152 char *name, *class;
154 if (rdb)
156 char *resource;
158 if (resource = w32_get_rdb_resource (rdb, name))
159 return resource;
160 if (resource = w32_get_rdb_resource (rdb, class))
161 return resource;
164 if (inhibit_x_resources)
165 /* --quick was passed, so this is a no-op. */
166 return NULL;
168 return (w32_get_string_resource (name, class, REG_SZ));
171 /* arch-tag: 755fce25-42d7-4acb-874f-2fb42336823d
172 (do not change this comment) */