Release 971116

Sun Nov 16 07:42:44 1997  Alex Korobka <alex@trantor.pharm.sunysb.edu>

	* [windows/dce.c] [windows/clipboard.c] [windows/nonclient.c]
	Bug fixes.

	* [misc/shell.c] [resources/*]
	New "About" dialog.

Sat Nov 15 17:30:18 1997  Alexandre Julliard  <julliard@lrc.epfl.ch>

	* [configure.in] [Makefile.in]
	Replaced --with-library option by --disable-emulator. The default
 	is now to build both the library and the emulator.
	Renamed --with options to --enable to follow autoconf guidelines.

	* [loader/main.c] [miscemu/main.c] (New file)
	Split initialization in WinelibInit/EmulatorInit.

	* [loader/*.c]
	Removed all remaining #ifdef's WINELIB.

	* [controls/widgets.c] [windows/mdi.c]
	Converted MDIClientWndProc to 32-bit.

	* [debugger/break.c] [if1632/signal.c] [include/selectors.h]
	  [scheduler/thread.c]
	Code and data selector values are now computed at run-time.

	* [library/libres.c]
	Moved to loader/ directory.

	* [misc/main.c] [misc/version.c] (New file)
	Moved all version stuff to version.c. Cleaned up a bit.

	* [msdos/dpmi.c]
	Update the REALMODECALL structure on return from real-mode
	interrupt.

	* [windows/event.c] [windows/keyboard.c]
	Changed the way event coordinates are determined. Don't rely on
	the ConfigureNotify event values. This should fix all problems
	with cursor position in -desktop and -managed modes.

Sat Nov 15 16:09:36 1997  Slaven Rezic  <eserte@cs.tu-berlin.de>

	* [controls/button.c]
	(BUTTON_CheckAutoRadioButton): Prevent possible endless loop.

Wed Nov 12 03:42:45 1997  Chris Faherty <chrisf@america.com>

	* [misc/ver.c]
	Changed VerInstall32A to assume srcdir as destination if destdir
	is blank.  This was causing alot of DLL installation into SYSTEM
	directory to fail.

	* [loader/ne_image.c]
	NE_LoadSegment buffer[100] was too small and getting overruns.
	Changed it to buffer[200].

Sat Nov  8 06:09:57 1997  Len White <phreak@cgocable.net>

	* [misc/ddeml.c] [include/ddeml.h] [if1632/ddeml.spec]
	Added stub functions DdeConnectList(), DdeQueryNextServer(),
	DdeDisconnectList(), DdeSetUserHandle(), DdeAbandonTransaction(),
	DdePostAdvise(), DdeCreateDataHandle(), DdeAddData(), DdeGetData(),
	DdeAccessData(), DdeUnaccessData(), DdeEnableCallback(),
	DdeCmpStringHandles().

Fri Nov  7 19:44:26 1997  Olaf Flebbe  <o.flebbe@science-computing.de>

	* [files/directory.c]
	Fix typo in directory.c [broke loading of cdplayer on nt40]

	* [misc/main.c]
	Implemented -winver nt40.

	* [loader/resource.c] [user32.spec]
	Stubs for CopyAcceleratorTable, Destroy AcceleratorTable.

Thu Nov  6 22:37:04 1997  Morten Welinder  <welinder@rentec.com>

	* [files/drive.c]
	(GetDiskFreeSpace32A): Cap at 2GB.

	* [include/windows.h]
	Prototype DrawIconEx and CreateDIBSection32.
	Define OBM_RADIOCHECK.
	Add DI_* macros.

	* [objects/dib.c] [if1632/gdi.spec]
	CreateDIBSection is a WINAPI.  Renamed to CreateDIBSection32.
	Implement CreateDIBSection16.

	* [if1632/user.spec] [if1632/user32.spec]
	Add DrawIconEx.

	* [objects/cursoricon.c]
	(CopyIcon32): Fix bogus implementation.

	* [objects/bitmap.c]
	(CopyBitmap32): New function.
	(CopyImage32): Do bitmaps.

	* [graphics/x11drv/text.c]
	(X11DRV_ExtTextOut): Change ascent and descent default to avoid
	zero-thinkness overstrike line.

	* [include/debugstr.h] [misc/debugstr.c]
	New files.

	* [msdos/dpmi.c]
	Don't prototype do_mscdex. In INT_Int31Handler, handle real-mode
	int 0x21, ah=0x52.

	* [msdos/int2f.c]
	Add dummys for 0x1681 and 0x1682.

	* [misc/registry.c]
	Fix memory leaks in RegDeleteKey32W.

	* [objects/text.c]
	In TEXT_NextLine, fix another off-by-one bug.

	* [include/bitmaps/obm_radiocheck]
	New file.  (It a small circle used to radio-button menu items
	when selected.)
	
	* [objects/oembitmap.c]
	Add obm_radiocheck.

	* [include/windows.h] [if1632/user32.spec] [controls/menu.c]
	  [if1632/user.spec]
	Define CheckMenuRadioItem{16,32}.  Define GetMenuItemRect{16,32}.

Wed Nov  5 11:30:14 1997  Marcus Meissner <msmeissn@cip.informatik.uni-erlangen.de>
	* [misc/main.c]
	Auto adjust versions depending on binary.

Tue Nov  4 15:21:00 1997  Kristian Nielsen  <kristian.nielsen@risoe.dk>

	* [controls/listbox.c]
	Paint full background in listbox items with tab stops enabled.

	* [if1632/thunk.c]
	Copy some more message parameter structures (DRAWITEMSTRUCT16,
	COMPAREITEMSTRUCT16) to the stack segment to fix broken programs
	that need this.

	* [windows/dce.c]
	Only clip sibling windows when the parent has the WS_CLIPSIBLINGS
	style set.

	* [windows/focus.c]
	Make order of events in FOCUS_SwitchFocus() reflect API docs.

	* [windows/defdlg.c]
	Fix problem with loss of focus in some dialogs.

	* [win32/code_page.c]
	Fix return value for MultiByteToWideChar().

	* [BUGS]
	BCW now works.
diff --git a/misc/version.c b/misc/version.c
new file mode 100644
index 0000000..5e0d7bb
--- /dev/null
+++ b/misc/version.c
@@ -0,0 +1,262 @@
+/*
+ * Windows version functions
+ *
+ * Copyright 1997 Alexandre Julliard
+ * Copyright 1997 Marcus Meissner
+ */
+
+#include <stdio.h>
+#include "windows.h"
+#include "winbase.h"
+#include "process.h"
+#include "options.h"
+
+typedef enum
+{
+    WIN31, /* Windows 3.1 */
+    WIN95, /* Windows 95 */
+    NT351, /* Windows NT 3.51 */
+    NT40,  /* Windows NT 4.0 */
+    NB_VERSIONS
+} VERSION;
+
+typedef struct
+{
+    LONG             getVersion16; 
+    LONG             getVersion32;
+    OSVERSIONINFO32A getVersionEx;
+} VERSION_DATA;
+
+
+/* FIXME: compare values below with original and fix */
+static const VERSION_DATA VersionData[NB_VERSIONS] =
+{
+    /* WIN31 */
+    {
+	MAKELONG( 0x0a03, 0x0616 ), /* DOS 6.22 */
+	MAKELONG( 0x0a03, 0x8000 ),
+	{
+            sizeof(OSVERSIONINFO32A), 3, 10, 0,
+            VER_PLATFORM_WIN32s, "Win32s 1.3" 
+	}
+    },
+    /* WIN95 */
+    {
+        0x07005F03,
+        0xC0000004,
+	{
+            sizeof(OSVERSIONINFO32A), 4, 0, 0x40003B6,
+            VER_PLATFORM_WIN32_WINDOWS, "Win95"
+	}
+    },
+    /* NT351 */
+    {
+        0x05000A03,
+        0x04213303,
+        {
+            sizeof(OSVERSIONINFO32A), 3, 51, 0x421,
+            VER_PLATFORM_WIN32_NT, "Service Pack 2"
+	}
+    },
+    /* NT40 */
+    {
+        0x05000A03,
+        0x05650004,
+        {
+            sizeof(OSVERSIONINFO32A), 4, 0, 0x565,
+            VER_PLATFORM_WIN32_NT, "Service Pack 3"
+        }
+    }
+};
+
+static const char *VersionNames[NB_VERSIONS] =
+{
+    "win31",
+    "win95",
+    "nt351",
+    "nt40"
+};
+
+/* the current version has not been autodetected but forced via cmdline */
+static BOOL32 versionForced = FALSE;
+static VERSION defaultVersion = WIN31;
+
+
+/**********************************************************************
+ *         VERSION_ParseVersion
+ */
+void VERSION_ParseVersion( char *arg )
+{
+    int i;
+    for (i = 0; i < NB_VERSIONS; i++)
+    {
+        if (!strcmp( VersionNames[i], arg ))
+        {
+            defaultVersion = (VERSION)i;
+            versionForced = TRUE;
+            return;
+        }
+    }
+    fprintf( stderr, "Invalid winver value '%s' specified.\n", arg );
+    fprintf( stderr, "Valid versions are:" );
+    for (i = 0; i < NB_VERSIONS; i++)
+        fprintf( stderr, " '%s'%c", VersionNames[i],
+                 (i == NB_VERSIONS - 1) ? '\n' : ',' );
+}
+
+
+/**********************************************************************
+ *         VERSION_get_version
+ */
+static VERSION VERSION_GetVersion(void)
+{
+    LPIMAGE_NT_HEADERS peheader;	
+
+    if (versionForced) /* user has overridden any sensible checks */
+        return defaultVersion;
+    if (!pCurrentProcess) /* at startuptime probably */
+        return defaultVersion;
+    if (!pCurrentProcess->exe_modref)
+        return WIN31; /* FIXME: hmm, look at DDB.version ? */
+    peheader = pCurrentProcess->exe_modref->pe_module->pe_header;
+    if (peheader->OptionalHeader.MajorSubsystemVersion == 4)
+        /* FIXME: NT4 has the same majorversion; add a check here for it. */
+        return WIN95;
+    if (peheader->OptionalHeader.MajorSubsystemVersion == 3)
+    {
+        /* Win3.10 */
+        if (peheader->OptionalHeader.MinorSubsystemVersion <= 11) return WIN31;
+        /* NT 3.51 */
+        if (peheader->OptionalHeader.MinorSubsystemVersion == 51) return NT351;
+    }
+    fprintf(stderr,"VERSION_GetVersion: unknown subsystem version: %04x.%04x, please report.\n",
+            peheader->OptionalHeader.MajorSubsystemVersion,
+            peheader->OptionalHeader.MinorSubsystemVersion );
+    return defaultVersion;
+}
+
+
+/***********************************************************************
+ *         GetVersion16   (KERNEL.3)
+ */
+LONG WINAPI GetVersion16(void)
+{
+    VERSION ver = VERSION_GetVersion();
+    return VersionData[ver].getVersion16;
+}
+
+
+/***********************************************************************
+ *         GetVersion32   (KERNEL32.427)
+ */
+LONG WINAPI GetVersion32(void)
+{
+    VERSION ver = VERSION_GetVersion();
+    return VersionData[ver].getVersion32;
+}
+
+
+/***********************************************************************
+ *         GetVersionEx32A   (KERNEL32.428)
+ */
+BOOL32 WINAPI GetVersionEx32A(OSVERSIONINFO32A *v)
+{
+    VERSION ver = VERSION_GetVersion();
+    if (v->dwOSVersionInfoSize != sizeof(OSVERSIONINFO32A))
+    {
+        fprintf(stderr,"wrong OSVERSIONINFO size from app");
+        return FALSE;
+    }
+    v->dwMajorVersion = VersionData[ver].getVersionEx.dwMajorVersion;
+    v->dwMinorVersion = VersionData[ver].getVersionEx.dwMinorVersion;
+    v->dwBuildNumber  = VersionData[ver].getVersionEx.dwBuildNumber;
+    v->dwPlatformId   = VersionData[ver].getVersionEx.dwPlatformId;
+    strcpy( v->szCSDVersion, VersionData[ver].getVersionEx.szCSDVersion );
+    return TRUE;
+}
+
+
+/***********************************************************************
+ *         GetVersionEx32W   (KERNEL32.429)
+ */
+BOOL32 WINAPI GetVersionEx32W(OSVERSIONINFO32W *v)
+{
+    VERSION ver = VERSION_GetVersion();
+    if (v->dwOSVersionInfoSize!=sizeof(OSVERSIONINFO32W))
+    {
+        fprintf(stderr,"wrong OSVERSIONINFO size from app");
+        return FALSE;
+    }
+    v->dwMajorVersion = VersionData[ver].getVersionEx.dwMajorVersion;
+    v->dwMinorVersion = VersionData[ver].getVersionEx.dwMinorVersion;
+    v->dwBuildNumber  = VersionData[ver].getVersionEx.dwBuildNumber;
+    v->dwPlatformId   = VersionData[ver].getVersionEx.dwPlatformId;
+    lstrcpyAtoW( v->szCSDVersion, VersionData[ver].getVersionEx.szCSDVersion );
+    return TRUE;
+}
+
+
+/***********************************************************************
+ *	    GetWinFlags   (KERNEL.132)
+ */
+DWORD WINAPI GetWinFlags(void)
+{
+  static const long cpuflags[5] =
+    { WF_CPU086, WF_CPU186, WF_CPU286, WF_CPU386, WF_CPU486 };
+  SYSTEM_INFO si;
+  OSVERSIONINFO32A ovi;
+  DWORD result;
+
+  GetSystemInfo(&si);
+
+  /* There doesn't seem to be any Pentium flag.  */
+  result = cpuflags[MIN (si.wProcessorLevel, 4)];
+
+  switch(Options.mode)
+  {
+  case MODE_STANDARD:
+      result |= WF_STANDARD | WF_PMODE | WF_80x87;
+      break;
+
+  case MODE_ENHANCED:
+      result |= WF_ENHANCED | WF_PMODE | WF_80x87 | WF_PAGING;
+      break;
+
+  default:
+      fprintf(stderr, "Unknown mode set? This shouldn't happen. Check GetWinFlags()!\n");
+      break;
+  }
+  if (si.wProcessorLevel >= 4) result |= WF_HASCPUID;
+  ovi.dwOSVersionInfoSize = sizeof(ovi);
+  GetVersionEx32A(&ovi);
+  if (ovi.dwPlatformId == VER_PLATFORM_WIN32_NT)
+      result |= WF_WIN32WOW; /* undocumented WF_WINNT */
+  return result;
+}
+
+
+/***********************************************************************
+ *	    GetWinDebugInfo   (KERNEL.355)
+ */
+BOOL16 WINAPI GetWinDebugInfo(WINDEBUGINFO *lpwdi, UINT16 flags)
+{
+    printf("GetWinDebugInfo(%8lx,%d) stub returning 0\n",
+           (unsigned long)lpwdi, flags);
+    /* 0 means not in debugging mode/version */
+    /* Can this type of debugging be used in wine ? */
+    /* Constants: WDI_OPTIONS WDI_FILTER WDI_ALLOCBREAK */
+    return 0;
+}
+
+
+/***********************************************************************
+ *	    SetWinDebugInfo   (KERNEL.356)
+ */
+BOOL16 WINAPI SetWinDebugInfo(WINDEBUGINFO *lpwdi)
+{
+    printf("SetWinDebugInfo(%8lx) stub returning 0\n", (unsigned long)lpwdi);
+    /* 0 means not in debugging mode/version */
+    /* Can this type of debugging be used in wine ? */
+    /* Constants: WDI_OPTIONS WDI_FILTER WDI_ALLOCBREAK */
+    return 0;
+}