2 * Registry editing UI functions.
4 * Copyright (C) 2003 Dimitrie O. Paun
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
23 typedef enum _EDIT_MODE
30 static const TCHAR
* editValueName
;
31 static TCHAR
* stringValueData
;
32 static PVOID binValueData
;
33 static DWORD dwordValueData
;
34 static DWORD valueDataLen
;
35 static EDIT_MODE dwordEditMode
= EDIT_MODE_HEX
;
37 void error(HWND hwnd
, INT resId
, ...)
45 hInstance
= GetModuleHandle(0);
47 if (!LoadString(hInstance
, IDS_ERROR
, title
, COUNT_OF(title
)))
48 _tcscpy(title
, _T("Error"));
50 if (!LoadString(hInstance
, resId
, errfmt
, COUNT_OF(errfmt
)))
51 _tcscpy(errfmt
, _T("Unknown error string!"));
54 _vsntprintf(errstr
, COUNT_OF(errstr
), errfmt
, ap
);
57 MessageBox(hwnd
, errstr
, title
, MB_OK
| MB_ICONERROR
);
60 static void error_code_messagebox(HWND hwnd
, DWORD error_code
)
63 if (!LoadString(hInst
, IDS_ERROR
, title
, COUNT_OF(title
)))
64 lstrcpy(title
, TEXT("Error"));
65 ErrorMessageBox(hwnd
, title
, error_code
);
68 void warning(HWND hwnd
, INT resId
, ...)
76 hInstance
= GetModuleHandle(0);
78 if (!LoadString(hInstance
, IDS_WARNING
, title
, COUNT_OF(title
)))
79 _tcscpy(title
, _T("Warning"));
81 if (!LoadString(hInstance
, resId
, errfmt
, COUNT_OF(errfmt
)))
82 _tcscpy(errfmt
, _T("Unknown error string!"));
85 _vsntprintf(errstr
, COUNT_OF(errstr
), errfmt
, ap
);
88 MessageBox(hwnd
, errstr
, title
, MB_OK
| MB_ICONSTOP
);
91 INT_PTR CALLBACK
modify_string_dlgproc(HWND hwndDlg
, UINT uMsg
, WPARAM wParam
, LPARAM lParam
)
97 UNREFERENCED_PARAMETER(lParam
);
102 if(editValueName
&& _tcscmp(editValueName
, _T("")))
104 SetDlgItemText(hwndDlg
, IDC_VALUE_NAME
, editValueName
);
109 LoadString(hInst
, IDS_DEFAULT_VALUE_NAME
, buffer
, sizeof(buffer
)/sizeof(TCHAR
));
110 SetDlgItemText(hwndDlg
, IDC_VALUE_NAME
, buffer
);
112 SetDlgItemText(hwndDlg
, IDC_VALUE_DATA
, stringValueData
);
113 SetFocus(GetDlgItem(hwndDlg
, IDC_VALUE_DATA
));
116 switch (LOWORD(wParam
))
119 if ((hwndValue
= GetDlgItem(hwndDlg
, IDC_VALUE_DATA
)))
121 if ((len
= GetWindowTextLength(hwndValue
)))
125 if ((valueData
= HeapReAlloc(GetProcessHeap(), 0, stringValueData
, (len
+ 1) * sizeof(TCHAR
))))
127 stringValueData
= valueData
;
128 if (!GetWindowText(hwndValue
, stringValueData
, len
+ 1))
129 *stringValueData
= 0;
134 if ((valueData
= HeapAlloc(GetProcessHeap(), 0, (len
+ 1) * sizeof(TCHAR
))))
136 stringValueData
= valueData
;
137 if (!GetWindowText(hwndValue
, stringValueData
, len
+ 1))
138 *stringValueData
= 0;
145 *stringValueData
= 0;
148 EndDialog(hwndDlg
, IDOK
);
151 EndDialog(hwndDlg
, IDCANCEL
);
159 INT_PTR CALLBACK
modify_multi_string_dlgproc(HWND hwndDlg
, UINT uMsg
, WPARAM wParam
, LPARAM lParam
)
165 UNREFERENCED_PARAMETER(lParam
);
170 if(editValueName
&& _tcscmp(editValueName
, _T("")))
172 SetDlgItemText(hwndDlg
, IDC_VALUE_NAME
, editValueName
);
177 LoadString(hInst
, IDS_DEFAULT_VALUE_NAME
, buffer
, sizeof(buffer
)/sizeof(TCHAR
));
178 SetDlgItemText(hwndDlg
, IDC_VALUE_NAME
, buffer
);
180 SetDlgItemText(hwndDlg
, IDC_VALUE_DATA
, stringValueData
);
181 SetFocus(GetDlgItem(hwndDlg
, IDC_VALUE_DATA
));
184 switch (LOWORD(wParam
))
187 if ((hwndValue
= GetDlgItem(hwndDlg
, IDC_VALUE_DATA
)))
189 if ((len
= GetWindowTextLength(hwndValue
)))
193 if ((valueData
= HeapReAlloc(GetProcessHeap(), 0, stringValueData
, (len
+ 1) * sizeof(TCHAR
))))
195 stringValueData
= valueData
;
196 if (!GetWindowText(hwndValue
, stringValueData
, len
+ 1))
197 *stringValueData
= 0;
202 if ((valueData
= HeapAlloc(GetProcessHeap(), 0, (len
+ 1) * sizeof(TCHAR
))))
204 stringValueData
= valueData
;
205 if (!GetWindowText(hwndValue
, stringValueData
, len
+ 1))
206 *stringValueData
= 0;
213 *stringValueData
= 0;
216 EndDialog(hwndDlg
, IDOK
);
219 EndDialog(hwndDlg
, IDCANCEL
);
227 LRESULT CALLBACK
DwordEditSubclassProc(HWND hwnd
, UINT uMsg
, WPARAM wParam
, LPARAM lParam
)
231 oldwndproc
= (WNDPROC
)(LONG_PTR
)GetWindowLongPtr(hwnd
, GWL_USERDATA
);
236 if (dwordEditMode
== EDIT_MODE_DEC
)
238 if (isdigit((int) wParam
& 0xff) || iscntrl((int) wParam
& 0xff))
247 else if (dwordEditMode
== EDIT_MODE_HEX
)
249 if (isxdigit((int) wParam
& 0xff) || iscntrl((int) wParam
& 0xff))
264 return CallWindowProc(oldwndproc
, hwnd
, uMsg
, wParam
, lParam
);
268 INT_PTR CALLBACK
modify_dword_dlgproc(HWND hwndDlg
, UINT uMsg
, WPARAM wParam
, LPARAM lParam
)
272 TCHAR ValueString
[32];
277 UNREFERENCED_PARAMETER(lParam
);
282 dwordEditMode
= EDIT_MODE_HEX
;
284 /* subclass the edit control */
285 hwndValue
= GetDlgItem(hwndDlg
, IDC_VALUE_DATA
);
286 oldproc
= (WNDPROC
)(LONG_PTR
)GetWindowLongPtr(hwndValue
, GWL_WNDPROC
);
287 SetWindowLongPtr(hwndValue
, GWL_USERDATA
, (DWORD_PTR
)oldproc
);
288 SetWindowLongPtr(hwndValue
, GWL_WNDPROC
, (DWORD_PTR
)DwordEditSubclassProc
);
290 if(editValueName
&& _tcscmp(editValueName
, _T("")))
292 SetDlgItemText(hwndDlg
, IDC_VALUE_NAME
, editValueName
);
297 LoadString(hInst
, IDS_DEFAULT_VALUE_NAME
, buffer
, sizeof(buffer
)/sizeof(TCHAR
));
298 SetDlgItemText(hwndDlg
, IDC_VALUE_NAME
, buffer
);
300 CheckRadioButton (hwndDlg
, IDC_FORMAT_HEX
, IDC_FORMAT_DEC
, IDC_FORMAT_HEX
);
301 _stprintf (ValueString
, _T("%lx"), dwordValueData
);
302 SetDlgItemText(hwndDlg
, IDC_VALUE_DATA
, ValueString
);
303 SetFocus(GetDlgItem(hwndDlg
, IDC_VALUE_DATA
));
307 switch (LOWORD(wParam
))
310 if (HIWORD(wParam
) == BN_CLICKED
&& dwordEditMode
== EDIT_MODE_DEC
)
312 dwordEditMode
= EDIT_MODE_HEX
;
313 if ((hwndValue
= GetDlgItem(hwndDlg
, IDC_VALUE_DATA
)))
315 if (GetWindowTextLength(hwndValue
))
317 if (GetWindowText(hwndValue
, ValueString
, 32))
319 Value
= _tcstoul (ValueString
, &Remainder
, 10);
323 _stprintf (ValueString
, _T("%lx"), Value
);
324 SetDlgItemText(hwndDlg
, IDC_VALUE_DATA
, ValueString
);
330 if (HIWORD(wParam
) == BN_CLICKED
&& dwordEditMode
== EDIT_MODE_HEX
)
332 dwordEditMode
= EDIT_MODE_DEC
;
333 if ((hwndValue
= GetDlgItem(hwndDlg
, IDC_VALUE_DATA
)))
335 if (GetWindowTextLength(hwndValue
))
337 if (GetWindowText(hwndValue
, ValueString
, 32))
339 Value
= _tcstoul (ValueString
, &Remainder
, 16);
343 _stprintf (ValueString
, _T("%lu"), Value
);
344 SetDlgItemText(hwndDlg
, IDC_VALUE_DATA
, ValueString
);
350 if ((hwndValue
= GetDlgItem(hwndDlg
, IDC_VALUE_DATA
)))
352 if (GetWindowTextLength(hwndValue
))
354 if (!GetWindowText(hwndValue
, ValueString
, 32))
356 EndDialog(hwndDlg
, IDCANCEL
);
360 Base
= (dwordEditMode
== EDIT_MODE_HEX
) ? 16 : 10;
361 dwordValueData
= _tcstoul (ValueString
, &Remainder
, Base
);
365 EndDialog(hwndDlg
, IDCANCEL
);
369 EndDialog(hwndDlg
, IDOK
);
373 EndDialog(hwndDlg
, IDCANCEL
);
381 INT_PTR CALLBACK
modify_binary_dlgproc(HWND hwndDlg
, UINT uMsg
, WPARAM wParam
, LPARAM lParam
)
386 UNREFERENCED_PARAMETER(lParam
);
391 if(editValueName
&& _tcscmp(editValueName
, _T("")))
393 SetDlgItemText(hwndDlg
, IDC_VALUE_NAME
, editValueName
);
398 LoadString(hInst
, IDS_DEFAULT_VALUE_NAME
, buffer
, sizeof(buffer
)/sizeof(TCHAR
));
399 SetDlgItemText(hwndDlg
, IDC_VALUE_NAME
, buffer
);
401 hwndValue
= GetDlgItem(hwndDlg
, IDC_VALUE_DATA
);
402 HexEdit_LoadBuffer(hwndValue
, binValueData
, valueDataLen
);
403 /* reset the hex edit control's font */
404 SendMessage(hwndValue
, WM_SETFONT
, 0, 0);
408 switch (LOWORD(wParam
))
411 if ((hwndValue
= GetDlgItem(hwndDlg
, IDC_VALUE_DATA
)))
413 len
= (UINT
) HexEdit_GetBufferSize(hwndValue
);
414 if (len
> 0 && binValueData
)
415 binValueData
= HeapReAlloc(GetProcessHeap(), 0, binValueData
, len
);
417 binValueData
= HeapAlloc(GetProcessHeap(), 0, len
+ 1);
418 HexEdit_CopyBuffer(hwndValue
, binValueData
, len
);
421 EndDialog(hwndDlg
, IDOK
);
424 EndDialog(hwndDlg
, IDCANCEL
);
432 BOOL
ModifyValue(HWND hwnd
, HKEY hKey
, LPCTSTR valueName
, BOOL EditBin
)
441 editValueName
= valueName
;
443 lRet
= RegQueryValueEx(hKey
, valueName
, 0, &type
, 0, &valueDataLen
);
444 if (lRet
!= ERROR_SUCCESS
&& (!_tcscmp(valueName
, _T("")) || valueName
== NULL
))
446 lRet
= ERROR_SUCCESS
; /* Allow editing of (Default) values which don't exist */
449 stringValueData
= NULL
;
453 if (lRet
!= ERROR_SUCCESS
)
455 error(hwnd
, IDS_BAD_VALUE
, valueName
);
459 if (EditBin
== FALSE
&& ((type
== REG_SZ
) || (type
== REG_EXPAND_SZ
)))
461 if (valueDataLen
> 0)
463 if (!(stringValueData
= HeapAlloc(GetProcessHeap(), 0, valueDataLen
)))
465 error(hwnd
, IDS_TOO_BIG_VALUE
, valueDataLen
);
468 lRet
= RegQueryValueEx(hKey
, valueName
, 0, 0, (LPBYTE
)stringValueData
, &valueDataLen
);
469 if (lRet
!= ERROR_SUCCESS
)
471 error(hwnd
, IDS_BAD_VALUE
, valueName
);
477 stringValueData
= NULL
;
480 if (DialogBox(0, MAKEINTRESOURCE(IDD_EDIT_STRING
), hwnd
, modify_string_dlgproc
) == IDOK
)
484 lRet
= RegSetValueEx(hKey
, valueName
, 0, type
, (LPBYTE
)stringValueData
, (DWORD
) (_tcslen(stringValueData
) + 1) * sizeof(TCHAR
));
488 lRet
= RegSetValueEx(hKey
, valueName
, 0, type
, NULL
, 0);
490 if (lRet
== ERROR_SUCCESS
)
494 else if (EditBin
== FALSE
&& type
== REG_MULTI_SZ
)
496 if (valueDataLen
> 0)
498 size_t llen
, listlen
, nl_len
;
499 LPTSTR src
, lines
= NULL
;
501 if (!(stringValueData
= HeapAlloc(GetProcessHeap(), 0, valueDataLen
)))
503 error(hwnd
, IDS_TOO_BIG_VALUE
, valueDataLen
);
506 lRet
= RegQueryValueEx(hKey
, valueName
, 0, 0, (LPBYTE
)stringValueData
, &valueDataLen
);
507 if (lRet
!= ERROR_SUCCESS
)
509 error(hwnd
, IDS_BAD_VALUE
, valueName
);
513 /* convert \0 to \r\n */
514 src
= stringValueData
;
515 nl_len
= _tcslen(_T("\r\n")) * sizeof(TCHAR
);
516 listlen
= sizeof(TCHAR
);
517 lines
= HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY
, listlen
+ sizeof(TCHAR
));
518 while(*src
!= _T('\0'))
523 listlen
+= (llen
* sizeof(TCHAR
)) + nl_len
;
524 lines
= HeapReAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY
, lines
, listlen
);
526 _tcscat(lines
, _T("\r\n"));
529 HeapFree(GetProcessHeap(), 0, stringValueData
);
530 stringValueData
= lines
;
534 stringValueData
= NULL
;
537 if (DialogBox(0, MAKEINTRESOURCE(IDD_EDIT_MULTI_STRING
), hwnd
, modify_multi_string_dlgproc
) == IDOK
)
541 /* convert \r\n to \0 */
542 BOOL EmptyLines
= FALSE
;
543 LPTSTR src
, lines
, nl
;
544 size_t linechars
, buflen
, c_nl
, dest
;
546 src
= stringValueData
;
547 buflen
= sizeof(TCHAR
);
548 lines
= HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY
, buflen
+ sizeof(TCHAR
));
549 c_nl
= _tcslen(_T("\r\n"));
551 while(*src
!= _T('\0'))
553 if((nl
= _tcsstr(src
, _T("\r\n"))))
555 linechars
= nl
- src
;
565 linechars
= _tcslen(src
);
569 buflen
+= ((linechars
+ 1) * sizeof(TCHAR
));
570 lines
= HeapReAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY
, lines
, buflen
);
571 memcpy((lines
+ dest
), src
, linechars
* sizeof(TCHAR
));
573 lines
[dest
++] = _T('\0');
579 src
+= linechars
+ (nl
!= NULL
? c_nl
: 0);
581 lines
[++dest
] = _T('\0');
585 warning(hwnd
, IDS_MULTI_SZ_EMPTY_STRING
);
588 lRet
= RegSetValueEx(hKey
, valueName
, 0, type
, (LPBYTE
)lines
, (DWORD
) buflen
);
589 HeapFree(GetProcessHeap(), 0, lines
);
593 lRet
= RegSetValueEx(hKey
, valueName
, 0, type
, NULL
, 0);
595 if (lRet
== ERROR_SUCCESS
)
599 else if (EditBin
== FALSE
&& type
== REG_DWORD
)
601 lRet
= RegQueryValueEx(hKey
, valueName
, 0, 0, (LPBYTE
)&dwordValueData
, &valueDataLen
);
602 if (lRet
!= ERROR_SUCCESS
)
604 error(hwnd
, IDS_BAD_VALUE
, valueName
);
608 if (DialogBox(0, MAKEINTRESOURCE(IDD_EDIT_DWORD
), hwnd
, modify_dword_dlgproc
) == IDOK
)
610 lRet
= RegSetValueEx(hKey
, valueName
, 0, type
, (LPBYTE
)&dwordValueData
, sizeof(DWORD
));
611 if (lRet
== ERROR_SUCCESS
)
615 else if (EditBin
== TRUE
|| type
== REG_NONE
|| type
== REG_BINARY
)
619 int len_vname
= lstrlen(valueName
);
623 if(!(u_valuename
= HeapAlloc(GetProcessHeap(), 0, (len_vname
+ 1) * sizeof(WCHAR
))))
625 error(hwnd
, IDS_TOO_BIG_VALUE
, len_vname
);
628 /* convert the ansi value name to an unicode string */
629 MultiByteToWideChar(CP_ACP
, 0, valueName
, -1, u_valuename
, len_vname
+ 1);
630 valueDataLen
*= sizeof(WCHAR
);
637 if(!(binValueData
= HeapAlloc(GetProcessHeap(), 0, valueDataLen
+ 1)))
639 error(hwnd
, IDS_TOO_BIG_VALUE
, valueDataLen
);
643 /* force to use the unicode version, so editing strings in binary mode is correct */
644 lRet
= RegQueryValueExW(hKey
,
650 0, 0, (LPBYTE
)binValueData
, &valueDataLen
);
651 if (lRet
!= ERROR_SUCCESS
)
653 HeapFree(GetProcessHeap(), 0, binValueData
);
656 HeapFree(GetProcessHeap(), 0, u_valuename
);
658 error(hwnd
, IDS_BAD_VALUE
, valueName
);
667 if (DialogBox(0, MAKEINTRESOURCE(IDD_EDIT_BIN_DATA
), hwnd
, modify_binary_dlgproc
) == IDOK
)
669 /* force to use the unicode version, so editing strings in binary mode is correct */
670 lRet
= RegSetValueExW(hKey
,
676 0, type
, (LPBYTE
)binValueData
, valueDataLen
);
677 if (lRet
== ERROR_SUCCESS
)
680 if(binValueData
!= NULL
)
681 HeapFree(GetProcessHeap(), 0, binValueData
);
684 HeapFree(GetProcessHeap(), 0, u_valuename
);
689 error(hwnd
, IDS_UNSUPPORTED_TYPE
, type
);
694 HeapFree(GetProcessHeap(), 0, stringValueData
);
695 stringValueData
= NULL
;
700 static LONG
CopyKey(HKEY hDestKey
, LPCTSTR lpDestSubKey
, HKEY hSrcKey
, LPCTSTR lpSrcSubKey
)
704 HKEY hDestSubKey
= NULL
;
705 HKEY hSrcSubKey
= NULL
;
706 DWORD dwIndex
, dwType
, cbName
, cbData
;
708 TCHAR szValueName
[256];
709 BYTE szValueData
[512];
713 /* open the source subkey, if specified */
716 lResult
= RegOpenKeyEx(hSrcKey
, lpSrcSubKey
, 0, KEY_ALL_ACCESS
, &hSrcSubKey
);
719 hSrcKey
= hSrcSubKey
;
722 /* create the destination subkey */
723 lResult
= RegCreateKeyEx(hDestKey
, lpDestSubKey
, 0, NULL
, 0, KEY_WRITE
, NULL
,
724 &hDestSubKey
, &dwDisposition
);
728 /* copy all subkeys */
732 cbName
= sizeof(szSubKey
) / sizeof(szSubKey
[0]);
733 lResult
= RegEnumKeyEx(hSrcKey
, dwIndex
++, szSubKey
, &cbName
, NULL
, NULL
, NULL
, &ft
);
734 if (lResult
== ERROR_SUCCESS
)
736 lResult
= CopyKey(hDestSubKey
, szSubKey
, hSrcKey
, szSubKey
);
741 while(lResult
== ERROR_SUCCESS
);
743 /* copy all subvalues */
747 cbName
= sizeof(szValueName
) / sizeof(szValueName
[0]);
748 cbData
= sizeof(szValueData
) / sizeof(szValueData
[0]);
749 lResult
= RegEnumValue(hSrcKey
, dwIndex
++, szValueName
, &cbName
, NULL
, &dwType
, szValueData
, &cbData
);
750 if (lResult
== ERROR_SUCCESS
)
752 lResult
= RegSetValueEx(hDestSubKey
, szValueName
, 0, dwType
, szValueData
, cbData
);
757 while(lResult
== ERROR_SUCCESS
);
759 lResult
= ERROR_SUCCESS
;
763 RegCloseKey(hSrcSubKey
);
765 RegCloseKey(hDestSubKey
);
766 if (lResult
!= ERROR_SUCCESS
)
767 SHDeleteKey(hDestKey
, lpDestSubKey
);
771 static LONG
MoveKey(HKEY hDestKey
, LPCTSTR lpDestSubKey
, HKEY hSrcKey
, LPCTSTR lpSrcSubKey
)
776 return ERROR_INVALID_FUNCTION
;
778 lResult
= CopyKey(hDestKey
, lpDestSubKey
, hSrcKey
, lpSrcSubKey
);
779 if (lResult
== ERROR_SUCCESS
)
780 SHDeleteKey(hSrcKey
, lpSrcSubKey
);
785 BOOL
DeleteKey(HWND hwnd
, HKEY hKeyRoot
, LPCTSTR keyPath
)
787 TCHAR msg
[128], caption
[128];
792 lRet
= RegOpenKeyEx(hKeyRoot
, keyPath
, 0, KEY_READ
|KEY_SET_VALUE
, &hKey
);
793 if (lRet
!= ERROR_SUCCESS
)
795 error_code_messagebox(hwnd
, lRet
);
799 LoadString(hInst
, IDS_QUERY_DELETE_KEY_CONFIRM
, caption
, sizeof(caption
)/sizeof(TCHAR
));
800 LoadString(hInst
, IDS_QUERY_DELETE_KEY_ONE
, msg
, sizeof(msg
)/sizeof(TCHAR
));
802 if (MessageBox(g_pChildWnd
->hWnd
, msg
, caption
, MB_ICONQUESTION
| MB_YESNO
) != IDYES
)
805 lRet
= SHDeleteKey(hKeyRoot
, keyPath
);
806 if (lRet
!= ERROR_SUCCESS
)
808 error(hwnd
, IDS_BAD_KEY
, keyPath
);
818 LONG
RenameKey(HKEY hKey
, LPCTSTR lpSubKey
, LPCTSTR lpNewName
)
821 LPTSTR lpNewSubKey
= NULL
;
827 s
= _tcsrchr(lpSubKey
, _T('\\'));
831 lpNewSubKey
= (LPTSTR
) HeapAlloc(GetProcessHeap(), 0, (s
- lpSubKey
+ _tcslen(lpNewName
) + 1) * sizeof(TCHAR
));
832 if (lpNewSubKey
!= NULL
)
834 memcpy(lpNewSubKey
, lpSubKey
, (s
- lpSubKey
) * sizeof(TCHAR
));
835 lstrcpy(lpNewSubKey
+ (s
- lpSubKey
), lpNewName
);
836 lpNewName
= lpNewSubKey
;
839 return ERROR_NOT_ENOUGH_MEMORY
;
842 Ret
= MoveKey(hKey
, lpNewName
, hKey
, lpSubKey
);
846 HeapFree(GetProcessHeap(), 0, lpNewSubKey
);
851 LONG
RenameValue(HKEY hKey
, LPCTSTR lpSubKey
, LPCTSTR lpDestValue
, LPCTSTR lpSrcValue
)
855 DWORD dwType
, cbData
;
860 lResult
= RegOpenKey(hKey
, lpSubKey
, &hSubKey
);
861 if (lResult
!= ERROR_SUCCESS
)
866 cbData
= sizeof(data
);
867 lResult
= RegQueryValueEx(hKey
, lpSrcValue
, NULL
, &dwType
, data
, &cbData
);
868 if (lResult
!= ERROR_SUCCESS
)
871 lResult
= RegSetValueEx(hKey
, lpDestValue
, 0, dwType
, data
, cbData
);
872 if (lResult
!= ERROR_SUCCESS
)
875 RegDeleteValue(hKey
, lpSrcValue
);
879 RegCloseKey(hSubKey
);
883 LONG
QueryStringValue(HKEY hKey
, LPCTSTR lpSubKey
, LPCTSTR lpValueName
, LPTSTR pszBuffer
, DWORD dwBufferLen
)
887 DWORD cbData
, dwType
;
891 lResult
= RegOpenKey(hKey
, lpSubKey
, &hSubKey
);
892 if (lResult
!= ERROR_SUCCESS
)
897 cbData
= (dwBufferLen
- 1) * sizeof(*pszBuffer
);
898 lResult
= RegQueryValueEx(hKey
, lpValueName
, NULL
, &dwType
, (LPBYTE
) pszBuffer
, &cbData
);
899 if (lResult
!= ERROR_SUCCESS
)
901 if (dwType
!= REG_SZ
)
907 pszBuffer
[cbData
/ sizeof(*pszBuffer
)] = _T('\0');
910 if (lResult
!= ERROR_SUCCESS
)
911 pszBuffer
[0] = _T('\0');
913 RegCloseKey(hSubKey
);
917 BOOL
GetKeyName(LPTSTR pszDest
, size_t iDestLength
, HKEY hRootKey
, LPCTSTR lpSubKey
)
921 if (hRootKey
== HKEY_CLASSES_ROOT
)
922 pszRootKey
= TEXT("HKEY_CLASSES_ROOT");
923 else if (hRootKey
== HKEY_CURRENT_USER
)
924 pszRootKey
= TEXT("HKEY_CURRENT_USER");
925 else if (hRootKey
== HKEY_LOCAL_MACHINE
)
926 pszRootKey
= TEXT("HKEY_LOCAL_MACHINE");
927 else if (hRootKey
== HKEY_USERS
)
928 pszRootKey
= TEXT("HKEY_USERS");
929 else if (hRootKey
== HKEY_CURRENT_CONFIG
)
930 pszRootKey
= TEXT("HKEY_CURRENT_CONFIG");
931 else if (hRootKey
== HKEY_DYN_DATA
)
932 pszRootKey
= TEXT("HKEY_DYN_DATA");
937 _sntprintf(pszDest
, iDestLength
, TEXT("%s\\%s"), pszRootKey
, lpSubKey
);
939 _sntprintf(pszDest
, iDestLength
, TEXT("%s"), pszRootKey
);