blob: 5ed58bb08ecdb2477108be7cc49e00b8a1bd0c99 [file] [log] [blame]
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001/*
Fred Drake270e19b2000-06-29 16:14:14 +00002 _winreg.c
Guido van Rossum9f3712c2000-03-28 20:37:15 +00003
4 Windows Registry access module for Python.
5
6 * Simple registry access written by Mark Hammond in win32api
7 module circa 1995.
8 * Bill Tutt expanded the support significantly not long after.
9 * Numerous other people have submitted patches since then.
10 * Ripped from win32api module 03-Feb-2000 by Mark Hammond, and
11 basic Unicode support added.
12
13*/
14
15#include "windows.h"
16#include "Python.h"
17#include "structmember.h"
18#include "malloc.h" /* for alloca */
19
20static BOOL PyHKEY_AsHKEY(PyObject *ob, HKEY *pRes, BOOL bNoneOK);
21static PyObject *PyHKEY_FromHKEY(HKEY h);
22static BOOL PyHKEY_Close(PyObject *obHandle);
23
24static char errNotAHandle[] = "Object is not a handle";
25
26/* The win32api module reports the function name that failed,
27 but this concept is not in the Python core.
28 Hopefully it will one day, and in the meantime I dont
29 want to lose this info...
30*/
31#define PyErr_SetFromWindowsErrWithFunction(rc, fnname) \
32 PyErr_SetFromWindowsErr(rc)
33
34/* Forward declares */
35
36/* Doc strings */
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +000037PyDoc_STRVAR(module_doc,
Guido van Rossum9f3712c2000-03-28 20:37:15 +000038"This module provides access to the Windows registry API.\n"
39"\n"
40"Functions:\n"
41"\n"
42"CloseKey() - Closes a registry key.\n"
43"ConnectRegistry() - Establishes a connection to a predefined registry handle\n"
44" on another computer.\n"
45"CreateKey() - Creates the specified key, or opens it if it already exists.\n"
46"DeleteKey() - Deletes the specified key.\n"
47"DeleteValue() - Removes a named value from the specified registry key.\n"
48"EnumKey() - Enumerates subkeys of the specified open registry key.\n"
49"EnumValue() - Enumerates values of the specified open registry key.\n"
50"FlushKey() - Writes all the attributes of the specified key to the registry.\n"
51"LoadKey() - Creates a subkey under HKEY_USER or HKEY_LOCAL_MACHINE and stores\n"
52" registration information from a specified file into that subkey.\n"
53"OpenKey() - Alias for <om win32api.RegOpenKeyEx>\n"
54"OpenKeyEx() - Opens the specified key.\n"
55"QueryValue() - Retrieves the value associated with the unnamed value for a\n"
56" specified key in the registry.\n"
57"QueryValueEx() - Retrieves the type and data for a specified value name\n"
58" associated with an open registry key.\n"
59"QueryInfoKey() - Returns information about the specified key.\n"
60"SaveKey() - Saves the specified key, and all its subkeys a file.\n"
61"SetValue() - Associates a value with a specified key.\n"
62"SetValueEx() - Stores data in the value field of an open registry key.\n"
63"\n"
64"Special objects:\n"
65"\n"
66"HKEYType -- type object for HKEY objects\n"
67"error -- exception raised for Win32 errors\n"
68"\n"
69"Integer constants:\n"
70"Many constants are defined - see the documentation for each function\n"
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +000071"to see what constants are used, and where.");
Guido van Rossum9f3712c2000-03-28 20:37:15 +000072
73
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +000074PyDoc_STRVAR(CloseKey_doc,
Guido van Rossum9f3712c2000-03-28 20:37:15 +000075"CloseKey(hkey) - Closes a previously opened registry key.\n"
76"\n"
77"The hkey argument specifies a previously opened key.\n"
78"\n"
79"Note that if the key is not closed using this method, it will be\n"
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +000080"closed when the hkey object is destroyed by Python.");
Guido van Rossum9f3712c2000-03-28 20:37:15 +000081
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +000082PyDoc_STRVAR(ConnectRegistry_doc,
Guido van Rossum9f3712c2000-03-28 20:37:15 +000083"key = ConnectRegistry(computer_name, key) - "
84"Establishes a connection to a predefined registry handle on another computer.\n"
85"\n"
86"computer_name is the name of the remote computer, of the form \\\\computername.\n"
87" If None, the local computer is used.\n"
88"key is the predefined handle to connect to.\n"
89"\n"
90"The return value is the handle of the opened key.\n"
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +000091"If the function fails, an EnvironmentError exception is raised.");
Guido van Rossum9f3712c2000-03-28 20:37:15 +000092
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +000093PyDoc_STRVAR(CreateKey_doc,
Guido van Rossum9f3712c2000-03-28 20:37:15 +000094"key = CreateKey(key, sub_key) - Creates or opens the specified key.\n"
95"\n"
96"key is an already open key, or one of the predefined HKEY_* constants\n"
97"sub_key is a string that names the key this method opens or creates.\n"
98" If key is one of the predefined keys, sub_key may be None. In that case,\n"
99" the handle returned is the same key handle passed in to the function.\n"
100"\n"
101"If the key already exists, this function opens the existing key\n"
102"\n"
103"The return value is the handle of the opened key.\n"
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000104"If the function fails, an exception is raised.");
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000105
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000106PyDoc_STRVAR(DeleteKey_doc,
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000107"DeleteKey(key, sub_key) - Deletes the specified key.\n"
108"\n"
109"key is an already open key, or any one of the predefined HKEY_* constants.\n"
110"sub_key is a string that must be a subkey of the key identified by the key parameter.\n"
111" This value must not be None, and the key may not have subkeys.\n"
112"\n"
113"This method can not delete keys with subkeys.\n"
114"\n"
115"If the method succeeds, the entire key, including all of its values,\n"
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000116"is removed. If the method fails, an EnvironmentError exception is raised.");
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000117
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000118PyDoc_STRVAR(DeleteValue_doc,
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000119"DeleteValue(key, value) - Removes a named value from a registry key.\n"
120"\n"
121"key is an already open key, or any one of the predefined HKEY_* constants.\n"
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000122"value is a string that identifies the value to remove.");
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000123
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000124PyDoc_STRVAR(EnumKey_doc,
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000125"string = EnumKey(key, index) - Enumerates subkeys of an open registry key.\n"
126"\n"
127"key is an already open key, or any one of the predefined HKEY_* constants.\n"
128"index is an integer that identifies the index of the key to retrieve.\n"
129"\n"
130"The function retrieves the name of one subkey each time it is called.\n"
Mark Hammondb422f952000-06-09 06:01:47 +0000131"It is typically called repeatedly until an EnvironmentError exception is\n"
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000132"raised, indicating no more values are available.");
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000133
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000134PyDoc_STRVAR(EnumValue_doc,
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000135"tuple = EnumValue(key, index) - Enumerates values of an open registry key.\n"
136"key is an already open key, or any one of the predefined HKEY_* constants.\n"
137"index is an integer that identifies the index of the value to retrieve.\n"
138"\n"
139"The function retrieves the name of one subkey each time it is called.\n"
Mark Hammondb422f952000-06-09 06:01:47 +0000140"It is typically called repeatedly, until an EnvironmentError exception\n"
141"is raised, indicating no more values.\n"
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000142"\n"
143"The result is a tuple of 3 items:\n"
144"value_name is a string that identifies the value.\n"
145"value_data is an object that holds the value data, and whose type depends\n"
146" on the underlying registry type.\n"
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000147"data_type is an integer that identifies the type of the value data.");
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000148
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000149PyDoc_STRVAR(FlushKey_doc,
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000150"FlushKey(key) - Writes all the attributes of a key to the registry.\n"
151"\n"
152"key is an already open key, or any one of the predefined HKEY_* constants.\n"
153"\n"
154"It is not necessary to call RegFlushKey to change a key.\n"
155"Registry changes are flushed to disk by the registry using its lazy flusher.\n"
156"Registry changes are also flushed to disk at system shutdown.\n"
157"Unlike CloseKey(), the FlushKey() method returns only when all the data has\n"
158"been written to the registry.\n"
159"An application should only call FlushKey() if it requires absolute certainty that registry changes are on disk.\n"
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000160"If you don't know whether a FlushKey() call is required, it probably isn't.");
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000161
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000162PyDoc_STRVAR(LoadKey_doc,
Mark Hammondb422f952000-06-09 06:01:47 +0000163"LoadKey(key, sub_key, file_name) - Creates a subkey under the specified key\n"
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000164"and stores registration information from a specified file into that subkey.\n"
165"\n"
166"key is an already open key, or any one of the predefined HKEY_* constants.\n"
167"sub_key is a string that identifies the sub_key to load\n"
168"file_name is the name of the file to load registry data from.\n"
169" This file must have been created with the SaveKey() function.\n"
170" Under the file allocation table (FAT) file system, the filename may not\n"
171"have an extension.\n"
172"\n"
173"A call to LoadKey() fails if the calling process does not have the\n"
174"SE_RESTORE_PRIVILEGE privilege.\n"
175"\n"
176"If key is a handle returned by ConnectRegistry(), then the path specified\n"
177"in fileName is relative to the remote computer.\n"
178"\n"
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000179"The docs imply key must be in the HKEY_USER or HKEY_LOCAL_MACHINE tree");
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000180
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000181PyDoc_STRVAR(OpenKey_doc,
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000182"key = OpenKey(key, sub_key, res = 0, sam = KEY_READ) - Opens the specified key.\n"
183"\n"
184"key is an already open key, or any one of the predefined HKEY_* constants.\n"
185"sub_key is a string that identifies the sub_key to open\n"
186"res is a reserved integer, and must be zero. Default is zero.\n"
187"sam is an integer that specifies an access mask that describes the desired\n"
188" security access for the key. Default is KEY_READ\n"
189"\n"
190"The result is a new handle to the specified key\n"
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000191"If the function fails, an EnvironmentError exception is raised.");
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000192
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000193PyDoc_STRVAR(OpenKeyEx_doc, "See OpenKey()");
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000194
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000195PyDoc_STRVAR(QueryInfoKey_doc,
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000196"tuple = QueryInfoKey(key) - Returns information about a key.\n"
197"\n"
198"key is an already open key, or any one of the predefined HKEY_* constants.\n"
199"\n"
200"The result is a tuple of 3 items:"
201"An integer that identifies the number of sub keys this key has.\n"
202"An integer that identifies the number of values this key has.\n"
203"A long integer that identifies when the key was last modified (if available)\n"
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000204" as 100's of nanoseconds since Jan 1, 1600.");
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000205
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000206PyDoc_STRVAR(QueryValue_doc,
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000207"string = QueryValue(key, sub_key) - retrieves the unnamed value for a key.\n"
208"\n"
209"key is an already open key, or any one of the predefined HKEY_* constants.\n"
Mark Hammondb422f952000-06-09 06:01:47 +0000210"sub_key is a string that holds the name of the subkey with which the value\n"
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000211" is associated. If this parameter is None or empty, the function retrieves\n"
212" the value set by the SetValue() method for the key identified by key."
213"\n"
214"Values in the registry have name, type, and data components. This method\n"
215"retrieves the data for a key's first value that has a NULL name.\n"
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000216"But the underlying API call doesn't return the type, Lame Lame Lame, DONT USE THIS!!!");
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000217
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000218PyDoc_STRVAR(QueryValueEx_doc,
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000219"value,type_id = QueryValueEx(key, value_name) - Retrieves the type and data for a specified value name associated with an open registry key.\n"
220"\n"
221"key is an already open key, or any one of the predefined HKEY_* constants.\n"
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000222"value_name is a string indicating the value to query");
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000223
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000224PyDoc_STRVAR(SaveKey_doc,
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000225"SaveKey(key, file_name) - Saves the specified key, and all its subkeys to the specified file.\n"
226"\n"
227"key is an already open key, or any one of the predefined HKEY_* constants.\n"
228"file_name is the name of the file to save registry data to.\n"
229" This file cannot already exist. If this filename includes an extension,\n"
230" it cannot be used on file allocation table (FAT) file systems by the\n"
231" LoadKey(), ReplaceKey() or RestoreKey() methods.\n"
232"\n"
233"If key represents a key on a remote computer, the path described by\n"
234"file_name is relative to the remote computer.\n"
235"The caller of this method must possess the SeBackupPrivilege security privilege.\n"
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000236"This function passes NULL for security_attributes to the API.");
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000237
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000238PyDoc_STRVAR(SetValue_doc,
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000239"SetValue(key, sub_key, type, value) - Associates a value with a specified key.\n"
240"\n"
241"key is an already open key, or any one of the predefined HKEY_* constants.\n"
242"sub_key is a string that names the subkey with which the value is associated.\n"
243"type is an integer that specifies the type of the data. Currently this\n"
244" must be REG_SZ, meaning only strings are supported.\n"
245"value is a string that specifies the new value.\n"
246"\n"
247"If the key specified by the sub_key parameter does not exist, the SetValue\n"
248"function creates it.\n"
249"\n"
250"Value lengths are limited by available memory. Long values (more than\n"
251"2048 bytes) should be stored as files with the filenames stored in \n"
252"the configuration registry. This helps the registry perform efficiently.\n"
253"\n"
254"The key identified by the key parameter must have been opened with\n"
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000255"KEY_SET_VALUE access.");
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000256
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000257PyDoc_STRVAR(SetValueEx_doc,
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000258"SetValueEx(key, value_name, reserved, type, value) - Stores data in the value field of an open registry key.\n"
259"\n"
260"key is an already open key, or any one of the predefined HKEY_* constants.\n"
Mark Hammondc9083b62003-01-15 23:38:15 +0000261"value_name is a string containing the name of the value to set, or None\n"
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000262"type is an integer that specifies the type of the data. This should be one of:\n"
263" REG_BINARY -- Binary data in any form.\n"
264" REG_DWORD -- A 32-bit number.\n"
265" REG_DWORD_LITTLE_ENDIAN -- A 32-bit number in little-endian format.\n"
266" REG_DWORD_BIG_ENDIAN -- A 32-bit number in big-endian format.\n"
267" REG_EXPAND_SZ -- A null-terminated string that contains unexpanded references\n"
268" to environment variables (for example, %PATH%).\n"
269" REG_LINK -- A Unicode symbolic link.\n"
Mark Hammondb422f952000-06-09 06:01:47 +0000270" REG_MULTI_SZ -- An sequence of null-terminated strings, terminated by\n"
271" two null characters. Note that Python handles this\n"
272" termination automatically.\n"
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000273" REG_NONE -- No defined value type.\n"
274" REG_RESOURCE_LIST -- A device-driver resource list.\n"
275" REG_SZ -- A null-terminated string.\n"
276"reserved can be anything - zero is always passed to the API.\n"
277"value is a string that specifies the new value.\n"
278"\n"
279"This method can also set additional value and type information for the\n"
280"specified key. The key identified by the key parameter must have been\n"
281"opened with KEY_SET_VALUE access.\n"
282"\n"
283"To open the key, use the CreateKeyEx() or OpenKeyEx() methods.\n"
284"\n"
285"Value lengths are limited by available memory. Long values (more than\n"
286"2048 bytes) should be stored as files with the filenames stored in \n"
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000287"the configuration registry. This helps the registry perform efficiently.");
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000288
289/* PyHKEY docstrings */
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000290PyDoc_STRVAR(PyHKEY_doc,
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000291"PyHKEY Object - A Python object, representing a win32 registry key.\n"
292"\n"
Mark Hammondb422f952000-06-09 06:01:47 +0000293"This object wraps a Windows HKEY object, automatically closing it when\n"
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000294"the object is destroyed. To guarantee cleanup, you can call either\n"
295"the Close() method on the PyHKEY, or the CloseKey() method.\n"
296"\n"
297"All functions which accept a handle object also accept an integer - \n"
298"however, use of the handle object is encouraged.\n"
299"\n"
300"Functions:\n"
301"Close() - Closes the underlying handle.\n"
302"Detach() - Returns the integer Win32 handle, detaching it from the object\n"
303"\n"
304"Properties:\n"
305"handle - The integer Win32 handle.\n"
306"\n"
307"Operations:\n"
308"__nonzero__ - Handles with an open object return true, otherwise false.\n"
309"__int__ - Converting a handle to an integer returns the Win32 handle.\n"
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000310"__cmp__ - Handle objects are compared using the handle value.");
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000311
312
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000313PyDoc_STRVAR(PyHKEY_Close_doc,
Mark Hammondb422f952000-06-09 06:01:47 +0000314"key.Close() - Closes the underlying Windows handle.\n"
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000315"\n"
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000316"If the handle is already closed, no error is raised.");
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000317
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000318PyDoc_STRVAR(PyHKEY_Detach_doc,
Mark Hammondb422f952000-06-09 06:01:47 +0000319"int = key.Detach() - Detaches the Windows handle from the handle object.\n"
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000320"\n"
321"The result is the value of the handle before it is detached. If the\n"
322"handle is already detached, this will return zero.\n"
323"\n"
324"After calling this function, the handle is effectively invalidated,\n"
325"but the handle is not closed. You would call this function when you\n"
326"need the underlying win32 handle to exist beyond the lifetime of the\n"
Mark Hammondb422f952000-06-09 06:01:47 +0000327"handle object.\n"
Martin v. Löwis14f8b4c2002-06-13 20:33:02 +0000328"On 64 bit windows, the result of this function is a long integer");
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000329
330
331/************************************************************************
332
333 The PyHKEY object definition
334
335************************************************************************/
336typedef struct {
337 PyObject_VAR_HEAD
338 HKEY hkey;
339} PyHKEYObject;
340
341#define PyHKEY_Check(op) ((op)->ob_type == &PyHKEY_Type)
342
343static char *failMsg = "bad operand type";
344
345static PyObject *
346PyHKEY_unaryFailureFunc(PyObject *ob)
347{
348 PyErr_SetString(PyExc_TypeError, failMsg);
349 return NULL;
350}
351static PyObject *
352PyHKEY_binaryFailureFunc(PyObject *ob1, PyObject *ob2)
353{
354 PyErr_SetString(PyExc_TypeError, failMsg);
355 return NULL;
356}
357static PyObject *
358PyHKEY_ternaryFailureFunc(PyObject *ob1, PyObject *ob2, PyObject *ob3)
359{
360 PyErr_SetString(PyExc_TypeError, failMsg);
361 return NULL;
362}
363
364static void
365PyHKEY_deallocFunc(PyObject *ob)
366{
367 /* Can not call PyHKEY_Close, as the ob->tp_type
368 has already been cleared, thus causing the type
369 check to fail!
370 */
371 PyHKEYObject *obkey = (PyHKEYObject *)ob;
372 if (obkey->hkey)
373 RegCloseKey((HKEY)obkey->hkey);
Guido van Rossumb18618d2000-05-03 23:44:39 +0000374 PyObject_DEL(ob);
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000375}
376
377static int
378PyHKEY_nonzeroFunc(PyObject *ob)
379{
380 return ((PyHKEYObject *)ob)->hkey != 0;
381}
382
383static PyObject *
384PyHKEY_intFunc(PyObject *ob)
385{
386 PyHKEYObject *pyhkey = (PyHKEYObject *)ob;
387 return PyLong_FromVoidPtr(pyhkey->hkey);
388}
389
390static int
391PyHKEY_printFunc(PyObject *ob, FILE *fp, int flags)
392{
393 PyHKEYObject *pyhkey = (PyHKEYObject *)ob;
394 char resBuf[160];
395 wsprintf(resBuf, "<PyHKEY at %p (%p)>",
396 ob, pyhkey->hkey);
397 fputs(resBuf, fp);
398 return 0;
399}
400
401static PyObject *
402PyHKEY_strFunc(PyObject *ob)
403{
404 PyHKEYObject *pyhkey = (PyHKEYObject *)ob;
405 char resBuf[160];
406 wsprintf(resBuf, "<PyHKEY:%p>", pyhkey->hkey);
407 return PyString_FromString(resBuf);
408}
409
410static int
411PyHKEY_compareFunc(PyObject *ob1, PyObject *ob2)
412{
413 PyHKEYObject *pyhkey1 = (PyHKEYObject *)ob1;
414 PyHKEYObject *pyhkey2 = (PyHKEYObject *)ob2;
415 return pyhkey1 == pyhkey2 ? 0 :
416 (pyhkey1 < pyhkey2 ? -1 : 1);
417}
418
419static long
420PyHKEY_hashFunc(PyObject *ob)
421{
422 /* Just use the address.
423 XXX - should we use the handle value?
424 */
Fred Drake13634cf2000-06-29 19:17:04 +0000425 return _Py_HashPointer(ob);
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000426}
427
428
429static PyNumberMethods PyHKEY_NumberMethods =
430{
431 PyHKEY_binaryFailureFunc, /* nb_add */
432 PyHKEY_binaryFailureFunc, /* nb_subtract */
433 PyHKEY_binaryFailureFunc, /* nb_multiply */
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000434 PyHKEY_binaryFailureFunc, /* nb_remainder */
435 PyHKEY_binaryFailureFunc, /* nb_divmod */
436 PyHKEY_ternaryFailureFunc, /* nb_power */
437 PyHKEY_unaryFailureFunc, /* nb_negative */
438 PyHKEY_unaryFailureFunc, /* nb_positive */
439 PyHKEY_unaryFailureFunc, /* nb_absolute */
440 PyHKEY_nonzeroFunc, /* nb_nonzero */
441 PyHKEY_unaryFailureFunc, /* nb_invert */
442 PyHKEY_binaryFailureFunc, /* nb_lshift */
443 PyHKEY_binaryFailureFunc, /* nb_rshift */
444 PyHKEY_binaryFailureFunc, /* nb_and */
445 PyHKEY_binaryFailureFunc, /* nb_xor */
446 PyHKEY_binaryFailureFunc, /* nb_or */
447 0, /* nb_coerce (allowed to be zero) */
448 PyHKEY_intFunc, /* nb_int */
449 PyHKEY_unaryFailureFunc, /* nb_long */
450 PyHKEY_unaryFailureFunc, /* nb_float */
451 PyHKEY_unaryFailureFunc, /* nb_oct */
452 PyHKEY_unaryFailureFunc, /* nb_hex */
453};
454
455
456/* fwd declare __getattr__ */
Tim Petersc3d12ac2005-12-24 06:03:06 +0000457static PyObject *PyHKEY_getattr(PyObject *self, const char *name);
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000458
459/* The type itself */
460PyTypeObject PyHKEY_Type =
461{
462 PyObject_HEAD_INIT(0) /* fill in type at module init */
463 0,
464 "PyHKEY",
465 sizeof(PyHKEYObject),
466 0,
467 PyHKEY_deallocFunc, /* tp_dealloc */
468 PyHKEY_printFunc, /* tp_print */
469 PyHKEY_getattr, /* tp_getattr */
470 0, /* tp_setattr */
471 PyHKEY_compareFunc, /* tp_compare */
472 0, /* tp_repr */
473 &PyHKEY_NumberMethods, /* tp_as_number */
474 0, /* tp_as_sequence */
475 0, /* tp_as_mapping */
476 PyHKEY_hashFunc, /* tp_hash */
477 0, /* tp_call */
478 PyHKEY_strFunc, /* tp_str */
479 0, /* tp_getattro */
480 0, /* tp_setattro */
481 0, /* tp_as_buffer */
482 0, /* tp_flags */
483 PyHKEY_doc, /* tp_doc */
484};
485
486#define OFF(e) offsetof(PyHKEYObject, e)
487
488static struct memberlist PyHKEY_memberlist[] = {
489 {"handle", T_INT, OFF(hkey)},
490 {NULL} /* Sentinel */
491};
492
493/************************************************************************
494
495 The PyHKEY object methods
496
497************************************************************************/
498static PyObject *
499PyHKEY_CloseMethod(PyObject *self, PyObject *args)
500{
501 if (!PyArg_ParseTuple(args, ":Close"))
502 return NULL;
503 if (!PyHKEY_Close(self))
504 return NULL;
505 Py_INCREF(Py_None);
506 return Py_None;
507}
508
509static PyObject *
510PyHKEY_DetachMethod(PyObject *self, PyObject *args)
511{
512 void* ret;
513 PyHKEYObject *pThis = (PyHKEYObject *)self;
514 if (!PyArg_ParseTuple(args, ":Detach"))
515 return NULL;
516 ret = (void*)pThis->hkey;
517 pThis->hkey = 0;
518 return PyLong_FromVoidPtr(ret);
519}
520
521static struct PyMethodDef PyHKEY_methods[] = {
Neal Norwitz031829d2002-03-31 14:37:44 +0000522 {"Close", PyHKEY_CloseMethod, METH_VARARGS, PyHKEY_Close_doc},
523 {"Detach", PyHKEY_DetachMethod, METH_VARARGS, PyHKEY_Detach_doc},
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000524 {NULL}
525};
526
527/*static*/ PyObject *
Tim Petersc3d12ac2005-12-24 06:03:06 +0000528PyHKEY_getattr(PyObject *self, const char *name)
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000529{
530 PyObject *res;
531
532 res = Py_FindMethod(PyHKEY_methods, self, name);
533 if (res != NULL)
534 return res;
535 PyErr_Clear();
536 if (strcmp(name, "handle") == 0)
537 return PyLong_FromVoidPtr(((PyHKEYObject *)self)->hkey);
538 return PyMember_Get((char *)self, PyHKEY_memberlist, name);
539}
540
541/************************************************************************
542 The public PyHKEY API (well, not public yet :-)
543************************************************************************/
544PyObject *
545PyHKEY_New(HKEY hInit)
546{
547 PyHKEYObject *key = PyObject_NEW(PyHKEYObject, &PyHKEY_Type);
548 if (key)
549 key->hkey = hInit;
550 return (PyObject *)key;
551}
552
553BOOL
554PyHKEY_Close(PyObject *ob_handle)
555{
556 LONG rc;
557 PyHKEYObject *key;
558
559 if (!PyHKEY_Check(ob_handle)) {
560 PyErr_SetString(PyExc_TypeError, "bad operand type");
561 return FALSE;
562 }
563 key = (PyHKEYObject *)ob_handle;
564 rc = key->hkey ? RegCloseKey((HKEY)key->hkey) : ERROR_SUCCESS;
565 key->hkey = 0;
566 if (rc != ERROR_SUCCESS)
567 PyErr_SetFromWindowsErrWithFunction(rc, "RegCloseKey");
568 return rc == ERROR_SUCCESS;
569}
570
571BOOL
572PyHKEY_AsHKEY(PyObject *ob, HKEY *pHANDLE, BOOL bNoneOK)
573{
574 if (ob == Py_None) {
575 if (!bNoneOK) {
576 PyErr_SetString(
577 PyExc_TypeError,
578 "None is not a valid HKEY in this context");
579 return FALSE;
580 }
581 *pHANDLE = (HKEY)0;
582 }
583 else if (PyHKEY_Check(ob)) {
584 PyHKEYObject *pH = (PyHKEYObject *)ob;
585 *pHANDLE = pH->hkey;
586 }
587 else if (PyInt_Check(ob) || PyLong_Check(ob)) {
588 /* We also support integers */
589 PyErr_Clear();
590 *pHANDLE = (HKEY)PyLong_AsVoidPtr(ob);
591 if (PyErr_Occurred())
592 return FALSE;
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000593 }
594 else {
595 PyErr_SetString(
596 PyExc_TypeError,
597 "The object is not a PyHKEY object");
598 return FALSE;
599 }
600 return TRUE;
601}
602
603PyObject *
604PyHKEY_FromHKEY(HKEY h)
605{
Guido van Rossumb18618d2000-05-03 23:44:39 +0000606 PyHKEYObject *op;
607
Guido van Rossume3a8e7e2002-08-19 19:26:42 +0000608 /* Inline PyObject_New */
Guido van Rossumb18618d2000-05-03 23:44:39 +0000609 op = (PyHKEYObject *) PyObject_MALLOC(sizeof(PyHKEYObject));
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000610 if (op == NULL)
611 return PyErr_NoMemory();
Guido van Rossumb18618d2000-05-03 23:44:39 +0000612 PyObject_INIT(op, &PyHKEY_Type);
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000613 op->hkey = h;
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000614 return (PyObject *)op;
615}
616
617
618/************************************************************************
619 The module methods
620************************************************************************/
621BOOL
622PyWinObject_CloseHKEY(PyObject *obHandle)
623{
624 BOOL ok;
625 if (PyHKEY_Check(obHandle)) {
626 ok = PyHKEY_Close(obHandle);
627 }
Fred Drake25e17262000-06-30 17:48:51 +0000628#if SIZEOF_LONG >= SIZEOF_HKEY
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000629 else if (PyInt_Check(obHandle)) {
630 long rc = RegCloseKey((HKEY)PyInt_AsLong(obHandle));
631 ok = (rc == ERROR_SUCCESS);
632 if (!ok)
633 PyErr_SetFromWindowsErrWithFunction(rc, "RegCloseKey");
634 }
Fred Drake25e17262000-06-30 17:48:51 +0000635#else
636 else if (PyLong_Check(obHandle)) {
637 long rc = RegCloseKey((HKEY)PyLong_AsVoidPtr(obHandle));
638 ok = (rc == ERROR_SUCCESS);
639 if (!ok)
640 PyErr_SetFromWindowsErrWithFunction(rc, "RegCloseKey");
641 }
642#endif
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000643 else {
644 PyErr_SetString(
645 PyExc_TypeError,
646 "A handle must be a HKEY object or an integer");
647 return FALSE;
648 }
649 return ok;
650}
651
652
653/*
654 Private Helper functions for the registry interfaces
655
656** Note that fixupMultiSZ and countString have both had changes
657** made to support "incorrect strings". The registry specification
658** calls for strings to be terminated with 2 null bytes. It seems
Thomas Wouters7e474022000-07-16 12:04:32 +0000659** some commercial packages install strings which dont conform,
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000660** causing this code to fail - however, "regedit" etc still work
661** with these strings (ie only we dont!).
662*/
663static void
664fixupMultiSZ(char **str, char *data, int len)
665{
666 char *P;
667 int i;
668 char *Q;
669
670 Q = data + len;
671 for (P = data, i = 0; P < Q && *P != '\0'; P++, i++) {
672 str[i] = P;
673 for(; *P != '\0'; P++)
674 ;
675 }
676}
677
678static int
679countStrings(char *data, int len)
680{
681 int strings;
682 char *P;
683 char *Q = data + len;
684
685 for (P = data, strings = 0; P < Q && *P != '\0'; P++, strings++)
686 for (; P < Q && *P != '\0'; P++)
687 ;
688 return strings;
689}
690
691/* Convert PyObject into Registry data.
692 Allocates space as needed. */
693static BOOL
694Py2Reg(PyObject *value, DWORD typ, BYTE **retDataBuf, DWORD *retDataSize)
695{
696 int i,j;
697 switch (typ) {
698 case REG_DWORD:
699 if (value != Py_None && !PyInt_Check(value))
700 return FALSE;
701 *retDataBuf = (BYTE *)PyMem_NEW(DWORD, sizeof(DWORD));
702 if (*retDataBuf==NULL){
703 PyErr_NoMemory();
704 return FALSE;
705 }
706 *retDataSize = sizeof(DWORD);
707 if (value == Py_None) {
708 DWORD zero = 0;
709 memcpy(*retDataBuf, &zero, sizeof(DWORD));
710 }
711 else
712 memcpy(*retDataBuf,
713 &PyInt_AS_LONG((PyIntObject *)value),
714 sizeof(DWORD));
715 break;
716 case REG_SZ:
717 case REG_EXPAND_SZ:
718 {
719 int need_decref = 0;
720 if (value == Py_None)
721 *retDataSize = 1;
722 else {
723 if (PyUnicode_Check(value)) {
724 value = PyUnicode_AsEncodedString(
725 value,
726 "mbcs",
727 NULL);
728 if (value==NULL)
729 return FALSE;
730 need_decref = 1;
731 }
732 if (!PyString_Check(value))
733 return FALSE;
734 *retDataSize = 1 + strlen(
735 PyString_AS_STRING(
736 (PyStringObject *)value));
737 }
738 *retDataBuf = (BYTE *)PyMem_NEW(DWORD, *retDataSize);
739 if (*retDataBuf==NULL){
740 PyErr_NoMemory();
741 return FALSE;
742 }
743 if (value == Py_None)
744 strcpy((char *)*retDataBuf, "");
745 else
746 strcpy((char *)*retDataBuf,
747 PyString_AS_STRING(
748 (PyStringObject *)value));
749 if (need_decref)
750 Py_DECREF(value);
751 break;
752 }
753 case REG_MULTI_SZ:
754 {
755 DWORD size = 0;
756 char *P;
757 PyObject **obs = NULL;
758
759 if (value == Py_None)
760 i = 0;
761 else {
762 if (!PyList_Check(value))
763 return FALSE;
764 i = PyList_Size(value);
765 }
766 obs = malloc(sizeof(PyObject *) * i);
767 memset(obs, 0, sizeof(PyObject *) * i);
768 for (j = 0; j < i; j++)
769 {
770 PyObject *t;
771 t = PyList_GET_ITEM(
772 (PyListObject *)value,j);
773 if (PyString_Check(t)) {
774 obs[j] = t;
775 Py_INCREF(t);
776 } else if (PyUnicode_Check(t)) {
777 obs[j] = PyUnicode_AsEncodedString(
778 t,
779 "mbcs",
780 NULL);
781 if (obs[j]==NULL)
782 goto reg_multi_fail;
783 } else
784 goto reg_multi_fail;
785 size += 1 + strlen(
786 PyString_AS_STRING(
787 (PyStringObject *)obs[j]));
788 }
789
790 *retDataSize = size + 1;
791 *retDataBuf = (BYTE *)PyMem_NEW(char,
792 *retDataSize);
793 if (*retDataBuf==NULL){
794 PyErr_NoMemory();
795 goto reg_multi_fail;
796 }
797 P = (char *)*retDataBuf;
798
799 for (j = 0; j < i; j++)
800 {
801 PyObject *t;
802 t = obs[j];
803 strcpy(P,
804 PyString_AS_STRING(
805 (PyStringObject *)t));
806 P += 1 + strlen(
807 PyString_AS_STRING(
808 (PyStringObject *)t));
809 Py_DECREF(obs[j]);
810 }
811 /* And doubly-terminate the list... */
812 *P = '\0';
813 free(obs);
814 break;
815 reg_multi_fail:
816 if (obs) {
817 for (j = 0; j < i; j++)
818 Py_XDECREF(obs[j]);
819
820 free(obs);
821 }
822 return FALSE;
823 }
824 case REG_BINARY:
825 /* ALSO handle ALL unknown data types here. Even if we can't
826 support it natively, we should handle the bits. */
827 default:
828 if (value == Py_None)
829 *retDataSize = 0;
830 else {
Mark Hammond4e80bb52000-07-28 03:44:41 +0000831 void *src_buf;
832 PyBufferProcs *pb = value->ob_type->tp_as_buffer;
833 if (pb==NULL) {
Tim Peters313fcd42006-02-19 04:05:39 +0000834 PyErr_Format(PyExc_TypeError,
Mark Hammond4e80bb52000-07-28 03:44:41 +0000835 "Objects of type '%s' can not "
Tim Peters313fcd42006-02-19 04:05:39 +0000836 "be used as binary registry values",
Mark Hammond4e80bb52000-07-28 03:44:41 +0000837 value->ob_type->tp_name);
838 return FALSE;
839 }
840 *retDataSize = (*pb->bf_getreadbuffer)(value, 0, &src_buf);
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000841 *retDataBuf = (BYTE *)PyMem_NEW(char,
842 *retDataSize);
843 if (*retDataBuf==NULL){
844 PyErr_NoMemory();
845 return FALSE;
846 }
Mark Hammond4e80bb52000-07-28 03:44:41 +0000847 memcpy(*retDataBuf, src_buf, *retDataSize);
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000848 }
849 break;
850 }
851 return TRUE;
852}
853
854/* Convert Registry data into PyObject*/
855static PyObject *
856Reg2Py(char *retDataBuf, DWORD retDataSize, DWORD typ)
857{
858 PyObject *obData;
859
860 switch (typ) {
861 case REG_DWORD:
862 if (retDataSize == 0)
863 obData = Py_BuildValue("i", 0);
864 else
865 obData = Py_BuildValue("i",
866 *(int *)retDataBuf);
867 break;
868 case REG_SZ:
869 case REG_EXPAND_SZ:
870 /* retDataBuf may or may not have a trailing NULL in
871 the buffer. */
872 if (retDataSize && retDataBuf[retDataSize-1] == '\0')
873 --retDataSize;
874 if (retDataSize ==0)
875 retDataBuf = "";
876 obData = PyUnicode_DecodeMBCS(retDataBuf,
877 retDataSize,
878 NULL);
879 break;
880 case REG_MULTI_SZ:
881 if (retDataSize == 0)
882 obData = PyList_New(0);
883 else
884 {
885 int index = 0;
886 int s = countStrings(retDataBuf, retDataSize);
887 char **str = (char **)malloc(sizeof(char *)*s);
888 if (str == NULL)
889 return PyErr_NoMemory();
890
891 fixupMultiSZ(str, retDataBuf, retDataSize);
892 obData = PyList_New(s);
Fred Drake25e17262000-06-30 17:48:51 +0000893 if (obData == NULL)
894 return NULL;
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000895 for (index = 0; index < s; index++)
896 {
Fred Drake25e17262000-06-30 17:48:51 +0000897 size_t len = _mbstrlen(str[index]);
898 if (len > INT_MAX) {
899 PyErr_SetString(PyExc_OverflowError,
900 "registry string is too long for a Python string");
901 Py_DECREF(obData);
902 return NULL;
903 }
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000904 PyList_SetItem(obData,
905 index,
906 PyUnicode_DecodeMBCS(
907 (const char *)str[index],
Fred Drake25e17262000-06-30 17:48:51 +0000908 (int)len,
Guido van Rossum9f3712c2000-03-28 20:37:15 +0000909 NULL)
910 );
911 }
912 free(str);
913
914 break;
915 }
916 case REG_BINARY:
917 /* ALSO handle ALL unknown data types here. Even if we can't
918 support it natively, we should handle the bits. */
919 default:
920 if (retDataSize == 0) {
921 Py_INCREF(Py_None);
922 obData = Py_None;
923 }
924 else
925 obData = Py_BuildValue("s#",
926 (char *)retDataBuf,
927 retDataSize);
928 break;
929 }
930 if (obData == NULL)
931 return NULL;
932 else
933 return obData;
934}
935
936/* The Python methods */
937
938static PyObject *
939PyCloseKey(PyObject *self, PyObject *args)
940{
941 PyObject *obKey;
942 if (!PyArg_ParseTuple(args, "O:CloseKey", &obKey))
943 return NULL;
944 if (!PyHKEY_Close(obKey))
945 return NULL;
946 Py_INCREF(Py_None);
947 return Py_None;
948}
949
950static PyObject *
951PyConnectRegistry(PyObject *self, PyObject *args)
952{
953 HKEY hKey;
954 PyObject *obKey;
955 char *szCompName = NULL;
956 HKEY retKey;
957 long rc;
958 if (!PyArg_ParseTuple(args, "zO:ConnectRegistry", &szCompName, &obKey))
959 return NULL;
960 if (!PyHKEY_AsHKEY(obKey, &hKey, FALSE))
961 return NULL;
962 rc = RegConnectRegistry(szCompName, hKey, &retKey);
963 if (rc != ERROR_SUCCESS)
964 return PyErr_SetFromWindowsErrWithFunction(rc,
965 "ConnectRegistry");
966 return PyHKEY_FromHKEY(retKey);
967}
968
969static PyObject *
970PyCreateKey(PyObject *self, PyObject *args)
971{
972 HKEY hKey;
973 PyObject *obKey;
974 char *subKey;
975 HKEY retKey;
976 long rc;
977 if (!PyArg_ParseTuple(args, "Oz:CreateKey", &obKey, &subKey))
978 return NULL;
979 if (!PyHKEY_AsHKEY(obKey, &hKey, FALSE))
980 return NULL;
981 rc = RegCreateKey(hKey, subKey, &retKey);
982 if (rc != ERROR_SUCCESS)
983 return PyErr_SetFromWindowsErrWithFunction(rc, "CreateKey");
984 return PyHKEY_FromHKEY(retKey);
985}
986
987static PyObject *
988PyDeleteKey(PyObject *self, PyObject *args)
989{
990 HKEY hKey;
991 PyObject *obKey;
992 char *subKey;
993 long rc;
994 if (!PyArg_ParseTuple(args, "Os:DeleteKey", &obKey, &subKey))
995 return NULL;
996 if (!PyHKEY_AsHKEY(obKey, &hKey, FALSE))
997 return NULL;
998 rc = RegDeleteKey(hKey, subKey );
999 if (rc != ERROR_SUCCESS)
1000 return PyErr_SetFromWindowsErrWithFunction(rc, "RegDeleteKey");
1001 Py_INCREF(Py_None);
1002 return Py_None;
1003}
1004
1005static PyObject *
1006PyDeleteValue(PyObject *self, PyObject *args)
1007{
1008 HKEY hKey;
1009 PyObject *obKey;
1010 char *subKey;
1011 long rc;
1012 if (!PyArg_ParseTuple(args, "Oz:DeleteValue", &obKey, &subKey))
1013 return NULL;
1014 if (!PyHKEY_AsHKEY(obKey, &hKey, FALSE))
1015 return NULL;
1016 Py_BEGIN_ALLOW_THREADS
1017 rc = RegDeleteValue(hKey, subKey);
1018 Py_END_ALLOW_THREADS
1019 if (rc !=ERROR_SUCCESS)
1020 return PyErr_SetFromWindowsErrWithFunction(rc,
1021 "RegDeleteValue");
1022 Py_INCREF(Py_None);
1023 return Py_None;
1024}
1025
1026static PyObject *
1027PyEnumKey(PyObject *self, PyObject *args)
1028{
1029 HKEY hKey;
1030 PyObject *obKey;
1031 int index;
1032 long rc;
Guido van Rossuma6a38ad2003-11-30 22:01:43 +00001033 PyObject *retStr;
Georg Brandl9a928e72006-02-18 23:35:11 +00001034 char tmpbuf[256]; /* max key name length is 255 */
Georg Brandlb2699b22006-02-18 23:44:24 +00001035 DWORD len = sizeof(tmpbuf); /* includes NULL terminator */
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001036
1037 if (!PyArg_ParseTuple(args, "Oi:EnumKey", &obKey, &index))
1038 return NULL;
1039 if (!PyHKEY_AsHKEY(obKey, &hKey, FALSE))
1040 return NULL;
Tim Peters313fcd42006-02-19 04:05:39 +00001041
Georg Brandl9a928e72006-02-18 23:35:11 +00001042 Py_BEGIN_ALLOW_THREADS
1043 rc = RegEnumKeyEx(hKey, index, tmpbuf, &len, NULL, NULL, NULL, NULL);
1044 Py_END_ALLOW_THREADS
1045 if (rc != ERROR_SUCCESS)
1046 return PyErr_SetFromWindowsErrWithFunction(rc, "RegEnumKeyEx");
Tim Peters313fcd42006-02-19 04:05:39 +00001047
Georg Brandl9a928e72006-02-18 23:35:11 +00001048 retStr = PyString_FromStringAndSize(tmpbuf, len);
1049 return retStr; /* can be NULL */
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001050}
1051
1052static PyObject *
1053PyEnumValue(PyObject *self, PyObject *args)
1054{
1055 HKEY hKey;
1056 PyObject *obKey;
1057 int index;
1058 long rc;
1059 char *retValueBuf;
1060 char *retDataBuf;
1061 DWORD retValueSize;
1062 DWORD retDataSize;
1063 DWORD typ;
1064 PyObject *obData;
1065 PyObject *retVal;
1066
1067 if (!PyArg_ParseTuple(args, "Oi:EnumValue", &obKey, &index))
1068 return NULL;
1069 if (!PyHKEY_AsHKEY(obKey, &hKey, FALSE))
1070 return NULL;
1071
1072 if ((rc = RegQueryInfoKey(hKey, NULL, NULL, NULL, NULL, NULL, NULL,
1073 NULL,
1074 &retValueSize, &retDataSize, NULL, NULL))
1075 != ERROR_SUCCESS)
1076 return PyErr_SetFromWindowsErrWithFunction(rc,
1077 "RegQueryInfoKey");
1078 ++retValueSize; /* include null terminators */
1079 ++retDataSize;
Guido van Rossuma6a38ad2003-11-30 22:01:43 +00001080 retValueBuf = (char *)PyMem_Malloc(retValueSize);
1081 if (retValueBuf == NULL)
1082 return PyErr_NoMemory();
1083 retDataBuf = (char *)PyMem_Malloc(retDataSize);
1084 if (retDataBuf == NULL) {
1085 PyMem_Free(retValueBuf);
1086 return PyErr_NoMemory();
1087 }
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001088
1089 Py_BEGIN_ALLOW_THREADS
1090 rc = RegEnumValue(hKey,
1091 index,
1092 retValueBuf,
1093 &retValueSize,
1094 NULL,
1095 &typ,
1096 (BYTE *)retDataBuf,
1097 &retDataSize);
1098 Py_END_ALLOW_THREADS
1099
Guido van Rossuma6a38ad2003-11-30 22:01:43 +00001100 if (rc != ERROR_SUCCESS) {
1101 retVal = PyErr_SetFromWindowsErrWithFunction(rc,
1102 "PyRegEnumValue");
1103 goto fail;
1104 }
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001105 obData = Reg2Py(retDataBuf, retDataSize, typ);
Guido van Rossuma6a38ad2003-11-30 22:01:43 +00001106 if (obData == NULL) {
1107 retVal = NULL;
1108 goto fail;
1109 }
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001110 retVal = Py_BuildValue("sOi", retValueBuf, obData, typ);
1111 Py_DECREF(obData);
Guido van Rossuma6a38ad2003-11-30 22:01:43 +00001112 fail:
1113 PyMem_Free(retValueBuf);
1114 PyMem_Free(retDataBuf);
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001115 return retVal;
1116}
1117
1118static PyObject *
1119PyFlushKey(PyObject *self, PyObject *args)
1120{
1121 HKEY hKey;
1122 PyObject *obKey;
1123 long rc;
1124 if (!PyArg_ParseTuple(args, "O:FlushKey", &obKey))
1125 return NULL;
1126 if (!PyHKEY_AsHKEY(obKey, &hKey, FALSE))
1127 return NULL;
1128 Py_BEGIN_ALLOW_THREADS
1129 rc = RegFlushKey(hKey);
1130 Py_END_ALLOW_THREADS
1131 if (rc != ERROR_SUCCESS)
1132 return PyErr_SetFromWindowsErrWithFunction(rc, "RegFlushKey");
1133 Py_INCREF(Py_None);
1134 return Py_None;
1135}
1136static PyObject *
1137PyLoadKey(PyObject *self, PyObject *args)
1138{
1139 HKEY hKey;
1140 PyObject *obKey;
1141 char *subKey;
1142 char *fileName;
1143
1144 long rc;
1145 if (!PyArg_ParseTuple(args, "Oss:LoadKey", &obKey, &subKey, &fileName))
1146 return NULL;
1147 if (!PyHKEY_AsHKEY(obKey, &hKey, FALSE))
1148 return NULL;
1149 Py_BEGIN_ALLOW_THREADS
1150 rc = RegLoadKey(hKey, subKey, fileName );
1151 Py_END_ALLOW_THREADS
1152 if (rc != ERROR_SUCCESS)
1153 return PyErr_SetFromWindowsErrWithFunction(rc, "RegLoadKey");
1154 Py_INCREF(Py_None);
1155 return Py_None;
1156}
1157
1158static PyObject *
1159PyOpenKey(PyObject *self, PyObject *args)
1160{
1161 HKEY hKey;
1162 PyObject *obKey;
1163
1164 char *subKey;
1165 int res = 0;
1166 HKEY retKey;
1167 long rc;
1168 REGSAM sam = KEY_READ;
1169 if (!PyArg_ParseTuple(args, "Oz|ii:OpenKey", &obKey, &subKey,
1170 &res, &sam))
1171 return NULL;
1172 if (!PyHKEY_AsHKEY(obKey, &hKey, FALSE))
1173 return NULL;
1174
1175 Py_BEGIN_ALLOW_THREADS
1176 rc = RegOpenKeyEx(hKey, subKey, res, sam, &retKey);
1177 Py_END_ALLOW_THREADS
1178 if (rc != ERROR_SUCCESS)
1179 return PyErr_SetFromWindowsErrWithFunction(rc, "RegOpenKeyEx");
1180 return PyHKEY_FromHKEY(retKey);
1181}
1182
1183
1184static PyObject *
1185PyQueryInfoKey(PyObject *self, PyObject *args)
1186{
1187 HKEY hKey;
1188 PyObject *obKey;
1189 long rc;
1190 DWORD nSubKeys, nValues;
1191 FILETIME ft;
1192 LARGE_INTEGER li;
1193 PyObject *l;
1194 PyObject *ret;
1195 if (!PyArg_ParseTuple(args, "O:QueryInfoKey", &obKey))
1196 return NULL;
1197 if (!PyHKEY_AsHKEY(obKey, &hKey, FALSE))
1198 return NULL;
1199 if ((rc = RegQueryInfoKey(hKey, NULL, NULL, 0, &nSubKeys, NULL, NULL,
1200 &nValues, NULL, NULL, NULL, &ft))
1201 != ERROR_SUCCESS)
1202 return PyErr_SetFromWindowsErrWithFunction(rc, "RegQueryInfoKey");
1203 li.LowPart = ft.dwLowDateTime;
1204 li.HighPart = ft.dwHighDateTime;
1205 l = PyLong_FromLongLong(li.QuadPart);
1206 if (l == NULL)
1207 return NULL;
1208 ret = Py_BuildValue("iiO", nSubKeys, nValues, l);
1209 Py_DECREF(l);
1210 return ret;
1211}
1212
1213static PyObject *
1214PyQueryValue(PyObject *self, PyObject *args)
1215{
1216 HKEY hKey;
1217 PyObject *obKey;
1218 char *subKey;
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001219 long rc;
Guido van Rossuma6a38ad2003-11-30 22:01:43 +00001220 PyObject *retStr;
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001221 char *retBuf;
1222 long bufSize = 0;
Guido van Rossuma6a38ad2003-11-30 22:01:43 +00001223
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001224 if (!PyArg_ParseTuple(args, "Oz:QueryValue", &obKey, &subKey))
1225 return NULL;
1226
1227 if (!PyHKEY_AsHKEY(obKey, &hKey, FALSE))
1228 return NULL;
1229 if ((rc = RegQueryValue(hKey, subKey, NULL, &bufSize))
1230 != ERROR_SUCCESS)
1231 return PyErr_SetFromWindowsErrWithFunction(rc,
1232 "RegQueryValue");
Guido van Rossuma6a38ad2003-11-30 22:01:43 +00001233 retStr = PyString_FromStringAndSize(NULL, bufSize);
1234 if (retStr == NULL)
1235 return NULL;
1236 retBuf = PyString_AS_STRING(retStr);
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001237 if ((rc = RegQueryValue(hKey, subKey, retBuf, &bufSize))
Guido van Rossuma6a38ad2003-11-30 22:01:43 +00001238 != ERROR_SUCCESS) {
1239 Py_DECREF(retStr);
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001240 return PyErr_SetFromWindowsErrWithFunction(rc,
1241 "RegQueryValue");
Guido van Rossuma6a38ad2003-11-30 22:01:43 +00001242 }
1243 _PyString_Resize(&retStr, strlen(retBuf));
1244 return retStr;
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001245}
1246
1247static PyObject *
1248PyQueryValueEx(PyObject *self, PyObject *args)
1249{
1250 HKEY hKey;
1251 PyObject *obKey;
1252 char *valueName;
1253
1254 long rc;
1255 char *retBuf;
1256 DWORD bufSize = 0;
1257 DWORD typ;
1258 PyObject *obData;
1259 PyObject *result;
1260
1261 if (!PyArg_ParseTuple(args, "Oz:QueryValueEx", &obKey, &valueName))
1262 return NULL;
1263
1264 if (!PyHKEY_AsHKEY(obKey, &hKey, FALSE))
1265 return NULL;
1266 if ((rc = RegQueryValueEx(hKey, valueName,
1267 NULL, NULL, NULL,
1268 &bufSize))
1269 != ERROR_SUCCESS)
1270 return PyErr_SetFromWindowsErrWithFunction(rc,
1271 "RegQueryValueEx");
Guido van Rossuma6a38ad2003-11-30 22:01:43 +00001272 retBuf = (char *)PyMem_Malloc(bufSize);
1273 if (retBuf == NULL)
1274 return PyErr_NoMemory();
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001275 if ((rc = RegQueryValueEx(hKey, valueName, NULL,
1276 &typ, (BYTE *)retBuf, &bufSize))
Guido van Rossuma6a38ad2003-11-30 22:01:43 +00001277 != ERROR_SUCCESS) {
1278 PyMem_Free(retBuf);
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001279 return PyErr_SetFromWindowsErrWithFunction(rc,
1280 "RegQueryValueEx");
Guido van Rossuma6a38ad2003-11-30 22:01:43 +00001281 }
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001282 obData = Reg2Py(retBuf, bufSize, typ);
Guido van Rossuma6a38ad2003-11-30 22:01:43 +00001283 PyMem_Free((void *)retBuf);
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001284 if (obData == NULL)
1285 return NULL;
1286 result = Py_BuildValue("Oi", obData, typ);
1287 Py_DECREF(obData);
1288 return result;
1289}
1290
1291
1292static PyObject *
1293PySaveKey(PyObject *self, PyObject *args)
1294{
1295 HKEY hKey;
1296 PyObject *obKey;
1297 char *fileName;
1298 LPSECURITY_ATTRIBUTES pSA = NULL;
1299
1300 long rc;
1301 if (!PyArg_ParseTuple(args, "Os:SaveKey", &obKey, &fileName))
1302 return NULL;
1303 if (!PyHKEY_AsHKEY(obKey, &hKey, FALSE))
1304 return NULL;
1305/* One day we may get security into the core?
1306 if (!PyWinObject_AsSECURITY_ATTRIBUTES(obSA, &pSA, TRUE))
1307 return NULL;
1308*/
1309 Py_BEGIN_ALLOW_THREADS
1310 rc = RegSaveKey(hKey, fileName, pSA );
1311 Py_END_ALLOW_THREADS
1312 if (rc != ERROR_SUCCESS)
1313 return PyErr_SetFromWindowsErrWithFunction(rc, "RegSaveKey");
1314 Py_INCREF(Py_None);
1315 return Py_None;
1316}
1317
1318static PyObject *
1319PySetValue(PyObject *self, PyObject *args)
1320{
1321 HKEY hKey;
1322 PyObject *obKey;
1323 char *subKey;
1324 char *str;
1325 DWORD typ;
1326 DWORD len;
1327 long rc;
1328 PyObject *obStrVal;
1329 PyObject *obSubKey;
1330 if (!PyArg_ParseTuple(args, "OOiO:SetValue",
1331 &obKey,
1332 &obSubKey,
1333 &typ,
1334 &obStrVal))
1335 return NULL;
1336 if (!PyHKEY_AsHKEY(obKey, &hKey, FALSE))
1337 return NULL;
1338 if (typ != REG_SZ) {
1339 PyErr_SetString(PyExc_TypeError,
Thomas Hellere1d18f52002-12-20 20:13:35 +00001340 "Type must be _winreg.REG_SZ");
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001341 return NULL;
1342 }
1343 /* XXX - need Unicode support */
1344 str = PyString_AsString(obStrVal);
1345 if (str == NULL)
1346 return NULL;
1347 len = PyString_Size(obStrVal);
1348 if (obSubKey == Py_None)
1349 subKey = NULL;
1350 else {
1351 subKey = PyString_AsString(obSubKey);
1352 if (subKey == NULL)
1353 return NULL;
1354 }
1355 Py_BEGIN_ALLOW_THREADS
1356 rc = RegSetValue(hKey, subKey, REG_SZ, str, len+1);
1357 Py_END_ALLOW_THREADS
1358 if (rc != ERROR_SUCCESS)
1359 return PyErr_SetFromWindowsErrWithFunction(rc, "RegSetValue");
1360 Py_INCREF(Py_None);
1361 return Py_None;
1362}
1363
1364static PyObject *
1365PySetValueEx(PyObject *self, PyObject *args)
1366{
1367 HKEY hKey;
1368 PyObject *obKey;
1369 char *valueName;
1370 PyObject *obRes;
1371 PyObject *value;
1372 BYTE *data;
1373 DWORD len;
1374 DWORD typ;
1375
1376 LONG rc;
1377
1378 if (!PyArg_ParseTuple(args, "OzOiO:SetValueEx",
1379 &obKey,
1380 &valueName,
1381 &obRes,
1382 &typ,
1383 &value))
1384 return NULL;
1385 if (!PyHKEY_AsHKEY(obKey, &hKey, FALSE))
1386 return NULL;
1387 if (!Py2Reg(value, typ, &data, &len))
1388 {
1389 if (!PyErr_Occurred())
1390 PyErr_SetString(PyExc_ValueError,
1391 "Could not convert the data to the specified type.");
1392 return NULL;
1393 }
1394 Py_BEGIN_ALLOW_THREADS
1395 rc = RegSetValueEx(hKey, valueName, 0, typ, data, len);
1396 Py_END_ALLOW_THREADS
Guido van Rossumb18618d2000-05-03 23:44:39 +00001397 PyMem_DEL(data);
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001398 if (rc != ERROR_SUCCESS)
1399 return PyErr_SetFromWindowsErrWithFunction(rc,
1400 "RegSetValueEx");
1401 Py_INCREF(Py_None);
1402 return Py_None;
1403}
1404
1405static struct PyMethodDef winreg_methods[] = {
Neal Norwitz031829d2002-03-31 14:37:44 +00001406 {"CloseKey", PyCloseKey, METH_VARARGS, CloseKey_doc},
1407 {"ConnectRegistry", PyConnectRegistry, METH_VARARGS, ConnectRegistry_doc},
1408 {"CreateKey", PyCreateKey, METH_VARARGS, CreateKey_doc},
1409 {"DeleteKey", PyDeleteKey, METH_VARARGS, DeleteKey_doc},
1410 {"DeleteValue", PyDeleteValue, METH_VARARGS, DeleteValue_doc},
1411 {"EnumKey", PyEnumKey, METH_VARARGS, EnumKey_doc},
1412 {"EnumValue", PyEnumValue, METH_VARARGS, EnumValue_doc},
1413 {"FlushKey", PyFlushKey, METH_VARARGS, FlushKey_doc},
1414 {"LoadKey", PyLoadKey, METH_VARARGS, LoadKey_doc},
1415 {"OpenKey", PyOpenKey, METH_VARARGS, OpenKey_doc},
1416 {"OpenKeyEx", PyOpenKey, METH_VARARGS, OpenKeyEx_doc},
1417 {"QueryValue", PyQueryValue, METH_VARARGS, QueryValue_doc},
1418 {"QueryValueEx", PyQueryValueEx, METH_VARARGS, QueryValueEx_doc},
1419 {"QueryInfoKey", PyQueryInfoKey, METH_VARARGS, QueryInfoKey_doc},
1420 {"SaveKey", PySaveKey, METH_VARARGS, SaveKey_doc},
1421 {"SetValue", PySetValue, METH_VARARGS, SetValue_doc},
1422 {"SetValueEx", PySetValueEx, METH_VARARGS, SetValueEx_doc},
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001423 NULL,
1424};
1425
1426static void
1427insint(PyObject * d, char * name, long value)
1428{
1429 PyObject *v = PyInt_FromLong(value);
1430 if (!v || PyDict_SetItemString(d, name, v))
1431 PyErr_Clear();
1432 Py_XDECREF(v);
1433}
1434
1435#define ADD_INT(val) insint(d, #val, val)
1436
1437static void
1438inskey(PyObject * d, char * name, HKEY key)
1439{
1440 PyObject *v = PyLong_FromVoidPtr(key);
1441 if (!v || PyDict_SetItemString(d, name, v))
1442 PyErr_Clear();
1443 Py_XDECREF(v);
1444}
1445
1446#define ADD_KEY(val) inskey(d, #val, val)
1447
Mark Hammond8235ea12002-07-19 06:55:41 +00001448PyMODINIT_FUNC init_winreg(void)
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001449{
1450 PyObject *m, *d;
Fred Drake270e19b2000-06-29 16:14:14 +00001451 m = Py_InitModule3("_winreg", winreg_methods, module_doc);
Neal Norwitz1ac754f2006-01-19 06:09:39 +00001452 if (m == NULL)
1453 return;
Guido van Rossum9f3712c2000-03-28 20:37:15 +00001454 d = PyModule_GetDict(m);
1455 PyHKEY_Type.ob_type = &PyType_Type;
1456 PyHKEY_Type.tp_doc = PyHKEY_doc;
1457 Py_INCREF(&PyHKEY_Type);
1458 if (PyDict_SetItemString(d, "HKEYType",
1459 (PyObject *)&PyHKEY_Type) != 0)
1460 return;
1461 Py_INCREF(PyExc_WindowsError);
1462 if (PyDict_SetItemString(d, "error",
1463 PyExc_WindowsError) != 0)
1464 return;
1465
1466 /* Add the relevant constants */
1467 ADD_KEY(HKEY_CLASSES_ROOT);
1468 ADD_KEY(HKEY_CURRENT_USER);
1469 ADD_KEY(HKEY_LOCAL_MACHINE);
1470 ADD_KEY(HKEY_USERS);
1471 ADD_KEY(HKEY_PERFORMANCE_DATA);
1472#ifdef HKEY_CURRENT_CONFIG
1473 ADD_KEY(HKEY_CURRENT_CONFIG);
1474#endif
1475#ifdef HKEY_DYN_DATA
1476 ADD_KEY(HKEY_DYN_DATA);
1477#endif
1478 ADD_INT(KEY_QUERY_VALUE);
1479 ADD_INT(KEY_SET_VALUE);
1480 ADD_INT(KEY_CREATE_SUB_KEY);
1481 ADD_INT(KEY_ENUMERATE_SUB_KEYS);
1482 ADD_INT(KEY_NOTIFY);
1483 ADD_INT(KEY_CREATE_LINK);
1484 ADD_INT(KEY_READ);
1485 ADD_INT(KEY_WRITE);
1486 ADD_INT(KEY_EXECUTE);
1487 ADD_INT(KEY_ALL_ACCESS);
1488 ADD_INT(REG_OPTION_RESERVED);
1489 ADD_INT(REG_OPTION_NON_VOLATILE);
1490 ADD_INT(REG_OPTION_VOLATILE);
1491 ADD_INT(REG_OPTION_CREATE_LINK);
1492 ADD_INT(REG_OPTION_BACKUP_RESTORE);
1493 ADD_INT(REG_OPTION_OPEN_LINK);
1494 ADD_INT(REG_LEGAL_OPTION);
1495 ADD_INT(REG_CREATED_NEW_KEY);
1496 ADD_INT(REG_OPENED_EXISTING_KEY);
1497 ADD_INT(REG_WHOLE_HIVE_VOLATILE);
1498 ADD_INT(REG_REFRESH_HIVE);
1499 ADD_INT(REG_NO_LAZY_FLUSH);
1500 ADD_INT(REG_NOTIFY_CHANGE_NAME);
1501 ADD_INT(REG_NOTIFY_CHANGE_ATTRIBUTES);
1502 ADD_INT(REG_NOTIFY_CHANGE_LAST_SET);
1503 ADD_INT(REG_NOTIFY_CHANGE_SECURITY);
1504 ADD_INT(REG_LEGAL_CHANGE_FILTER);
1505 ADD_INT(REG_NONE);
1506 ADD_INT(REG_SZ);
1507 ADD_INT(REG_EXPAND_SZ);
1508 ADD_INT(REG_BINARY);
1509 ADD_INT(REG_DWORD);
1510 ADD_INT(REG_DWORD_LITTLE_ENDIAN);
1511 ADD_INT(REG_DWORD_BIG_ENDIAN);
1512 ADD_INT(REG_LINK);
1513 ADD_INT(REG_MULTI_SZ);
1514 ADD_INT(REG_RESOURCE_LIST);
1515 ADD_INT(REG_FULL_RESOURCE_DESCRIPTOR);
1516 ADD_INT(REG_RESOURCE_REQUIREMENTS_LIST);
1517}
1518