Release 961201

Sat Nov 30 19:21:17 1996  Alexandre Julliard  <julliard@lrc.epfl.ch>

	* [configure]
	Re-generated with autoconf 2.11. Let me know if you have
	problems.

	* [controls/listbox.c] [controls/oldlbox.c]
	Listboxes rewritten from scratch. Moved old code still used by
	comboboxes to oldlbox.c

	* [misc/registry.c]
	Use temporary file when saving registry.

	* [windows/dialog.c]
	Implemented Win32 version of DlgDirList() and DlgDirListComboBox().

	* [windows/winproc.c]
	Added translation for listbox Win32 messages.

Sat Nov 30 21:00:00 Alex Korobka <alex@trantor.pharm.sunysb.edu>

	* [controls/widgets.c] [controls/button.c]
	Fixed some incompatibilities with CTL3D DLL.

	* [windows/dialog.c]
	Made dialog windows fit into the desktop.

	* [misc/winsock.c] [misc/winsock_async.c]
	New Winsock engine.

	* [windows/message.c]
	GetMessage() fixes.

	* [windows/queue.c] [windows/hook.c] [windows/win.c]
	SetMessageQueue() fixes.

Fri Nov 29 10:25:12 1996  Slaven Rezic  <eserte@cs.tu-berlin.de>

	* [objects/text.c]
	DrawText16(): Fixed return value.

Tue Nov 26 14:47:09 1996  Marcus Meissner <msmeissn@cip.informatik.uni-erlangen.de>

	* [files/profile.c] [*/*]
	Added Win32 profile functions, updated to new naming standard.

	* [objects/font.c] [if1632/thunk.c] [include/windows.h]
	Added EnumFonts32*, EnumFontFamiliesEx*, changed prototypes and
	structures.

	* [misc/ole2nls.c] [if1632/thunk.c]
	Added EnumSystemLocales() (winhelp.exe).

	* [misc/registry.c]
	Added Windows 3.1 registry loader supplied by Tor Sjxwall, tor@sn.no

	* [win32/file.c]
	Partially fixed CreateFileMapping(), added UnmapViewOfFile().

Sat Nov 23 23:36:05 1996  Ronan Waide  <waider@waider.ie>

	* [misc/shell.c]
	Fixed some FIXMEs relating to ShellExec() and FindExecutable().

	* [misc/main.c]
	Implemented a few more of the SystemParametersInfo() cases.

Tue Nov 19 01:24:34 1996  Philippe De Muyter  <phdm@info.ucl.ac.be>

	* [include/keyboard.h]
	New file, new macro WINE_VKEY_MAPPINGS (using code taken from event.c).

	* [include/windows.h]
	New [VK_A, VK_Z] and [VK_0, VK9] macros.

	* [misc/keyboard.c]
	Fixes in KeyTable and ToAscii.

	* [objects/font.c]
	FONT_init : Give default value for MSWIN "system" font.
	FONT_MatchFont : Do not try every size of a font family if the
	family does not exist.

	* [windows/event.c]
	lastEventChar hack removed.
	KeyStateTable replaced by InputKeyStateTable (maintained in event.c)
	and QueueKeyStateTable (maintained in message.c).
	EVENT_key : Corrections to the extended bit setting.

	* [windows/message.c] [windows/keyboard.c]
	Implementation of a new QueueKeyStateTable : table of key states
	valid when messages are retrieved by GetMessage or PeekMessage,
	and valid for TranslateMessage.
	TranslateMessage : Convert WM*KEY messages using QueueKeyStateTable
	and ToAscii.
	
Mon Nov 18 16:59:01 1996  Robert Pouliot <krynos@clic.net>

	* [graphics/Makefile.in] [graphics/wing.c]
	  [if1632/wing.spec]
	Some functions for WinG support, mostly empty stubs.

	* [misc/crtdll.c] [if1632/crtdll.spec]
	Many functions added to CRTDLL, mostly calls to Unix C library.
diff --git a/misc/shell.c b/misc/shell.c
index 3a96897..2f9cc8b 100644
--- a/misc/shell.c
+++ b/misc/shell.c
@@ -195,29 +195,34 @@
     /* extensions; however, it'd make sense to check the programs */
     /* section first, so that's what happens here. */
 
-    /* See if it's a program */
-    GetProfileString("windows", "programs", "exe pif bat com",
-		      buffer, sizeof(buffer)); /* FIXME check return code! */
+    /* See if it's a program - if GetProfileString fails, we skip this
+     * section. Actually, if GetProfileString fails, we've probably
+     * got a lot more to worry about than running a program... */
+    if ( GetProfileString32A("windows", "programs", "exe pif bat com",
+						  buffer, sizeof(buffer)) > 0 )
+	  {
+		for (i=0;i<strlen(buffer); i++) buffer[i]=tolower(buffer[i]);
 
-    for (i=0;i<strlen(buffer); i++) buffer[i]=tolower(buffer[i]);
+		tok = strtok(buffer, " \t"); /* ? */
+		while( tok!= NULL)
+		  {
+			if (strcmp(tok, &tmpext[1])==0) /* have to skip the leading "." */
+			  {
+				strcpy(lpResult, xlpFile);
+				/* Need to perhaps check that the file has a path
+				 * attached */
+				dprintf_exec(stddeb, "SHELL_FindExecutable: found %s\n",
+							 lpResult);
+	    return 33;
 
-    tok = strtok(buffer, " \t"); /* ? */
-    while( tok!= NULL)
-    {
-	if (strcmp(tok, &tmpext[1])==0) /* have to skip the leading "." */
-	{
-	    strcpy(lpResult, xlpFile); /* Need to perhaps check that */
-				      /* the file has a path attached */
-	    dprintf_exec(stddeb, "SHELL_FindExecutable: found %s\n",
-			 lpResult);
-	    return 33; /* Greater than 32 to indicate success FIXME */
-		       /* According to the docs, I should be returning */
-		       /* a handle for the executable. Does this mean */
-		       /* I'm supposed to open the executable file or */
-		       /* something? More RTFM, I guess... */
-	}
-	tok=strtok(NULL, " \t");
-    }
+		/* Greater than 32 to indicate success FIXME According to the
+		 * docs, I should be returning a handle for the
+		 * executable. Does this mean I'm supposed to open the
+		 * executable file or something? More RTFM, I guess... */
+			  }
+			tok=strtok(NULL, " \t");
+		  }
+	  }
 
     /* Check registry */
     if (RegQueryValue16( (HKEY)HKEY_CLASSES_ROOT, tmpext, filetype,
@@ -249,32 +254,34 @@
 		    strcat( lpResult, &tok[2] );
 		}
 	    }
-	    retval=33;
+	    retval=33; /* FIXME see above */
 	}
     }
     else /* Check win.ini */
     {
 	/* Toss the leading dot */
 	extension++;
-	GetProfileString( "extensions", extension, "", command,
-			 sizeof(command));
-	if (strlen(command)!=0)
-	{
-	    strcpy( lpResult, command );
-	    tok=strstr( lpResult, "^" ); /* should be ^.extension? */
-	    if (tok != NULL)
-	    {
-		tok[0]='\0';
-		strcat( lpResult, xlpFile ); /* what if no dir in xlpFile? */
-		tok=strstr( command, "^" ); /* see above */
-		if ((tok != NULL) && (strlen(tok)>5))
-		{
-		    strcat( lpResult, &tok[5]);
-		}
-	    }
-	    retval=33;
+	if ( GetProfileString32A( "extensions", extension, "", command,
+                                  sizeof(command)) > 0)
+	  {
+		if (strlen(command)!=0)
+		  {
+			strcpy( lpResult, command );
+			tok=strstr( lpResult, "^" ); /* should be ^.extension? */
+			if (tok != NULL)
+			  {
+				tok[0]='\0';
+				strcat( lpResult, xlpFile ); /* what if no dir in xlpFile? */
+				tok=strstr( command, "^" ); /* see above */
+				if ((tok != NULL) && (strlen(tok)>5))
+				  {
+					strcat( lpResult, &tok[5]);
+				  }
+			  }
+			retval=33; /* FIXME - see above */
+		  }
+	  }
 	}
-    }
 
     dprintf_exec(stddeb, "SHELL_FindExecutable: returning %s\n", lpResult);
     return retval;
@@ -804,7 +811,7 @@
  */
 int RegisterShellHook(void *ptr) 
 {
-	fprintf(stdnimp, "RegisterShellHook : Empty Stub !!!\n");
+	fprintf(stdnimp, "RegisterShellHook( %p ) : Empty Stub !!!\n", ptr);
 	return 0;
 }