source: trunk/src/kernel32/registry.cpp@ 21455

Last change on this file since 21455 was 21302, checked in by ydario, 16 years ago

Kernel32 updates.

File size: 52.7 KB
Line 
1/* $Id: registry.cpp,v 1.22 2004-10-08 08:41:13 cinc Exp $ */
2
3/*
4 * Win32 registry API functions for OS/2
5 *
6 * 1998/06/12
7 *
8 * Copyright 1998 Sander van Leeuwen
9 * Copyright 1998 Patrick Haller
10 *
11 *
12 * TODO: Many unicode apis are still wrong (missing unicode conversions and wrong sizes)!!!!!
13 *
14 * Project Odin Software License can be found in LICENSE.TXT
15 *
16 */
17
18
19/*****************************************************************************
20 * Includes *
21 *****************************************************************************/
22
23#include <odin.h>
24#include <odinwrap.h>
25#include <os2sel.h>
26
27#include <os2win.h>
28#include <stdlib.h>
29#include <stdarg.h>
30#include <string.h>
31#include <odinwrap.h>
32#include <misc.h>
33#include "unicode.h"
34#include <winreg.h>
35#include <heapstring.h>
36
37#define DBG_LOCALLOG DBG_registry
38#include "dbglocal.h"
39
40
41ODINDEBUGCHANNEL(ADVAPI32-REGISTRY)
42
43
44/*****************************************************************************
45 * Defines *
46 *****************************************************************************/
47
48 /* this define enables certain less important debug messages */
49//#define DEBUG_LOCAL 1
50
51
52static HKEY hKeyClassesRoot = HKEY_CLASSES_ROOT_O32;
53static HKEY hKeyCurrentUser = HKEY_CURRENT_USER_O32;
54static HKEY hKeyLocalMachine = HKEY_LOCAL_MACHINE_O32;
55static HKEY hKeyUsers = HKEY_USERS_O32;
56
57/*****************************************************************************
58 * Name : Convert Key
59 * Purpose : convert key handle values between win32 and os/2
60 * Parameters: HKEY winkey - the win32 key handle value
61 * Variables :
62 * Result : the os/2 warp registry key handle value
63 * Remark :
64 * Status : UNTESTED STUB
65 *
66 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
67 *****************************************************************************/
68
69static HKEY ConvertKey(HKEY winkey)
70{
71 switch((DWORD)winkey)
72 {
73 case HKEY_CLASSES_ROOT: return hKeyClassesRoot;
74 case HKEY_CURRENT_USER: return hKeyCurrentUser;
75 case HKEY_LOCAL_MACHINE: return hKeyLocalMachine;
76 case HKEY_USERS: return hKeyUsers;
77 }
78 return(winkey);
79}
80
81void WIN32API SetRegistryRootKey(HKEY hRootkey, HKEY hKey)
82{
83 switch((DWORD)hRootkey)
84 {
85 case HKEY_CLASSES_ROOT:
86 hKeyClassesRoot = hKey;
87 break;
88 case HKEY_CURRENT_USER:
89 hKeyCurrentUser = hKey;
90 break;
91 case HKEY_LOCAL_MACHINE:
92 hKeyLocalMachine = hKey;
93 break;
94 case HKEY_USERS:
95 hKeyUsers = hKey;
96 break;
97 }
98}
99
100/*****************************************************************************
101 * Name :
102 * Purpose :
103 * Parameters:
104 * Variables :
105 * Result :
106 * Remark :
107 * Status : CORRECTED UNTESTED
108 *
109 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
110 *****************************************************************************/
111
112LONG WIN32API RegCloseKey(HKEY hKey)
113{
114 switch(hKey)
115 {//Closing a root key should just return success (matters for custom builds)
116 case HKEY_CLASSES_ROOT:
117 case HKEY_CURRENT_USER:
118 case HKEY_LOCAL_MACHINE:
119 case HKEY_USERS:
120 return 0;
121 }
122 return O32_RegCloseKey(ConvertKey(hKey));
123}
124
125
126/*****************************************************************************
127 * Name :
128 * Purpose :
129 * Parameters:
130 * Variables :
131 * Result :
132 * Remark :
133 * Status : CORRECTED UNTESTED
134 *
135 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
136 *****************************************************************************/
137
138LONG WIN32API RegCreateKeyA(HKEY hKey, LPCSTR lpszSubKey, PHKEY phkResult)
139{
140 dprintf(("RegCreateKeyA %x %s", hKey, lpszSubKey));
141 return O32_RegCreateKey(ConvertKey(hKey),
142 lpszSubKey,
143 phkResult);
144}
145
146
147/*****************************************************************************
148 * Name :
149 * Purpose :
150 * Parameters:
151 * Variables :
152 * Result :
153 * Remark :
154 * Status : CORRECTED UNTESTED
155 *
156 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
157 *****************************************************************************/
158
159LONG WIN32API RegCreateKeyW(HKEY hKey, LPCWSTR lpszSubKey, PHKEY phkResult)
160{
161 char *astring = UnicodeToAsciiString((LPWSTR)lpszSubKey);
162 LONG rc;
163
164 dprintf(("RegCreateKeyW %x %s", hKey, astring));
165 rc = O32_RegCreateKey(ConvertKey(hKey),
166 astring,
167 phkResult);
168
169 if (NULL != astring)
170 FreeAsciiString(astring);
171
172 return(rc);
173}
174
175
176/*****************************************************************************
177 * Name :
178 * Purpose :
179 * Parameters:
180 * Variables :
181 * Result :
182 * Remark :
183 * Status : CORRECTED UNTESTED
184 *
185 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
186 *****************************************************************************/
187
188LONG WIN32API RegCreateKeyExA(HKEY hKey,
189 LPCSTR lpszSubKey,
190 DWORD dwReserved,
191 LPSTR lpszClass,
192 DWORD fdwOptions,
193 REGSAM samDesired,
194 LPSECURITY_ATTRIBUTES lpSecurityAttributes,
195 PHKEY phkResult,
196 LPDWORD lpdwDisposition)
197{
198 dprintf(("RegCreateKeyExA %x %s", hKey, lpszSubKey));
199
200 return O32_RegCreateKeyEx(ConvertKey(hKey),
201 lpszSubKey,
202 dwReserved,
203 lpszClass,
204 fdwOptions,
205 samDesired, // | KEY_READ
206 lpSecurityAttributes,
207 phkResult,
208 lpdwDisposition);
209}
210
211
212/*****************************************************************************
213 * Name :
214 * Purpose :
215 * Parameters:
216 * Variables :
217 * Result :
218 * Remark :
219 * Status : CORRECTED UNTESTED
220 *
221 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
222 *****************************************************************************/
223
224LONG WIN32API RegCreateKeyExW(HKEY hKey,
225 LPCWSTR lpszSubKey,
226 DWORD dwReserved,
227 LPWSTR lpszClass,
228 DWORD fdwOptions,
229 REGSAM samDesired,
230 LPSECURITY_ATTRIBUTES lpSecurityAttributes,
231 PHKEY phkResult,
232 LPDWORD lpdwDisposition)
233{
234 char *astring1 = UnicodeToAsciiString((LPWSTR)lpszSubKey);
235 char *astring2 = UnicodeToAsciiString(lpszClass);
236 LONG rc;
237
238 dprintf(("RegCreateKeyExW %x %s", hKey, astring1));
239
240 rc = O32_RegCreateKeyEx(ConvertKey(hKey),
241 astring1,
242 dwReserved,
243 astring2,
244 fdwOptions,
245 samDesired, // | KEY_READ
246 lpSecurityAttributes,
247 phkResult,
248 lpdwDisposition);
249
250 if (NULL != astring1)
251 FreeAsciiString(astring1);
252
253 if (NULL != astring2)
254 FreeAsciiString(astring2);
255
256 return(rc);
257}
258
259
260/*****************************************************************************
261 * Name :
262 * Purpose :
263 * Parameters:
264 * Variables :
265 * Result :
266 * Remark :
267 * Status : CORRECTED UNTESTED
268 *
269 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
270 *****************************************************************************/
271
272LONG WIN32API RegDeleteKeyW(HKEY hKey, LPCWSTR lpszSubKey)
273{
274 char *astring = UnicodeToAsciiString(lpszSubKey);
275 LONG rc;
276
277 dprintf(("RegDeleteKeyW %s", astring));
278 rc = O32_RegDeleteKey(ConvertKey(hKey),
279 astring);
280
281 if (NULL != astring)
282 FreeAsciiString(astring);
283
284 return(rc);
285}
286
287
288/*****************************************************************************
289 * Name :
290 * Purpose :
291 * Parameters:
292 * Variables :
293 * Result :
294 * Remark :
295 * Status : CORRECTED UNTESTED
296 *
297 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
298 *****************************************************************************/
299
300LONG WIN32API RegDeleteKeyA(HKEY hKey, LPCSTR lpszSubKey)
301{
302 dprintf(("RegDeleteKeyW %s", lpszSubKey));
303 return O32_RegDeleteKey(ConvertKey(hKey), lpszSubKey);
304}
305
306
307/*****************************************************************************
308 * Name :
309 * Purpose :
310 * Parameters:
311 * Variables :
312 * Result :
313 * Remark :
314 * Status : CORRECTED UNTESTED
315 *
316 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
317 *****************************************************************************/
318
319LONG WIN32API RegDeleteValueA(HKEY hKey, LPSTR lpszValue)
320{
321 return O32_RegDeleteValue(ConvertKey(hKey),
322 lpszValue);
323}
324
325
326/*****************************************************************************
327 * Name :
328 * Purpose :
329 * Parameters:
330 * Variables :
331 * Result :
332 * Remark :
333 * Status : CORRECTED UNTESTED
334 *
335 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
336 *****************************************************************************/
337
338LONG WIN32API RegDeleteValueW(HKEY hKey, LPWSTR lpszValue)
339{
340 char *astring = UnicodeToAsciiString(lpszValue);
341 LONG rc;
342
343 rc = O32_RegDeleteValue(ConvertKey(hKey),
344 astring);
345
346 if (NULL != astring)
347 FreeAsciiString(astring);
348
349 return(rc);
350}
351
352
353/*****************************************************************************
354 * Name :
355 * Purpose :
356 * Parameters:
357 * Variables :
358 * Result :
359 * Remark :
360 * Status : UNTESTED STUB
361 *
362 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
363 *****************************************************************************/
364
365LONG WIN32API RegEnumKeyA(HKEY hKey, DWORD iSubKey, LPSTR lpszName,
366 DWORD cchName)
367{
368 return O32_RegEnumKey(ConvertKey(hKey),
369 iSubKey,
370 lpszName,
371 cchName);
372}
373
374
375/*****************************************************************************
376 * Name :
377 * Purpose :
378 * Parameters:
379 * Variables :
380 * Result :
381 * Remark :
382 * Status : UNTESTED STUB
383 *
384 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
385 *****************************************************************************/
386
387LONG WIN32API RegEnumKeyW(HKEY hKey, DWORD iSubKey, LPWSTR lpszName,
388 DWORD cchName)
389{
390 char *astring;
391 LONG rc;
392
393 rc = O32_RegEnumKey(ConvertKey(hKey),
394 iSubKey,
395 (char *)lpszName,
396 cchName);
397 if(rc == ERROR_SUCCESS)
398 {
399 astring = (char *)malloc(cchName);
400 strcpy(astring, (char *)lpszName);
401 AsciiToUnicode(astring, lpszName);
402 free(astring);
403 }
404 return(rc);
405}
406
407
408/*****************************************************************************
409 * Name :
410 * Purpose :
411 * Parameters:
412 * Variables :
413 * Result :
414 * Remark :
415 * Status : UNTESTED STUB
416 *
417 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
418 *****************************************************************************/
419
420LONG WIN32API RegEnumKeyExA(HKEY arg1,
421 DWORD arg2,
422 LPSTR arg3,
423 LPDWORD arg4,
424 LPDWORD arg5,
425 LPSTR arg6,
426 LPDWORD arg7,
427 LPFILETIME arg8)
428{
429 return O32_RegEnumKeyEx(ConvertKey(arg1),
430 arg2,
431 arg3,
432 arg4,
433 arg5,
434 arg6,
435 arg7,
436 arg8);
437}
438
439
440/*****************************************************************************
441 * Name :
442 * Purpose :
443 * Parameters:
444 * Variables :
445 * Result :
446 * Remark :
447 * Status : UNTESTED STUB
448 *
449 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
450 *****************************************************************************/
451
452LONG WIN32API RegEnumKeyExW(HKEY hKey,
453 DWORD iSubkey,
454 LPWSTR lpszName,
455 LPDWORD lpcchName,
456 LPDWORD lpdwReserved,
457 LPWSTR lpszClass,
458 LPDWORD lpcchClass,
459 LPFILETIME lpffLastWrite)
460{
461 char *astring;
462 LONG rc;
463
464 rc = O32_RegEnumKeyEx(ConvertKey(hKey),
465 iSubkey,
466 (char *)lpszName,
467 lpcchName,
468 lpdwReserved,
469 (char *)lpszClass,
470 lpcchClass,
471 lpffLastWrite);
472 if(rc == ERROR_SUCCESS)
473 {
474 astring = (char *)malloc(max(*lpcchName+1, (lpcchClass) ? (*lpcchClass+1) : 0)); //class & keyname
475 strcpy(astring, (char *)lpszName);
476 AsciiToUnicode(astring, lpszName);
477 if(lpszClass != NULL)
478 {
479 strcpy(astring, (char *)lpszClass);
480 AsciiToUnicode(astring, lpszClass);
481 }
482 free(astring);
483 }
484 return(rc);
485}
486
487
488/*****************************************************************************
489 * Name :
490 * Purpose :
491 * Parameters:
492 * Variables :
493 * Result :
494 * Remark :
495 * Status : UNTESTED STUB
496 *
497 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
498 *****************************************************************************/
499
500LONG WIN32API RegEnumValueA(HKEY arg1,
501 DWORD arg2,
502 LPSTR arg3,
503 LPDWORD arg4,
504 LPDWORD arg5,
505 LPDWORD arg6,
506 LPBYTE arg7,
507 LPDWORD arg8)
508{
509 return O32_RegEnumValue(ConvertKey(arg1),
510 arg2,
511 arg3,
512 arg4,
513 arg5,
514 arg6,
515 arg7,
516 arg8);
517}
518
519
520/*****************************************************************************
521 * Name :
522 * Purpose :
523 * Parameters:
524 * Variables :
525 * Result :
526 * Remark :
527 * Status : UNTESTED STUB
528 *
529 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
530 *****************************************************************************/
531
532LONG WIN32API RegEnumValueW(HKEY hkey,
533 DWORD iValue,
534 LPWSTR lpszValue,
535 LPDWORD lpcchValue,
536 LPDWORD lpdwReserved,
537 LPDWORD lpdwType,
538 LPBYTE lpbData,
539 LPDWORD lpcbData)
540{
541 char *astring;
542 LONG rc, oldsize = 0;
543
544 if(lpcbData) {
545 oldsize = *lpcbData;
546 }
547 rc = O32_RegEnumValue(ConvertKey(hkey),
548 iValue,
549 (char *)lpszValue,
550 lpcchValue,
551 lpdwReserved,
552 lpdwType,
553 lpbData,
554 lpcbData);
555 if(rc == ERROR_SUCCESS)
556 {
557 astring = (char *)malloc(*lpcchValue+1); //+ 0 terminator
558 strcpy(astring, (char *)lpszValue);
559 AsciiToUnicode(astring, lpszValue);
560 free(astring);
561
562 if(lpcbData && lpbData)
563 {
564 switch(*lpdwType) {
565 case REG_SZ:
566 case REG_EXPAND_SZ:
567 if(oldsize < *lpcbData*sizeof(WCHAR)) {
568 *lpcbData = *lpcbData*sizeof(WCHAR);
569 return ERROR_MORE_DATA;
570 }
571 astring = (char *)malloc(*lpcbData);
572 strcpy(astring, (char *)lpbData);
573 lstrcpyAtoW((LPWSTR)lpbData, astring);
574 free(astring);
575 break;
576 case REG_MULTI_SZ:
577 case REG_LINK: //???
578 dprintf(("ERROR: key data must be translated from Unicode to Ascii!!"));
579 break;
580 default:
581 break;
582 }
583 }
584
585 }
586 return(rc);
587}
588
589
590/*****************************************************************************
591 * Name :
592 * Purpose :
593 * Parameters:
594 * Variables :
595 * Result :
596 * Remark :
597 * Status : UNTESTED STUB
598 *
599 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
600 *****************************************************************************/
601
602LONG WIN32API RegOpenKeyA(HKEY hKey, LPCSTR arg2, PHKEY arg3)
603{
604 LONG rc;
605
606 dprintf(("RegOpenKey %s", arg2));
607
608 rc = O32_RegOpenKey(ConvertKey(hKey),
609 arg2,
610 arg3);
611 if(rc)
612 *arg3 = 0;
613
614 return(rc);
615}
616
617
618/*****************************************************************************
619 * Name :
620 * Purpose :
621 * Parameters:
622 * Variables :
623 * Result :
624 * Remark :
625 * Status : UNTESTED STUB
626 *
627 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
628 *****************************************************************************/
629
630LONG WIN32API RegOpenKeyW(HKEY hKey, LPCWSTR arg2, PHKEY arg3)
631{
632 char *astring = UnicodeToAsciiString((LPWSTR)arg2);
633 LONG rc;
634
635 rc = O32_RegOpenKey(ConvertKey(hKey),
636 astring,
637 arg3);
638 if(rc)
639 *arg3 = 0;
640
641 if (NULL != astring)
642 FreeAsciiString(astring);
643
644 return(rc);
645}
646
647
648/*****************************************************************************
649 * Name :
650 * Purpose :
651 * Parameters:
652 * Variables :
653 * Result :
654 * Remark :
655 * Status : UNTESTED STUB
656 *
657 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
658 *****************************************************************************/
659
660LONG WIN32API RegOpenKeyExA(HKEY hKey, LPCSTR arg2, DWORD arg3,
661 REGSAM arg4, PHKEY arg5)
662{
663 LONG rc;
664
665 dprintf(("RegOpenKeyEx %s", arg2));
666 rc = O32_RegOpenKeyEx(ConvertKey(hKey),
667 arg2,
668 arg3,
669 arg4,
670 arg5);
671
672 //SvL: This fixes crashes in pmwinx.dll. (if an app doesn't check the
673 // return value and uses the whatever *arg5 contains)
674 if(rc)
675 *arg5 = 0;
676
677 return(rc);
678}
679
680
681/*****************************************************************************
682 * Name :
683 * Purpose :
684 * Parameters:
685 * Variables :
686 * Result :
687 * Remark :
688 * Status : UNTESTED STUB
689 *
690 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
691 *****************************************************************************/
692
693LONG WIN32API RegOpenKeyExW(HKEY arg1,
694 LPCWSTR arg2,
695 DWORD arg3,
696 REGSAM arg4,
697 PHKEY arg5)
698{
699 char *astring = UnicodeToAsciiString((LPWSTR)arg2);
700 LONG rc;
701
702 rc = RegOpenKeyExA(arg1, astring, arg3, arg4, arg5);
703 //SvL: This fixes crashes in pmwinx.dll. (if an app doesn't check the
704 // return value and uses the whatever *arg5 contains)
705 if(rc)
706 *arg5 = 0;
707
708 if (NULL != astring)
709 FreeAsciiString(astring);
710
711 return(rc);
712}
713
714
715/*****************************************************************************
716 * Name :
717 * Purpose :
718 * Parameters:
719 * Variables :
720 * Result :
721 * Remark :
722 * Status : UNTESTED STUB
723 *
724 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
725 *****************************************************************************/
726
727LONG WIN32API RegQueryInfoKeyA(HKEY hkey,
728 LPSTR lpszClass,
729 LPDWORD lpcchClass,
730 LPDWORD lpdwReserved,
731 LPDWORD lpcSubKeys,
732 LPDWORD lpcchMaxSubKey,
733 LPDWORD lpcchMaxClass,
734 LPDWORD lpcValues,
735 LPDWORD lpcchMaxValueName,
736 LPDWORD lpcbMaxValueData,
737 LPDWORD lpcbSecurityDescriptor,
738 LPFILETIME lpftLastWriteTime)
739{
740 return O32_RegQueryInfoKey(ConvertKey(hkey), lpszClass,
741 lpcchClass, lpdwReserved, lpcSubKeys,
742 lpcchMaxSubKey, lpcchMaxClass, lpcValues,
743 lpcchMaxValueName, lpcbMaxValueData,
744 lpcbSecurityDescriptor,lpftLastWriteTime);
745}
746
747
748/*****************************************************************************
749 * Name :
750 * Purpose :
751 * Parameters:
752 * Variables :
753 * Result :
754 * Remark :
755 * Status : UNTESTED STUB
756 *
757 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
758 *****************************************************************************/
759
760LONG WIN32API RegQueryInfoKeyW(HKEY hkey,
761 LPWSTR lpszClass,
762 LPDWORD lpcchClass,
763 LPDWORD lpdwReserved,
764 LPDWORD lpcSubKeys,
765 LPDWORD lpcchMaxSubKey,
766 LPDWORD lpcchMaxClass,
767 LPDWORD lpcValues,
768 LPDWORD lpcchMaxValueName,
769 LPDWORD lpcbMaxValueData,
770 LPDWORD lpcbSecurityDescriptor,
771 LPFILETIME lpftLastWriteTime)
772{
773 LONG rc;
774
775 rc = O32_RegQueryInfoKey(ConvertKey(hkey), (char *)lpszClass,
776 lpcchClass, lpdwReserved, lpcSubKeys,
777 lpcchMaxSubKey, lpcchMaxClass, lpcValues,
778 lpcchMaxValueName, lpcbMaxValueData,
779 lpcbSecurityDescriptor,lpftLastWriteTime);
780 if(rc == ERROR_SUCCESS)
781 {
782 if(lpcchClass && *lpcchClass) {
783 char *astring = (char *)malloc(*lpcchClass+1); //returned length does NOT include 0 terminator
784 strcpy(astring, (char *)lpszClass);
785 AsciiToUnicode(astring, lpszClass);
786 free(astring);
787 }
788 else
789 if(lpszClass) *lpszClass = 0;
790 }
791 //TODO: lpcbMaxValueData could be wrong for string key values!!! (as it's in bytes)
792 return(rc);
793}
794
795
796/*****************************************************************************
797 * Name :
798 * Purpose :
799 * Parameters:
800 * Variables :
801 * Result :
802 * Remark :
803 * Status : UNTESTED STUB
804 *
805 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
806 *****************************************************************************/
807
808LONG WIN32API RegQueryValueA(HKEY arg1,
809 LPCSTR arg2,
810 LPSTR arg3,
811 PLONG arg4)
812{
813 dprintf(("ADVAPI32:Registry key=%s\n",
814 arg2));
815 return O32_RegQueryValue(ConvertKey(arg1),
816 arg2,
817 arg3,
818 arg4);
819}
820
821
822/*****************************************************************************
823 * Name :
824 * Purpose :
825 * Parameters:
826 * Variables :
827 * Result :
828 * Remark :
829 * Status : UNTESTED STUB
830 *
831 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
832 *****************************************************************************/
833
834LONG WIN32API RegQueryValueW(HKEY hkey,
835 LPCWSTR lpszSubKey,
836 LPWSTR lpszValue,
837 PLONG pcbValue)
838{
839 char *astring1 = UnicodeToAsciiString((LPWSTR)lpszSubKey);
840 char *astring2;
841 LONG rc;
842
843 rc = RegQueryValueA(hkey, astring1, (char *)lpszValue, pcbValue);
844 if(rc == ERROR_SUCCESS)
845 {
846 if(pcbValue) {
847 astring2 = (char *)malloc(*pcbValue); //includes 0 terminator
848 strcpy(astring2, (char *)lpszValue);
849 AsciiToUnicode(astring2, lpszValue);
850 free(astring2);
851 }
852 }
853
854 if((rc == ERROR_SUCCESS || rc == ERROR_MORE_DATA) &&
855 pcbValue)
856 {
857 *pcbValue = *pcbValue * sizeof(WCHAR); //size in bytes!!
858 }
859
860 if (NULL != astring1)
861 FreeAsciiString(astring1);
862
863 return(rc);
864}
865
866
867/*****************************************************************************
868 * Name :
869 * Purpose :
870 * Parameters:
871 * Variables :
872 * Result :
873 * Remark :
874 * Status : UNTESTED STUB
875 *
876 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
877 *****************************************************************************/
878
879LONG WIN32API RegQueryValueExA(HKEY hkey,
880 LPCSTR lpszValueName,
881 LPDWORD lpdwReserved,
882 LPDWORD lpdwType,
883 LPBYTE lpbData,
884 LPDWORD lpcbData)
885{
886 LONG ret;
887 DWORD dwType = 0;
888
889 dprintf(("ADVAPI32:Registry key=%s", lpszValueName));
890
891 if(lpdwType == NULL) {
892 lpdwType = &dwType;
893 }
894 ret = O32_RegQueryValueEx(ConvertKey(hkey),
895 lpszValueName,
896 lpdwReserved,
897 lpdwType,
898 lpbData,
899 lpcbData);
900
901 if(ret == 0) {
902 if(lpdwType) dprintf(("key type: %x", *lpdwType));
903 if(lpcbData) dprintf(("key length: %d", *lpcbData));
904 }
905 if(ret == 0 || ret == ERROR_MORE_DATA) {
906 //TODO:!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
907 // Probably the same bug for some other key types (binary, multi_sz, REG_EXPAND_SZ)
908 if(*lpdwType == REG_SZ && (lpbData == NULL || ret == ERROR_MORE_DATA) && lpcbData) {
909 dprintf(("Get the real size of the string key data"));
910 //Get the real size of the string key data
911 //not a nice fix; hope this is enough (there is no clear connection
912 //between returned length and real string length (not linear for different
913 //string sizes))
914 *lpcbData = 4096;
915 lpbData = (LPBYTE)malloc(*lpcbData);
916 if(lpcbData) {
917 //don't overwrite return value (in case it was ERROR_MODE_DATA)
918 O32_RegQueryValueEx(ConvertKey(hkey),
919 lpszValueName,
920 lpdwReserved,
921 lpdwType,
922 lpbData,
923 lpcbData);
924 if(lpcbData) dprintf(("real key length: %d", *lpcbData));
925 free(lpbData);
926 }
927 }
928 }
929 return ret;
930}
931
932
933/*****************************************************************************
934 * Name :
935 * Purpose :
936 * Parameters:
937 * Variables :
938 * Result :
939 * Remark : TODO: DOESN'T WORK FOR STRING DATA!!
940 * Status : UNTESTED STUB
941 *
942 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
943 *****************************************************************************/
944
945LONG WIN32API RegQueryValueExW(HKEY hkey,
946 LPCWSTR lpszValueName,
947 LPDWORD lpdwReserved,
948 LPDWORD lpdwType,
949 LPBYTE lpbData,
950 LPDWORD lpcbData)
951{
952 char *astring = UnicodeToAsciiString(lpszValueName);
953 char *akeydata = NULL;
954 LONG rc;
955 DWORD dwType;
956
957 if(lpbData && lpcbData)
958 {
959 akeydata = (char *)malloc(*lpcbData+1);
960 akeydata[*lpcbData] = 0;
961 }
962
963 if(lpdwType == NULL) {
964 lpdwType = &dwType;
965 }
966
967 rc = RegQueryValueExA(hkey, astring, lpdwReserved, lpdwType,
968 (LPBYTE)akeydata, lpcbData);
969 //could also query key type (without returning data), call it again and only allocate translation
970 //buffer if string type
971 if(rc == ERROR_SUCCESS && lpbData && lpcbData)
972 {
973 switch(*lpdwType) {
974 case REG_SZ:
975 case REG_EXPAND_SZ:
976 lstrcpyAtoW((LPWSTR)lpbData, akeydata);
977 break;
978 case REG_MULTI_SZ:
979 case REG_LINK: //???
980 dprintf(("ERROR: key data must be translated from Unicode to Ascii!!"));
981 break;
982 default:
983 memcpy(lpbData, akeydata, *lpcbData);
984 break;
985 }
986 }
987
988 if((rc == ERROR_SUCCESS || rc == ERROR_MORE_DATA) &&
989 lpcbData)
990 {
991 switch(*lpdwType) {
992 case REG_SZ:
993 case REG_EXPAND_SZ:
994 case REG_MULTI_SZ:
995 case REG_LINK: //???
996 *lpcbData = *lpcbData * sizeof(WCHAR); //size in bytes!!
997 break;
998 }
999 }
1000
1001 if (NULL != astring)
1002 FreeAsciiString(astring);
1003
1004 if(akeydata)
1005 free(akeydata);
1006
1007 return(rc);
1008}
1009
1010
1011/*****************************************************************************
1012 * Name :
1013 * Purpose :
1014 * Parameters:
1015 * Variables :
1016 * Result :
1017 * Remark :
1018 * Status : UNTESTED STUB
1019 *
1020 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1021 *****************************************************************************/
1022
1023LONG WIN32API RegSetValueA(HKEY hkey,
1024 LPCSTR lpSubKey,
1025 DWORD dwType,
1026 LPCSTR lpData,
1027 DWORD cbData)
1028{
1029 LONG rc;
1030
1031 //SvL: 8-11-'97: Bugfix: crash in pmwinx if size == 0 and string is large
1032 if(cbData == 0)
1033 cbData = strlen(lpData);
1034
1035 rc = O32_RegSetValue(ConvertKey(hkey), lpSubKey,
1036 dwType, lpData, cbData);
1037
1038 if(rc == ERROR_NOT_ENOUGH_MEMORY && cbData == 0 && dwType == REG_SZ)
1039 {
1040 char regdata = 0;
1041 //SvL: Netscape sets an empty string key this way; Open32 doesn't like it
1042 rc = O32_RegSetValue(ConvertKey(hkey),
1043 lpSubKey,
1044 dwType,
1045 &regdata,
1046 1);
1047 }
1048 return rc;
1049}
1050
1051
1052/*****************************************************************************
1053 * Name :
1054 * Purpose :
1055 * Parameters:
1056 * Variables :
1057 * Result :
1058 * Remark :
1059 * Status : UNTESTED STUB
1060 *
1061 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1062 *****************************************************************************/
1063
1064LONG WIN32API RegSetValueW(HKEY hkey,
1065 LPCWSTR lpSubKey,
1066 DWORD dwType,
1067 LPCWSTR lpData,
1068 DWORD cbData)
1069{
1070 char *astring1 = UnicodeToAsciiString((LPWSTR)lpSubKey);
1071 char *astring2 = UnicodeToAsciiString((LPWSTR)lpData);
1072 LONG rc;
1073
1074 rc = RegSetValueA(hkey, astring1, dwType, astring2, cbData);
1075
1076 if (NULL != astring1)
1077 FreeAsciiString(astring1);
1078
1079 if (NULL != astring2)
1080 FreeAsciiString(astring2);
1081
1082 return(rc);
1083}
1084
1085
1086/*****************************************************************************
1087 * Name :
1088 * Purpose :
1089 * Parameters:
1090 * Variables :
1091 * Result :
1092 * Remark : TODO:Check for string length here too?
1093 * Status : UNTESTED STUB
1094 *
1095 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1096 *****************************************************************************/
1097
1098LONG WIN32API RegSetValueExA(HKEY hkey,
1099 LPCSTR lpszValueName,
1100 DWORD dwReserved,
1101 DWORD fdwType,
1102 BYTE* lpbData,
1103 DWORD cbData)
1104{
1105 LPSTR lpszExpandedString = NULL;
1106 LONG ret;
1107
1108 if(fdwType == REG_SZ || fdwType == REG_EXPAND_SZ) {
1109 dprintf(("ADVAPI32: RegSetValueExA)%08xh,%s,%08xh,%08xh,%s,%08xh)",
1110 hkey,
1111 lpszValueName,
1112 dwReserved,
1113 fdwType,
1114 lpbData,
1115 cbData));
1116 }
1117 else {
1118 dprintf(("ADVAPI32: RegSetValueExA)%08xh,%s,%08xh,%08xh,%08xh,%08xh)",
1119 hkey,
1120 lpszValueName,
1121 dwReserved,
1122 fdwType,
1123 lpbData,
1124 cbData));
1125 }
1126
1127 if(fdwType == REG_EXPAND_SZ) {
1128 dprintf(("!WARNING!: REG_EXPAND_SZ converted to REG_SZ"));
1129 fdwType = REG_SZ; //registry.dll doesn't like this type
1130
1131 //Expand string
1132 lpszExpandedString = (LPSTR)malloc(cbData);
1133 if(lpszExpandedString == NULL) {
1134 DebugInt3();
1135 return ERROR_NOT_ENOUGH_MEMORY;
1136 }
1137 ExpandEnvironmentStringsA((LPSTR)lpbData, lpszExpandedString, cbData);
1138 lpbData = (BYTE *)lpszExpandedString;
1139 cbData = strlen(lpszExpandedString)+1;
1140 dprintf(("Expanded to: %s", lpszExpandedString));
1141 }
1142 ret = O32_RegSetValueEx(ConvertKey(hkey), lpszValueName, dwReserved,
1143 fdwType, lpbData, cbData);
1144
1145 if(lpszExpandedString) free(lpszExpandedString);
1146
1147 return ret;
1148}
1149
1150
1151/*****************************************************************************
1152 * Name :
1153 * Purpose :
1154 * Parameters:
1155 * Variables :
1156 * Result :
1157 * Remark : TODO:Check for string length here too?
1158 * Status : UNTESTED STUB
1159 *
1160 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1161 *****************************************************************************/
1162
1163LONG WIN32API RegSetValueExW(HKEY hkey,
1164 LPCWSTR lpszValueName,
1165 DWORD dwReserved,
1166 DWORD fdwType,
1167 BYTE* lpbData,
1168 DWORD cbData)
1169{
1170 char *astring = UnicodeToAsciiString(lpszValueName);
1171 char *akeydata = NULL;
1172 LONG rc;
1173
1174 switch(fdwType) {
1175 case REG_SZ:
1176 case REG_EXPAND_SZ:
1177 akeydata = UnicodeToAsciiString((LPWSTR)lpbData);
1178 lpbData = (BYTE *)akeydata;
1179 break;
1180 case REG_MULTI_SZ:
1181 case REG_LINK: //???
1182 dprintf(("ERROR: key data must be translated from Unicode to Ascii!!"));
1183 break;
1184 }
1185 rc = RegSetValueExA(hkey, astring, dwReserved, fdwType, lpbData, cbData);
1186
1187 if(akeydata)
1188 FreeAsciiString(akeydata);
1189
1190 if (NULL != astring)
1191 FreeAsciiString(astring);
1192
1193 return(rc);
1194}
1195
1196
1197/*****************************************************************************
1198 * Name :
1199 * Purpose :
1200 * Parameters:
1201 * Variables :
1202 * Result :
1203 * Remark :
1204 * Status : UNTESTED STUB
1205 *
1206 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1207 *****************************************************************************/
1208
1209LONG WIN32API RegFlushKey(HKEY hkey)
1210{
1211 dprintf(("ADVAPI32: RegFlushKey not implemented yet."));
1212
1213 return(ERROR_SUCCESS);
1214}
1215
1216
1217/*****************************************************************************
1218 * Name : RegConnectRegistryA
1219 * Purpose : The RegConnectRegistry function establishes a connection to a
1220 * predefined registry handle on another computer.
1221 * Parameters: LPTSTR lpszComputerName address of name of remote computer
1222 * HKEY hKey predefined registry handle
1223 * PHKEY phkResult address of buffer for remote registry handle
1224 * Variables :
1225 * Result :
1226 * Remark :
1227 * Status : UNTESTED STUB
1228 *
1229 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1230 *****************************************************************************/
1231
1232LONG WIN32API RegConnectRegistryA(LPCSTR lpszComputerName,
1233 HKEY hKey,
1234 PHKEY phkResult)
1235{
1236 char szLocalName[256];
1237 DWORD dwNameLength = sizeof(szLocalName)-2;
1238
1239 szLocalName[0] = '\\';
1240 szLocalName[1] = '\\';
1241 GetComputerNameA(szLocalName+2, &dwNameLength);
1242
1243 dprintf(("ADVAPI32: RegConnectRegistryA(%s,local %s) not implemented yet.\n",
1244 lpszComputerName,
1245 szLocalName));
1246
1247 /* local registry ? */
1248 if ( ( lpszComputerName == NULL) ||
1249 (strcmp(szLocalName, lpszComputerName) == 0 ) )
1250 {
1251 /* @@@PH experimental !!! */
1252 *phkResult = hKey;
1253
1254 return (NO_ERROR);
1255 }
1256
1257 return (ERROR_ACCESS_DENIED);
1258}
1259
1260
1261/*****************************************************************************
1262 * Name : RegConnectRegistryW
1263 * Purpose : The RegConnectRegistry function establishes a connection to a
1264 * predefined registry handle on another computer.
1265 * Parameters: LPWSTR lpszComputerName address of name of remote computer
1266 * HKEY hKey predefined registry handle
1267 * PHKEY phkResult address of buffer for remote registry handle
1268 * Variables :
1269 * Result :
1270 * Remark :
1271 * Status : UNTESTED STUB
1272 *
1273 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1274 *****************************************************************************/
1275
1276LONG WIN32API RegConnectRegistryW(LPCWSTR lpszComputerName,
1277 HKEY hKey,
1278 PHKEY phkResult)
1279{
1280 /* corresponding ascii string */
1281 LPSTR pszAscii;
1282 LONG rc; /* returncode from call to ascii version of this function */
1283
1284 dprintf(("ADVAPI32: RegConnectRegistryW not implemented yet."));
1285
1286 if (lpszComputerName != NULL)
1287 pszAscii = UnicodeToAsciiString((LPWSTR)lpszComputerName);
1288 else
1289 pszAscii = NULL;
1290
1291 rc = RegConnectRegistryA(pszAscii,
1292 hKey,
1293 phkResult);
1294
1295 if (pszAscii != NULL)
1296 FreeAsciiString(pszAscii);
1297
1298 return (rc); /* OK */
1299}
1300
1301
1302/*****************************************************************************
1303 * Name : RegGetKeySecurity
1304 * Purpose : The RegGetKeySecurity function retrieves a copy of the security
1305 * descriptor protecting the specified open registry key.
1306 * Parameters: HKEY hKey open handle of key to set
1307 * SECURITY_INFORMATION SecInf descriptor contents
1308 * PSECURITY_DESCRIPTOR pSecDesc address of descriptor for key
1309 * LPDWORD lpcbSecDesc address of size of buffer and descriptor
1310 * Variables :
1311 * Result :
1312 * Remark :
1313 * Status : UNTESTED STUB
1314 *
1315 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1316 *****************************************************************************/
1317
1318LONG WIN32API RegGetKeySecurity(HKEY hKey,
1319 SECURITY_INFORMATION SecInf,
1320 PSECURITY_DESCRIPTOR pSecDesc,
1321 LPDWORD lpcbSecDesc)
1322{
1323 dprintf(("ADVAPI32: RegGetKeySecurity not implemented.\n"));
1324
1325 return (ERROR_ACCESS_DENIED); /* signal failure */
1326}
1327
1328
1329/*****************************************************************************
1330 * Name : RegLoadKeyA
1331 * Purpose : The RegLoadKey function creates a subkey under HKEY_USER or
1332 * HKEY_LOCAL_MACHINE and stores registration information from a
1333 * specified file into that subkey. This registration information
1334 * is in the form of a hive. A hive is a discrete body of keys,
1335 * subkeys, and values that is rooted at the top of the registry
1336 * hierarchy. A hive is backed by a single file and .LOG file.
1337 * Parameters: HKEY hKey handle of open key
1338 * LPCSTR lpszSubKey address of name of subkey
1339 * LPCSTR lpszFile address of filename for registry information
1340 * Variables :
1341 * Result :
1342 * Remark :
1343 * Status : UNTESTED STUB
1344 *
1345 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1346 *****************************************************************************/
1347
1348LONG WIN32API RegLoadKeyA(HKEY hKey,
1349 LPCSTR lpszSubKey,
1350 LPCSTR lpszFile)
1351{
1352 dprintf(("ADVAPI32: RegLoadKeyA not implemented.\n"));
1353
1354 return (ERROR_ACCESS_DENIED); /* signal failure */
1355}
1356
1357
1358/*****************************************************************************
1359 * Name : RegLoadKeyW
1360 * Purpose : The RegLoadKey function creates a subkey under HKEY_USER or
1361 * HKEY_LOCAL_MACHINE and stores registration information from a
1362 * specified file into that subkey. This registration information
1363 * is in the form of a hive. A hive is a discrete body of keys,
1364 * subkeys, and values that is rooted at the top of the registry
1365 * hierarchy. A hive is backed by a single file and .LOG file.
1366 * Parameters: HKEY hKey handle of open key
1367 * LPCWSTR lpszSubKey address of name of subkey
1368 * LPCWSTR lpszFile address of filename for registry information
1369 * Variables :
1370 * Result :
1371 * Remark :
1372 * Status : UNTESTED STUB
1373 *
1374 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1375 *****************************************************************************/
1376
1377LONG WIN32API RegLoadKeyW(HKEY hKey,
1378 LPCWSTR lpszSubKey,
1379 LPCWSTR lpszFile)
1380{
1381 dprintf(("ADVAPI32: RegLoadKeyW not implemented.\n"));
1382
1383 return (ERROR_ACCESS_DENIED); /* signal failure */
1384}
1385
1386
1387/*****************************************************************************
1388 * Name : RegQueryMultipleValuesA
1389 * Purpose : The RegQueryMultipleValues function retrieves the type and data
1390 * for a list of value names associated with an open registry key.
1391 * Parameters: HKEY hKey handle of key to query
1392 * PVALENT val_list address of array of value entry structures
1393 * DWORD num_vals size of array of value entry structures
1394 * LPTSTR lpValueBuf address of buffer for value information
1395 * LPDWORD ldwTotsize address of size of value buffer
1396 * Variables :
1397 * Result :
1398 * Remark :
1399 * Status : UNTESTED STUB
1400 *
1401 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1402 *****************************************************************************/
1403
1404LONG WIN32API RegQueryMultipleValuesA(HKEY hKey,
1405 PVALENTA val_list,
1406 DWORD num_vals,
1407 LPTSTR lpValueBuf,
1408 LPDWORD ldwTotsize)
1409{
1410 dprintf(("ADVAPI32: RegQueryMultipleValuesA not implemented.\n"));
1411
1412 return (ERROR_ACCESS_DENIED); /* signal failure */
1413}
1414
1415
1416/*****************************************************************************
1417 * Name : RegQueryMultipleValuesW
1418 * Purpose : The RegQueryMultipleValues function retrieves the type and data
1419 * for a list of value names associated with an open registry key.
1420 * Parameters: HKEY hKey handle of key to query
1421 * PVALENT val_list address of array of value entry structures
1422 * DWORD num_vals size of array of value entry structures
1423 * LPWSTR lpValueBuf address of buffer for value information
1424 * LPDWORD ldwTotsize address of size of value buffer
1425 * Variables :
1426 * Result :
1427 * Remark :
1428 * Status : UNTESTED STUB
1429 *
1430 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1431 *****************************************************************************/
1432
1433LONG WIN32API RegQueryMultipleValuesW(HKEY hKey,
1434 PVALENTW val_list,
1435 DWORD num_vals,
1436 LPWSTR lpValueBuf,
1437 LPDWORD ldwTotsize)
1438{
1439 dprintf(("ADVAPI32: RegQueryMultipleValuesW not implemented.\n"));
1440
1441 return (ERROR_ACCESS_DENIED); /* signal failure */
1442}
1443
1444
1445/*****************************************************************************
1446 * Name : RegRemapPreDefKey
1447 * Purpose :
1448 * Parameters:
1449 * Variables :
1450 * Result :
1451 * Remark :
1452 * Status : UNTESTED STUB
1453 *
1454 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1455 *****************************************************************************/
1456
1457#if 0
1458LONG WIN32API RegRemapPreDefKey(HKEY hKey)
1459{
1460 dprintf(("ADVAPI32: RegRemapPreDefKey not implemented.\n"));
1461
1462 return (ERROR_ACCESS_DENIED); /* signal failure */
1463}
1464#endif
1465
1466
1467/*****************************************************************************
1468 * Name : RegReplaceKeyA
1469 * Purpose : The RegReplaceKey function replaces the file backing a key and
1470 * all its subkeys with another file, so that when the system is
1471 * next started, the key and subkeys will have the values stored in the new file.
1472 * Parameters: HKEY hKey handle of open key
1473 * LPCSTR lpSubKey address of name of subkey
1474 * LPCSTR lpNewFile address of filename for file with new data
1475 * LPCSTR lpOldFile address of filename for backup file
1476 * Variables :
1477 * Result :
1478 * Remark :
1479 * Status : UNTESTED STUB
1480 *
1481 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1482 *****************************************************************************/
1483
1484LONG WIN32API RegReplaceKeyA(HKEY hKey, LPCSTR lpSubKey, LPCSTR lpNewFile,
1485 LPCSTR lpOldFile)
1486{
1487 dprintf(("ADVAPI32: RegReplaceKeyA not implemented.\n"));
1488
1489 return (ERROR_ACCESS_DENIED); /* signal failure */
1490}
1491
1492
1493/*****************************************************************************
1494 * Name : RegReplaceKeyW
1495 * Purpose : The RegReplaceKey function replaces the file backing a key and
1496 * all its subkeys with another file, so that when the system is
1497 * next started, the key and subkeys will have the values stored in the new file.
1498 * Parameters: HKEY hKey handle of open key
1499 * LPCWSTR lpSubKey address of name of subkey
1500 * LPCWSTR lpNewFile address of filename for file with new data
1501 * LPCWSTR lpOldFile address of filename for backup file
1502 * Variables :
1503 * Result :
1504 * Remark :
1505 * Status : UNTESTED STUB
1506 *
1507 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1508 *****************************************************************************/
1509
1510LONG WIN32API RegReplaceKeyW(HKEY hKey,
1511 LPCWSTR lpSubKey,
1512 LPCWSTR lpNewFile,
1513 LPCWSTR lpOldFile)
1514{
1515 dprintf(("ADVAPI32: RegReplaceKeyW not implemented.\n"));
1516
1517 return (ERROR_ACCESS_DENIED); /* signal failure */
1518}
1519
1520
1521/*****************************************************************************
1522 * Name : RegRestoreKeyA
1523 * Purpose : The RegRestoreKey function reads the registry information in a
1524 * specified file and copies it over the specified key. This
1525 * registry information may be in the form of a key and multiple
1526 * levels of subkeys.
1527 * Parameters: HKEY hKey handle of key where restore begins
1528 * LPCSTR lpszFile address of filename containing saved tree
1529 * DWORD fdw optional flags
1530 * Variables :
1531 * Result :
1532 * Remark :
1533 * Status : UNTESTED STUB
1534 *
1535 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1536 *****************************************************************************/
1537
1538LONG WIN32API RegRestoreKeyA(HKEY hKey,
1539 LPCSTR lpszFile,
1540 DWORD fdw)
1541{
1542 dprintf(("ADVAPI32: RegRestoreKeyA not implemented.\n"));
1543
1544 return (ERROR_ACCESS_DENIED); /* signal failure */
1545}
1546
1547
1548/*****************************************************************************
1549 * Name : RegRestoreKeyW
1550 * Purpose : The RegRestoreKey function reads the registry information in a
1551 * specified file and copies it over the specified key. This
1552 * registry information may be in the form of a key and multiple
1553 * levels of subkeys.
1554 * Parameters: HKEY hKey handle of key where restore begins
1555 * LPCWSTR lpszFile address of filename containing saved tree
1556 * DWORD fdw optional flags
1557 * Variables :
1558 * Result :
1559 * Remark :
1560 * Status : UNTESTED STUB
1561 *
1562 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1563 *****************************************************************************/
1564
1565LONG WIN32API RegRestoreKeyW(HKEY hKey,
1566 LPCWSTR lpszFile,
1567 DWORD fdw)
1568{
1569 dprintf(("ADVAPI32: RegRestoreKeyW not implemented.\n"));
1570
1571 return (ERROR_ACCESS_DENIED); /* signal failure */
1572}
1573
1574
1575/*****************************************************************************
1576 * Name : RegSaveKeyA
1577 * Purpose : The RegSaveKey function saves the specified key and all of its
1578 * subkeys and values to a new file.
1579 * Parameters: HKEY hKey handle of key where save begins
1580 * LPCSTR lpszFile address of filename to save to
1581 * LPSECURITY_ATTRIBUTES lpsa address of security structure
1582 * Variables :
1583 * Result :
1584 * Remark :
1585 * Status : UNTESTED STUB
1586 *
1587 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1588 *****************************************************************************/
1589
1590LONG WIN32API RegSaveKeyA(HKEY hKey,
1591 LPCSTR lpszFile,
1592 LPSECURITY_ATTRIBUTES lpsa)
1593{
1594 dprintf(("ADVAPI32: RegSaveKeyA not implemented.\n"));
1595
1596 return (ERROR_ACCESS_DENIED); /* signal failure */
1597}
1598
1599
1600/*****************************************************************************
1601 * Name : RegSaveKeyW
1602 * Purpose : The RegSaveKey function saves the specified key and all of its
1603 * subkeys and values to a new file.
1604 * Parameters: HKEY hKey handle of key where save begins
1605 * LPCWSTR lpszFile address of filename to save to
1606 * LPSECURITY_ATTRIBUTES lpsa address of security structure
1607 * Variables :
1608 * Result :
1609 * Remark :
1610 * Status : UNTESTED STUB
1611 *
1612 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1613 *****************************************************************************/
1614
1615LONG WIN32API RegSaveKeyW(HKEY hKey,
1616 LPCWSTR lpszFile,
1617 LPSECURITY_ATTRIBUTES lpsa)
1618{
1619 dprintf(("ADVAPI32: RegSaveKeyW not implemented.\n"));
1620
1621 return (ERROR_ACCESS_DENIED); /* signal failure */
1622}
1623
1624
1625/*****************************************************************************
1626 * Name : RegSetKeySecurity
1627 * Purpose : The RegSetKeySecurity function sets the security of an open registry key.
1628 * Parameters: HKEY hKey open handle of key to set
1629 * SECURITY_INFORMATION si descriptor contents
1630 * PSECURITY_DESCRIPTOR psd address of descriptor for key
1631 * Variables :
1632 * Result :
1633 * Remark :
1634 * Status : UNTESTED STUB
1635 *
1636 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1637 *****************************************************************************/
1638
1639LONG WIN32API RegSetKeySecurity(HKEY hKey,
1640 SECURITY_INFORMATION si,
1641 PSECURITY_DESCRIPTOR psd)
1642{
1643 dprintf(("ADVAPI32: RegSetKeySecurity not implemented.\n"));
1644
1645 return (ERROR_ACCESS_DENIED); /* signal failure */
1646}
1647
1648
1649/*****************************************************************************
1650 * Name : RegUnLoadKeyA
1651 * Purpose : The RegUnLoadKey function unloads the specified key and subkeys from the registry.
1652 * Parameters: HKEY hKey handle of open key
1653 * LPCSTR lpszSubKey address of name of subkey to unload
1654 * Variables :
1655 * Result :
1656 * Remark :
1657 * Status : UNTESTED STUB
1658 *
1659 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1660 *****************************************************************************/
1661
1662LONG WIN32API RegUnLoadKeyA(HKEY hKey,
1663 LPCSTR lpszSubKey)
1664{
1665 dprintf(("ADVAPI32: RegUnLoadKeyA not implemented.\n"));
1666
1667 return (ERROR_ACCESS_DENIED); /* signal failure */
1668}
1669
1670
1671/*****************************************************************************
1672 * Name : RegUnLoadKeyW
1673 * Purpose : The RegUnLoadKey function unloads the specified key and subkeys from the registry.
1674 * Parameters: HKEY hKey handle of open key
1675 * LPCWSTR lpszSubKey address of name of subkey to unload
1676 * Variables :
1677 * Result :
1678 * Remark :
1679 * Status : UNTESTED STUB
1680 *
1681 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1682 *****************************************************************************/
1683
1684LONG WIN32API RegUnLoadKeyW(HKEY hKey,
1685 LPCWSTR lpszSubKey)
1686{
1687 dprintf(("ADVAPI32: RegUnLoadKeyW not implemented.\n"));
1688
1689 return (ERROR_ACCESS_DENIED); /* signal failure */
1690}
1691
1692
1693/*****************************************************************************
1694 * Name : RegNotifyChangeKeyValue
1695 * Purpose :
1696 * Parameters: HKEY hKey handle of open key
1697 * LPCWSTR lpszSubKey address of name of subkey to unload
1698 * Variables :
1699 * Result :
1700 * Remark :
1701 * Status : UNTESTED STUB
1702 *
1703 * Author : Patrick Haller [Tue, 1998/06/16 23:00]
1704 *****************************************************************************/
1705
1706LONG WIN32API RegNotifyChangeKeyValue(HKEY hKey,
1707 BOOL bWatchSubtree,
1708 DWORD dwNotifyFilter,
1709 HANDLE hEvent,
1710 BOOL fAsynchronus)
1711{
1712 dprintf(("ADVAPI32: RegNotifyChangeKeyValue() not implemented.\n"));
1713
1714 return ERROR_ACCESS_DENIED;
1715}
1716
Note: See TracBrowser for help on using the repository browser.