[PATCH 2/7] reg: Output value names when querying a registry key
Hugh McMaster
hugh.mcmaster at outlook.com
Thu Apr 21 06:45:21 CDT 2016
Signed-off-by: Hugh McMaster <hugh.mcmaster at outlook.com>
---
programs/reg/reg.c | 68 +++++++++++++++++++++++++++++++++++++++++++++++++++---
1 file changed, 65 insertions(+), 3 deletions(-)
diff --git a/programs/reg/reg.c b/programs/reg/reg.c
index f4fa28c..48e61bc 100644
--- a/programs/reg/reg.c
+++ b/programs/reg/reg.c
@@ -537,12 +537,60 @@ static int reg_delete(WCHAR *key_name, WCHAR *value_name, BOOL value_empty,
return 0;
}
+static int query_all(HKEY key, WCHAR *path)
+{
+ LONG rc;
+ DWORD num_values, max_value_len, value_len;
+ DWORD i;
+ WCHAR fmt[] = {'%','1','\n',0};
+ WCHAR fmt_value[] = {' ',' ',' ',' ','%','1',0};
+ WCHAR *value_name;
+ WCHAR newlineW[] = {'\n',0};
+
+ rc = RegQueryInfoKeyW(key, NULL, NULL, NULL, NULL, NULL, NULL,
+ &num_values, &max_value_len, NULL, NULL, NULL);
+ if (rc)
+ {
+ ERR("RegQueryInfoKey failed: %d\n", rc);
+ return 1;
+ }
+
+ output_string(fmt, path);
+
+ max_value_len++;
+ value_name = HeapAlloc(GetProcessHeap(), 0, max_value_len * sizeof(WCHAR));
+ if (!value_name)
+ {
+ ERR("Failed to allocate memory for value_name\n");
+ return 1;
+ }
+
+ for (i = 0; i < num_values; i++)
+ {
+ value_len = max_value_len;
+ rc = RegEnumValueW(key, i, value_name, &value_len, NULL, NULL, NULL, NULL);
+ if (rc == ERROR_SUCCESS)
+ {
+ output_string(fmt_value, value_name);
+ output_string(newlineW);
+ }
+ }
+
+ HeapFree(GetProcessHeap(), 0, value_name);
+
+ if (num_values)
+ output_string(newlineW);
+
+ return 0;
+}
+
static int reg_query(WCHAR *key_name, WCHAR *value_name, BOOL value_empty, BOOL recurse)
{
WCHAR *p;
- HKEY root;
+ HKEY root, key;
static const WCHAR stubW[] = {'S','T','U','B',' ','Q','U','E','R','Y',' ',
'-',' ','%','1',' ','%','2',' ','%','3','!','d','!',' ','%','4','!','d','!','\n',0};
+ int ret;
if (!sane_path(key_name))
return 1;
@@ -563,9 +611,23 @@ static int reg_query(WCHAR *key_name, WCHAR *value_name, BOOL value_empty, BOOL
p = strchrW(key_name, '\\');
if (p) p++;
- output_string(stubW, key_name, value_name, value_empty, recurse);
+ if (RegOpenKeyExW(root, p, 0, KEY_READ, &key) != ERROR_SUCCESS)
+ {
+ output_message(STRING_CANNOT_FIND);
+ return 1;
+ }
+
+ if (value_name || value_empty || recurse)
+ {
+ output_string(stubW, key_name, value_name, value_empty, recurse);
+ return 1;
+ }
+
+ ret = query_all(key, key_name);
+
+ RegCloseKey(key);
- return 1;
+ return ret;
}
int wmain(int argc, WCHAR *argvW[])
--
1.9.1
More information about the wine-patches
mailing list