Release 940405

Tue Apr  5 14:36:59 1994  Bob Amstadt  (bob@pooh)

	* [include/mdi.h] [windows/mdi.c]
	Use WM_PARENTNOTIFY messages to activate children.
	Generate WM_CHILDACTIVATE messages.
	Beginnings handler for maxmized child window.
	Clean up when children are destroyed.

	* [windows/message.c] [windows/nonclient.c] [windows/winpos.c]
	Removed code add 94/03/26.

Apr 4, 94 martin2@trgcorp.solucorp.qc.ca (Martin Ayotte)

	* [control/menu.c]
	Make mouse menu navigation working again. :-))
	(be carefull, clicking outside menus (ie.: clientrect) 
	not resolved yet)

	* [windows/nonclient.c]  [controls/scroll.c]
	Bugs fix in NCTrackScrollBars().

	* [misc/dos_fs.c]
	Bug fix in 'ToDos()' in conversion for '/',
		(example: '/window/' was translated to 'WINDOWs').

	* [miscemu/int21.c]
	Function ChangeDir() extract possible drive before DOS_ChangeDir().

	* [loader/library.c]  [loader/wine.c]
	Playing around moving function GetProcAddress() and put some code in.

Mon Apr  4 21:39:07 1994  Alexandre Julliard (julliard@lamisun.epfl.ch)

	* [misc/main.c]
	Better explanation of command-line options.

	* [objects/dib.c]
	Implemented SetDIBitsToDevice().

	* [windows/dc.c]
	Bug fix in SetDCState().

	* [windows/event.c]
	Removed WS_DISABLED handling (now done in message.c).

	* [windows/message.c]
	Added sending a WM_PARENTNOTIFY message in MSG_TranslateMouseMsg().
	Use WindowFromPoint() to find the window for mouse events, taking
	into account disabled windows.

	* [windows/painting.c]
	Bug fix in BeginPaint() to allow calling it at other times than
	on WM_PAINT (Solitaire needs it...)

	* [windows/win.c]
	Implemented FindWindow().
	Rewritten EnableWindow() to behave more like Windows.

	* [windows/winpos.c]
	Rewritten WindowFromPoint() to also search child windows.

Mon Apr  4 17:36:32 1994  Erik Bos (erik@trashcan.hacktic.nl)

	* [include/int21.h] -> [msdos.h]
	renamed.

	* [miscemu/int10.h] [miscemu/int25.h] [miscemu/int26.h] 
	new, added for int 10, 25 and 26.

	* [miscemu/ioports.c]
	new, added to allow win apps to use ioports.

	* [loader/signal.c]
	Added support for in, inb, out, outb instructions.

Sun Mar 27 13:40:25 1994  Bob Amstadt  (bob@pooh)

	* controls/menu.c (InsertMenu): Changed to use FindMenuItem().

Sat Mar 26 21:23:55 1994  Bob Amstadt  (bob@pooh)

	* [windows/mdi.c]
	Window list properly updated.

	* [windows/message.c]
	Call WINPOS_ChildActivate() when mouse pressed.

	* [windows/nonclient.c]
	Use WINPOS_IsAnActiveWindow() instead of GetActiveWindow() in
	NC_HandleNCPaint().

	* [windows/winpos.c]
	Created functions WINPOS_IsAnActiveWindow() and WINPOS_ActivateChild()

Thu Mar 24 14:49:17 1994  Bob Amstadt  (bob@pooh)

	* controls/menu.c (DeleteMenu): Changed to use FindMenuItem
	(DeleteMenu): Many bug fixes.

	* [controls/menu.c]
	Created function FindMenuItem().

Thu Mar 24 14:17:24 1994  Bob Amstadt  (bob@pooh)

	* [windows/win.c]
	Removed incorrect MDI handling code from CreateWindowEx().

	* [controls/menu.c]
	MF_STRING items needed to allocate a private copy of string.

	* [controls/menu.c]
	Fixed buggy calls to GlobalFree().

	* [memory/global.c]
	Eliminated some redundant code with function call.

Wed Mar 23 1994 Pentti Moilanen (pentti.moilanen@ntc.nokia.com)

	* [windows/timer.c]
	timer list pointers looped in InsertTimer

Tue Mar 29 13:32:08 MET DST 1994  julliard@di.epfl.ch (Alexandre Julliard)

	* [misc/cursor.c]
	A few changes for desktop window support.

	* [misc/main.c]
	Added -depth option.

	* [misc/rect.c]
	Yet another bug fix in SubtractRect().

	* [objects/bitmap.c]
	Changes to use only one depth (specified with -depth)
	for color bitmaps.

	* [objects/brush.c]
	Added support for dithered solid brushes.

	* [objects/color.c]
	Use the same 20 system colors as in Windows.
	System palette initialisation now done in COLOR_InitPalette().
	Added support for a color mapping table to map logical color
	indexes to X colormap entries.
	Implemented GetNearestColor() and RealizeDefaultPalette().

	* [objects/dib.c]
	Added support for color mapping table.

	* [objects/dither.c]  (New file)
	Implemented solid color dithering.

	* [objects/palette.c]
	Implemented GetSystemPaletteEntries() and SelectPalette().

	* [windows/class.c]
	Make a copy of the menu name in RegisterClass().

	* [windows/dc.c]
	Fixed device caps when using a desktop window.
	Added support for the color mapping table in DCs.

	* [windows/event.c]
	Added ConfigureNotify handler on desktop window.

	* [windows/message.c]
	Removed call to XTranslateCoordinates() on every mouse motion
	New function MSG_Synchronize() to synchronize with the X server.

	* [windows/syscolor.c]
	Rewritten SYSCOLOR_Init() to read the system colors from WIN.INI.

	* [windows/winpos.c]
	Added synchronization on window mapping. Solves the double redraw
	problem when starting Solitaire.

Mar 27, 94 martin2@trgcorp.solucorp.qc.ca (Martin Ayotte)

	* [control/menu.c]	* [windows/defwnd.c]
	Make keyboard navigation working with menubar,
	but temporarely inserted a bug in menubar mouse handling ... :-((
	(it will be fix next week !)

	* [windows/defwnd.c]
	Connect VK_MENU to menubar navigation.

	* [loader/library.c]
	GetModuleHandle() return 'fictive 0xF000+ handles' for built-in DLLs.

Sun Mar 20 22:32:13 1994 Erik Bos (erik@trashcan.hacktic.nl)

	* [misc/main.c]
	Added Copy(). Added a check for `-h' to show usage.

	* [misc/dos_fs.c]
	Fixed bug in FindFile(), to load directories as dlls.

	* [misc/dos_fs.c]
	Fixed ToUnix() and ToDos() again, as my previous patch
	didn't make it.

	* [misc/dos_fs.c] [miscemu/int21.c]
	Bug fixes, should be able to handle all winfile and progman int21
	requests now except for a few small things.

Tue Mar 29 06:25:54 1994  crw@harris.mlb.semi.harris.com (Carl Williams)

	* [memory/heap.c]
	Implemented GetFreeSystemResources().

Mon Mar 21 17:32:25 1994  Bob Amstadt  (bob@pooh)

	* controls/menu.c (GetSubMenu): Function did not return correct value

	* [windows/mdi.c]
	Beginnings of menu handling.

Thu Mar 10 11:32:06 1994  Stefan (SAM) Muenzel  (muenzel@tat.physik.uni-tuebingen.de)

	* [objects/font.c]
	if font.width equals zero use asterix instead.

Mon Mar 21 17:23:37 MET 1994  julliard@di.epfl.ch (Alexandre Julliard)

	* [objects/bitmap.c]
	Rewritten bitmap code to use exclusively X pixmaps; *much* faster.

	* [objects/brush.c]
	Some changes with pattern brushes because of the new bitmap code.

	* [objects/color.c]
	Added function COLOR_ToPhysical for better color mapping.

	* [objects/dib.c]
	Heavily optimized SetDIBits().

	* [windows/dc.c]
	Opimized SetDCState() and DC_SetupGC*() functions.
	Added stub for CreateIC().

Mar 20, 94 martin2@trgcorp.solucorp.qc.ca (Martin Ayotte)

	* [misc/message.c]
	Call SetFocus() after closing box to give back focus to previous owner.

	* [misc/files.c]
	Small bug fix in GetTempFilename() : replace a '\' to '\\'.

	* [control/scroll.c]
	Calls to BitBlt() replace by StretchBlt().

	* [control/menu.c]
	Call SetFocus() to previous owner after closing Popups.	
	Fill stub DeleteMenu().

	* [control/listbox.c]
	* [control/combo.c]
	Use SetFocus() in WM_LBUTTONDOWN.
	Close ComboBox List upon WM_KILLFOCUS.
	Early development of WM_MEASUREITEM mecanism.

	* [windows/defwnd.c]
	Early development of WM_MEASUREITEM mecanism.

Tue Mar 22 10:44:57 1994  Miguel de Icaza  (miguel@xochitl)

	* [misc/atom.c]
	Fixed sintaxis problem when building the library.

Tue Mar 15 13:11:56 1994  Bob Amstadt  (bob@pooh)

	* [include/windows.h]
	Added message types and structures for MDI

	* [include/mdi.h]
	Created internal structures for handling MDI

	* [windows/mdi.c]
	Began creating MDI support

Thu Mar 10 16:51:46 1994  Bob Amstadt  (bob@pooh)

	* [loader/wine.c] [include/wine.h]
	Added new field to "struct w_files" to hold the "name table"
	resource for Windows 3.0 programs

	* [loader/resource.c]
	Added code to handle programs with a "name table" resource.
	LoadResourceByName() modified to check for the existence of
	this resource.

Mon Mar 14 22:31:42 MET 1994  julliard@di.epfl.ch (Alexandre Julliard)

	* [objects/color.c]
	Added installing the private colormap on the desktop window.

	* [windows/event.c]
	Cleaned up focus event handling (see focus.c).
	Use GetFocus() to direct key events to the correct window.

	* [windows/focus.c]
	Rewritten SetFocus() to:
	- only set X focus on top-level windows
	- send WM_SETFOCUS and WM_KILLFOCUS messages (was done in event.c)
	- prevent setting focus to disabled windows
	- install private colormap so -privatemap option works again

	* [windows/message.c] [windows/timer.c]
	Changed timer management to no longer use PostMessage(), but
	to generate timer messages on the fly. Also fixed a related bug
	in GetMessage() which could cause busy-waiting.

	* [windows/win.c]
	Only select focus events on top-level windows.

	* [windows/winpos.c]
	Added some sanity checks for desktop window.

Fri Mar  4 20:42:01 1994  Erik Bos (erik@trashcan.hacktic.nl)

	* [misc/dos_fs.c]
	bug fixes in ToUnix(), WinIniFileName(), GetUnixFileName(). 
	Support for tilde symbol added for rootdirectories in [drives]
	section of wine's configfile.

	* [misc/file.c]
	hread(), hwrite() added.

	* [misc/main.c]
	hmemcpy() added.

	* [if1632/stress.spec] [include/stress.h] [misc/stress.c]
	Added STRESS.DLL, an useless dll used to stress a windows system.

	* [*/*]
	Added missing #includes, fixed prototypes for prototype checking.

	* [include/prototypes.h]

	Added prototypes for loader/*c, if1632/*c.

Tue Mar  8 09:54:34 1994  Bob Amstadt  (bob@pooh)

	* [Configure]
	Added reminder to set WINEPATH, if it is not set.

	* [Imakefile]
	Removed #elif's

	* [controls/button.c]
	Added BN_CLICKED notification for owner-draw buttons.

	* [if1632/kernel.spec] [memory/heap.c]
	Changed Local* functions to WIN16_Local* to prevent unconcious use
	of these functions.

	* [if1632/relay.c]
	Push old Stack16Frame on stack before setting.

	* [include/atom.h] [misc/atom.c] [include/heap.h] [memory/local.c]
	Added multiple local heap handling in Atom* functions.

	* [include/regfunc.h] [miscemu/int21.c]
	Rewrote DOS3Call() use context frame that is already on the stack.

	* [misc/profile.c]
	Fixed to allow leading ";" to mark comments.

	* [misc/spy.c]
	Fixed bugs and added support for "include" and "exclude" filters.

	* [misc/user.c]
	Rearranged calls in InitApp().

	* [misc/font.c]
	Fixed font handling to create system fonts, if they are used.

	* [windows/dc.c]
	If text drawn on window with no font specified, then default the
	font to the system font.

Mon Mar  7 20:32:09 MET 1994  julliard@di.epfl.ch (Alexandre Julliard)

	* [controls/desktop.c]
	Added handling of WM_NCCREATE and WM_ERASEBKGND functions.
	Implemented SetDeskPattern().

	* [misc/main.c]
	Added -desktop option to get a large desktop window with
	everything inside it.
	Added -name option.

	* [misc/rect.c]
	Bug fix in SubtractRect().

	* [objects/*.c]
	Replaced the DefaultRootWindow() macro by the rootWindow variable.

	* [windows/event.c] [windows/message.c]
	  [windows/nonclient.c] [windows/win.c]
	A few changes to accomodate the new desktop window.

 Tue Mar  8 11:13:03 1994  Miguel de Icaza  (miguel@xochitl.nuclecu.unam.mx)
 
 	* [toolkit/arch.c] --New file-- 
 	Routines for converting little endian data structures to
 	big-endian data structures, currently only BITMAP structures are 
 	converted.
 
 	* [misc/atom.c]
 	When used as part of the WineLib, the code is much simpler.
 	Doesn't depend on alignement.
 
 	* [loader/wine.c]
 	Ifdefed Emulator dependent code if compiling WineLib.
 
 	* [loader/resource.c]
 	Moved misc/resource.c to loader/resource.c.
 
 	* [loader/dump.c,ldt.c,ldtlib.c,library,c,selector.c,signal.c]
 	Ifdefed whole code if compiling WINELIB.
 
 	* [include/winsock.h]
 	Added compilation define to allow compilation on SunOS.
 
 	* [include/wine.h]
 	Removed load_typeinfo and load_nameinfo prototypes, they belong
 	to neexe.h
 
 	* [include/neexe.h]
 	Added load_typeinfo and load_nameinfo prototypes.
 
 	* [include/arch.h]
 	Fixed some bugs in the conversion routines.
 	Added macros for Bitmap loading.

Tue Mar  8 12:52:05 1994  crw@maniac.mlb.semi.harris.com (Carl Williams)
 	
	* [if1632/kernel.spec] [memory/global.c]
	Implemented GetFreeSpace()

	* [if1632/user.spec] [loader/resource.c]
	Implemented CreateIcon()
diff --git a/windows/win.c b/windows/win.c
index 45157f9..cfc8e85 100644
--- a/windows/win.c
+++ b/windows/win.c
@@ -6,6 +6,8 @@
 
 static char Copyright[] = "Copyright  Alexandre Julliard, 1993";
 
+#include <stdlib.h>
+#include <stdio.h>
 #include <string.h>
 
 #include "class.h"
@@ -19,7 +21,11 @@
 
 extern void EVENT_RegisterWindow( Window w, HWND hwnd );  /* event.c */
 extern void CURSOR_SetWinCursor( HWND hwnd, HCURSOR hcursor );  /* cursor.c */
+extern void WINPOS_ChangeActiveWindow( HWND hwnd, BOOL mouseMsg ); /*winpos.c*/
 extern HMENU CopySysMenu(); /* menu.c */
+extern LONG MDIClientWndProc(HWND hwnd, WORD message, 
+			     WORD wParam, LONG lParam); /* mdi.c */
+
 
 static HWND hwndDesktop = 0;
 
@@ -109,7 +115,8 @@
 HWND WIN_FindWinToRepaint( HWND hwnd )
 {
     WND * wndPtr;
-    
+
+      /* Note: the desktop window never gets WM_PAINT messages */
     if (!hwnd) hwnd = GetTopWindow( hwndDesktop );
     for ( ; hwnd != 0; hwnd = wndPtr->hwndNext )
     {
@@ -133,15 +140,15 @@
  * Send a WM_PARENTNOTIFY to all ancestors of the given window, unless
  * the window has the WS_EX_NOPARENTNOTIFY style.
  */
-static void WIN_SendParentNotify( HWND hwnd, WND * wndPtr, WORD event )
+void WIN_SendParentNotify( HWND hwnd, WORD event, LONG lParam )
 {
     HWND current = GetParent( hwnd );
-
-    if (wndPtr->dwExStyle & WS_EX_NOPARENTNOTIFY) return;
+    WND *wndPtr = WIN_FindWndPtr( hwnd );
+    
+    if (!wndPtr || (wndPtr->dwExStyle & WS_EX_NOPARENTNOTIFY)) return;
     while (current)
     {
-	SendMessage( current, WM_PARENTNOTIFY, 
-		     event, MAKELONG( hwnd, wndPtr->wIDmenu ) );
+	SendMessage( current, WM_PARENTNOTIFY, event, lParam );
 	current = GetParent( current );
     }
 }
@@ -152,19 +159,19 @@
  *
  * Create the desktop window.
  */
-static HWND WIN_CreateDesktopWindow()
+BOOL WIN_CreateDesktopWindow()
 {
-    HWND hwnd;
     WND *wndPtr;
     HCLASS hclass;
     CLASS *classPtr;
 
     if (!(hclass = CLASS_FindClassByName( DESKTOP_CLASS_NAME, &classPtr )))
-	return 0;
+	return FALSE;
 
-    hwnd = USER_HEAP_ALLOC(GMEM_MOVEABLE, sizeof(WND)+classPtr->wc.cbWndExtra);
-    if (!hwnd) return 0;
-    wndPtr = (WND *) USER_HEAP_ADDR( hwnd );
+    hwndDesktop = USER_HEAP_ALLOC( GMEM_MOVEABLE,
+				   sizeof(WND)+classPtr->wc.cbWndExtra );
+    if (!hwndDesktop) return FALSE;
+    wndPtr = (WND *) USER_HEAP_ADDR( hwndDesktop );
 
     wndPtr->hwndNext          = 0;
     wndPtr->hwndChild         = 0;
@@ -187,7 +194,7 @@
     wndPtr->hrgnUpdate        = 0;
     wndPtr->hwndLastActive    = 0;
     wndPtr->lpfnWndProc       = classPtr->wc.lpfnWndProc;
-    wndPtr->dwStyle           = WS_VISIBLE | WS_CLIPCHILDREN;
+    wndPtr->dwStyle           = WS_VISIBLE | WS_CLIPCHILDREN | WS_CLIPSIBLINGS;
     wndPtr->dwExStyle         = 0;
     wndPtr->hdce              = 0;
     wndPtr->hmenuSystem       = 0;
@@ -196,9 +203,15 @@
     wndPtr->wIDmenu           = 0;
     wndPtr->hText             = 0;
     wndPtr->flags             = 0;
-    wndPtr->window            = DefaultRootWindow( display );
+    wndPtr->window            = rootWindow;
     wndPtr->hSysMenu          = 0;
-    return hwnd;
+
+      /* Send dummy WM_NCCREATE message */
+    SendMessage( hwndDesktop, WM_NCCREATE, 0, 0 );
+    EVENT_RegisterWindow( wndPtr->window, hwndDesktop );
+    RedrawWindow( hwndDesktop, NULL, 0,
+		  RDW_INVALIDATE | RDW_ERASE | RDW_ERASENOW );
+    return TRUE;
 }
 
 
@@ -228,18 +241,12 @@
     HANDLE hcreateStruct;
     int wmcreate;
     XSetWindowAttributes win_attr;
-    Window parentWindow;
-    int x_rel, y_rel;
 
 #ifdef DEBUG_WIN
     printf( "CreateWindowEx: %d '%s' '%s' %d,%d %dx%d %08x %x\n",
 	   exStyle, className, windowName, x, y, width, height, style, parent);
 #endif
 
-      /* Before anything, create the desktop window */
-    if (!hwndDesktop)
-	if (!(hwndDesktop = WIN_CreateDesktopWindow())) return 0;
-
     if (x == CW_USEDEFAULT) x = y = 0;
     if (width == CW_USEDEFAULT)
     {
@@ -257,7 +264,7 @@
 	if (!(parentPtr = WIN_FindWndPtr( parent ))) return 0;
     }
     else if (style & WS_CHILD) return 0;  /* WS_CHILD needs a parent */
-    
+
     if (!(class = CLASS_FindClassByName( className, &classPtr ))) {
 	printf("CreateWindow BAD CLASSNAME '%s' !\n", className);
 	return 0;
@@ -345,30 +352,25 @@
 
     win_attr.event_mask = ExposureMask | KeyPressMask | KeyReleaseMask |
 	                 PointerMotionMask | ButtonPressMask |
-			 ButtonReleaseMask | FocusChangeMask | EnterWindowMask;
-    win_attr.override_redirect = True;
-    win_attr.colormap = COLOR_WinColormap;
-    if (style & WS_CHILD)
+			 ButtonReleaseMask | EnterWindowMask;
+    win_attr.override_redirect = (rootWindow == DefaultRootWindow(display));
+    win_attr.colormap          = COLOR_WinColormap;
+    if (!(style & WS_CHILD))
     {
-	parentWindow = parentPtr->window;
-	x_rel = x + parentPtr->rectClient.left - parentPtr->rectWindow.left;
-	y_rel = y + parentPtr->rectClient.top - parentPtr->rectWindow.top;
+	parentPtr = WIN_FindWndPtr( hwndDesktop );
+	  /* Only select focus events on top-level override-redirect windows */
+	if (win_attr.override_redirect) win_attr.event_mask |= FocusChangeMask;
     }
-    else
-    {
-	parentWindow = DefaultRootWindow( display );
-	x_rel = x;
-	y_rel = y;
-    }
-    wndPtr->window = XCreateWindow(display, parentWindow,
-				   x_rel, y_rel, width, height, 0,
-				   CopyFromParent, InputOutput, CopyFromParent,
-				   CWEventMask | CWOverrideRedirect |
-				   CWColormap, &win_attr );
+    wndPtr->window = XCreateWindow( display, parentPtr->window,
+		   x + parentPtr->rectClient.left - parentPtr->rectWindow.left,
+		   y + parentPtr->rectClient.top - parentPtr->rectWindow.top,
+		   width, height, 0,
+		   CopyFromParent, InputOutput, CopyFromParent,
+		   CWEventMask | CWOverrideRedirect | CWColormap, &win_attr );
     XStoreName( display, wndPtr->window, windowName );
 
       /* Send the WM_CREATE message */
-	
+
     hcreateStruct = USER_HEAP_ALLOC( GMEM_MOVEABLE, sizeof(CREATESTRUCT) );
     createStruct = (CREATESTRUCT *) USER_HEAP_ADDR( hcreateStruct );
     createStruct->lpCreateParams = data;
@@ -427,12 +429,13 @@
 
     EVENT_RegisterWindow( wndPtr->window, hwnd );
 
-    WIN_SendParentNotify( hwnd, wndPtr, WM_CREATE );
+    WIN_SendParentNotify( hwnd, WM_CREATE, MAKELONG( hwnd, wndPtr->wIDmenu ) );
     
     if (style & WS_VISIBLE) ShowWindow( hwnd, SW_SHOW );
     return hwnd;
 }
 
+
 /***********************************************************************
  *           DestroyWindow   (USER.53)
  */
@@ -443,9 +446,12 @@
     
       /* Initialisation */
 
+    if (hwnd == hwndDesktop) return FALSE;  /* Can't destroy desktop */
     if (!(wndPtr = WIN_FindWndPtr( hwnd ))) return FALSE;
     if (!(classPtr = CLASS_FindClassPtr( wndPtr->hClass ))) return FALSE;
-    WIN_SendParentNotify( hwnd, wndPtr, WM_DESTROY );
+    if (hwnd == GetActiveWindow()) WINPOS_ChangeActiveWindow( 0, FALSE );
+    if (hwnd == GetFocus()) SetFocus( 0 );
+    WIN_SendParentNotify( hwnd, WM_DESTROY, MAKELONG(hwnd, wndPtr->wIDmenu) );
 
       /* Send destroy messages and destroy children */
 
@@ -501,7 +507,34 @@
  */
 HWND FindWindow(LPSTR ClassMatch, LPSTR TitleMatch)
 {
-    return((HWND)NULL);
+    HCLASS hclass;
+    CLASS *classPtr;
+    HWND hwnd;
+
+    if (ClassMatch)
+    {
+	hclass = CLASS_FindClassByName( ClassMatch, &classPtr );
+	if (!hclass) return 0;
+    }
+    else hclass = 0;
+
+    hwnd = GetTopWindow( hwndDesktop );
+    while(hwnd)
+    {
+	WND *wndPtr = WIN_FindWndPtr( hwnd );
+	if (!hclass || (wndPtr->hClass == hclass))
+	{
+	      /* Found matching class */
+	    if (!TitleMatch) return hwnd;
+	    if (wndPtr->hText)
+	    {
+		char *textPtr = (char *) USER_HEAP_ADDR( wndPtr->hText );
+		if (!strcmp( textPtr, TitleMatch )) return hwnd;
+	    }
+	}
+	hwnd = wndPtr->hwndNext;
+    }
+    return 0;
 }
  
  
@@ -514,6 +547,47 @@
 }
 
 
+/*******************************************************************
+ *           EnableWindow   (USER.34)
+ */
+BOOL EnableWindow( HWND hwnd, BOOL enable )
+{
+    WND *wndPtr;
+
+    if (!(wndPtr = WIN_FindWndPtr( hwnd ))) return FALSE;
+    if (enable && (wndPtr->dwStyle & WS_DISABLED))
+    {
+	  /* Enable window */
+	wndPtr->dwStyle &= ~WS_DISABLED;
+	SendMessage( hwnd, WM_ENABLE, TRUE, 0 );
+	return TRUE;
+    }
+    else if (!enable && !(wndPtr->dwStyle & WS_DISABLED))
+    {
+	  /* Disable window */
+	wndPtr->dwStyle |= WS_DISABLED;
+	if ((hwnd == GetFocus()) || IsChild( hwnd, GetFocus() ))
+	    SetFocus( 0 );  /* A disabled window can't have the focus */
+	if ((hwnd == GetCapture()) || IsChild( hwnd, GetCapture() ))
+	    ReleaseCapture();  /* A disabled window can't capture the mouse */
+	SendMessage( hwnd, WM_ENABLE, FALSE, 0 );
+	return FALSE;
+    }
+    return ((wndPtr->dwStyle & WS_DISABLED) != 0);
+}
+
+
+/***********************************************************************
+ *           IsWindowEnabled   (USER.35)
+ */ 
+BOOL IsWindowEnabled(HWND hWnd)
+{
+    WND * wndPtr; 
+
+    if (!(wndPtr = WIN_FindWndPtr(hWnd))) return FALSE;
+    return !(wndPtr->dwStyle & WS_DISABLED);
+}
+
 
 /**********************************************************************
  *	     GetWindowWord    (USER.133)
@@ -554,86 +628,6 @@
 }
 
 
-
-/*******************************************************************
- *    WIN_SetSensitive
- * 
- *      sets hWnd and all children to the same sensitivity
- * 
- *      sets hWnd sensitive and then calls SetSensitive on hWnd's child
- *      and all of hWnd's child's Next windows 
- */
-static BOOL WIN_SetSensitive(HWND hWnd, BOOL fEnable)
-{
-    WND *wndPtr;
-    HWND hwnd;
-
-    printf("in SetSenitive\n");
-
-    if (!hWnd) return 0;
-    if (!(wndPtr = WIN_FindWndPtr(hWnd))) return 0;
-
-	
-    if (fEnable) {
-        wndPtr->dwStyle &= ~WS_DISABLED;
-     } else {
-        wndPtr->dwStyle |= WS_DISABLED;
-     }
-  
-    hwnd=wndPtr->hwndChild;
-    while (hwnd) {					/* mk next child sens */
-        WIN_SetSensitive(hwnd, fEnable); 
-        if ( !(wndPtr=WIN_FindWndPtr(hwnd)) ) return 0;
-	hwnd=wndPtr->hwndNext;
-    }
-    return 1;
-
-}
-
-/*******************************************************************
- *           EnableWindow   (USER.34)
- * 
- *
- */
-
-BOOL EnableWindow(HWND hWnd, BOOL fEnable)
-{
-    WND *wndPtr;
-    int eprev;
-   
-    if (hWnd == 0) return 0;
-    
-    wndPtr = WIN_FindWndPtr(hWnd);
-    if (wndPtr == 0) return 0;
-
-    eprev = ! (wndPtr->dwStyle & WS_DISABLED);
-
-    if (fEnable != eprev) {                        /* change req */
-        printf("changing window\n");
-        WIN_SetSensitive(hWnd, fEnable); 
-        SendMessage(hWnd, WM_ENABLE, (WORD)fEnable, 0);  
-    }
-    return !eprev;
-}
-
-/***********************************************************************
- *           IsWindowEnabled   (USER.35)
- */
- 
-BOOL IsWindowEnabled(HWND hWnd)
-{
-    WND * wndPtr; 
-
-    if (hWnd == 0) return 0;
-    wndPtr = WIN_FindWndPtr(hWnd);
-    if (wndPtr == 0) return 0;
-
-    return !(wndPtr->dwStyle & WS_DISABLED);
-}
-
-
-
-
 /**********************************************************************
  *	     GetWindowLong    (USER.135)
  */