Hugh McMaster : reg: Move duplicate path_get_rootkey() calls to wmain.

Alexandre Julliard julliard at winehq.org
Fri Jun 3 10:03:46 CDT 2016


Module: wine
Branch: master
Commit: ee718839646b41a3ca149acba56c567748864b2a
URL:    http://source.winehq.org/git/wine.git/?a=commit;h=ee718839646b41a3ca149acba56c567748864b2a

Author: Hugh McMaster <hugh.mcmaster at outlook.com>
Date:   Fri Jun  3 05:24:23 2016 +0000

reg: Move duplicate path_get_rootkey() calls to wmain.

Signed-off-by: Hugh McMaster <hugh.mcmaster at outlook.com>
Signed-off-by: Alexandre Julliard <julliard at winehq.org>

---

 programs/reg/reg.c | 52 +++++++++++++++++++---------------------------------
 1 file changed, 19 insertions(+), 33 deletions(-)

diff --git a/programs/reg/reg.c b/programs/reg/reg.c
index 3a9dc2e..9cf094e 100644
--- a/programs/reg/reg.c
+++ b/programs/reg/reg.c
@@ -345,22 +345,15 @@ static BOOL sane_path(const WCHAR *key)
     return TRUE;
 }
 
-static int reg_add(WCHAR *key_name, WCHAR *value_name, BOOL value_empty,
-    WCHAR *type, WCHAR separator, WCHAR *data, BOOL force)
+static int reg_add(HKEY root, WCHAR *key_name, WCHAR *value_name, BOOL value_empty,
+                   WCHAR *type, WCHAR separator, WCHAR *data, BOOL force)
 {
     LPWSTR p;
-    HKEY root,subkey;
+    HKEY subkey;
 
     p = strchrW(key_name,'\\');
     if (p) p++;
 
-    root = path_get_rootkey(key_name);
-    if (!root)
-    {
-        output_message(STRING_INVALID_KEY);
-        return 1;
-    }
-
     if (value_name && value_empty)
     {
         output_message(STRING_INVALID_CMDLINE);
@@ -422,22 +415,15 @@ static int reg_add(WCHAR *key_name, WCHAR *value_name, BOOL value_empty,
     return 0;
 }
 
-static int reg_delete(WCHAR *key_name, WCHAR *value_name, BOOL value_empty,
-    BOOL value_all, BOOL force)
+static int reg_delete(HKEY root, WCHAR *key_name, WCHAR *value_name, BOOL value_empty,
+                      BOOL value_all, BOOL force)
 {
     LPWSTR p;
-    HKEY root,subkey;
+    HKEY subkey;
 
     p = strchrW(key_name,'\\');
     if (p) p++;
 
-    root = path_get_rootkey(key_name);
-    if (!root)
-    {
-        output_message(STRING_INVALID_KEY);
-        return 1;
-    }
-
     if ((value_name && value_empty) || (value_name && value_all) || (value_empty && value_all))
     {
         output_message(STRING_INVALID_CMDLINE);
@@ -823,10 +809,10 @@ static int query_all(HKEY key, WCHAR *path, BOOL recurse)
     return 0;
 }
 
-static int reg_query(WCHAR *key_name, WCHAR *value_name, BOOL value_empty, BOOL recurse)
+static int reg_query(HKEY root, WCHAR *key_name, WCHAR *value_name, BOOL value_empty, BOOL recurse)
 {
     WCHAR *p;
-    HKEY root, key;
+    HKEY key;
     WCHAR newlineW[] = {'\n',0};
     int ret;
 
@@ -836,13 +822,6 @@ static int reg_query(WCHAR *key_name, WCHAR *value_name, BOOL value_empty, BOOL
         return 1;
     }
 
-    root = path_get_rootkey(key_name);
-    if (!root)
-    {
-        output_message(STRING_INVALID_KEY);
-        return 1;
-    }
-
     p = strchrW(key_name, '\\');
     if (p) p++;
 
@@ -909,6 +888,7 @@ int wmain(int argc, WCHAR *argvW[])
     int i, op;
     BOOL show_op_help = FALSE;
     WCHAR *key_name;
+    HKEY root;
     static const WCHAR slashDW[] = {'/','d',0};
     static const WCHAR slashFW[] = {'/','f',0};
     static const WCHAR slashSW[] = {'/','s',0};
@@ -964,6 +944,13 @@ int wmain(int argc, WCHAR *argvW[])
     if (!sane_path(key_name))
         return 1;
 
+    root = path_get_rootkey(key_name);
+    if (!root)
+    {
+        output_message(STRING_INVALID_KEY);
+        return 1;
+    }
+
     if (op == REG_ADD)
     {
         WCHAR *value_name = NULL, *type = NULL, separator = '\0', *data = NULL;
@@ -1005,8 +992,7 @@ int wmain(int argc, WCHAR *argvW[])
             else if (!lstrcmpiW(argvW[i], slashFW))
                 force = TRUE;
         }
-        return reg_add(key_name, value_name, value_empty, type, separator,
-            data, force);
+        return reg_add(root, key_name, value_name, value_empty, type, separator, data, force);
     }
     else if (op == REG_DELETE)
     {
@@ -1030,7 +1016,7 @@ int wmain(int argc, WCHAR *argvW[])
             else if (!lstrcmpiW(argvW[i], slashFW))
                 force = TRUE;
         }
-        return reg_delete(key_name, value_name, value_empty, value_all, force);
+        return reg_delete(root, key_name, value_name, value_empty, value_all, force);
     }
     else if (op == REG_QUERY)
     {
@@ -1052,7 +1038,7 @@ int wmain(int argc, WCHAR *argvW[])
             else if (!lstrcmpiW(argvW[i], slashSW))
                 recurse = TRUE;
         }
-        return reg_query(key_name, value_name, value_empty, recurse);
+        return reg_query(root, key_name, value_name, value_empty, recurse);
     }
     else
     {




More information about the wine-cvs mailing list