find applet by name (fixes bug #1063)
Modified: trunk/reactos/lib/shell32/control.c

Modified: trunk/reactos/lib/shell32/control.c
--- trunk/reactos/lib/shell32/control.c	2005-12-11 14:35:33 UTC (rev 20064)
+++ trunk/reactos/lib/shell32/control.c	2005-12-11 15:18:39 UTC (rev 20065)
@@ -352,6 +352,7 @@
     unsigned 	sp = 0;
     LPWSTR	extraPmts = NULL;
     int        quoted = 0;
+    BOOL	spSet = FALSE;
 
     buffer = HeapAlloc(GetProcessHeap(), 0, (lstrlenW(wszCmd) + 1) * sizeof(*wszCmd));
     if (!buffer) return;
@@ -366,8 +367,10 @@
 	    if (beg) {
 	        if (*beg == '@') {
 		    sp = atoiW(beg + 1);
+                    spSet = TRUE;
 		} else if (*beg == '\0') {
 		    sp = 0;
+                    spSet = TRUE;
 		} else {
 		    extraPmts = beg;
 		}
@@ -381,6 +384,9 @@
     while ((ptr = StrChrW(buffer, '"')))
 	memmove(ptr, ptr+1, lstrlenW(ptr)*sizeof(WCHAR));
 
+    while ((ptr = StrChrW(extraPmts, '"')))
+	memmove(ptr, ptr+1, lstrlenW(ptr)*sizeof(WCHAR));
+
     TRACE("cmd %s, extra %s, sp %d\n", debugstr_w(buffer), debugstr_w(extraPmts), sp);
 
     Control_LoadApplet(hWnd, buffer, panel);
@@ -393,6 +399,13 @@
 	  WARN("Out of bounds (%u >= %u), setting to 0\n", sp, applet->count);
 	  sp = 0;
        }
+
+       if ((extraPmts)&&(!spSet))
+       {
+          while ((lstrcmpiW(extraPmts, applet->info[sp].szName)) && (sp < applet->count))
+            sp++;
+       }
+
        if (applet->info[sp].dwSize) {
 	  if (!applet->proc(applet->hWnd, CPL_STARTWPARMSA, sp, (LPARAM)extraPmts))
 	     applet->proc(applet->hWnd, CPL_DBLCLK, sp, applet->info[sp].lData);