Release 970120

Sun Jan 19 11:46:48 1997  Alexandre Julliard  <julliard@lrc.epfl.ch>

	* [loader/module.c]
	Fixed LoadModule() to always call the DLL initialization code.

	* [windows/event.c]
	Moved all the keyboard stuff to windows/keyboard.c

	* [tools/build.c]
	Fixed Win32 register functions.

Sat Jan 18 22:24:41 1997  David Makepeace  <D.Makepeace@mailbox.uq.oz.au>

        * [tools/makedep.c]
        Fixed bug which causes SEGV on Solaris x86.

Fri Jan 17 18:32:27 1997  Frans van Dorsselaer <dorssel@rulhmpc49.LeidenUniv.nl>

	* [controls/edit.c]
	Implemented WM_UNDO, WM_CONTEXTMENU (temporary using WM_RBUTTONUP),
	WM_COMMAND, WM_INITPOPUPMENU, WM_SYSKEYDOWN.
	Fixed EM_SETSEL and some minor bugs (features).
	Hence: fully functional undo and a win95 menu with the right mouse
		button.

	* [include/resources.h] [resources/TODO] [resources/sysres_??.rc]
	Added a context menu for the edit control.
	Translations, please ...

Fri Jan	17 08:29:52 1997  David Faure <david.faure@ifhamy.insa-lyon.fr>

	* [windows/event.c]
	Move EVENT_ToAscii to windows/keyboard.c (where name ToAscii)
	Fixed Keypad keys 0-9 and . in EVENT_event_to_vkey.
	Added 3-state handling of toggle keys (CapsLock, NumLock) in order
	to make them work with any X server.
	Toggle keys now generate WM_KEYDOWN and WM_KEYUP on each pressing.

	* [include/keyboard.h]
	Totally replaced the file (formerly containing the vkcase definitions)
	by the declaration of 'extern' variables contained by event.c and used
	by keyboard.c
	
	* [windows/keyboard.c]
	Started to rewrite VkKeyScan and MapVirtualKey, to make them use the 
	table keyc2vkey or X functions only.
	ToAscii : added keypad 0-9 and . special case.
	Changed toggle keys active mask from 0x80 to 0x1.

	* [misc/keyboard.c]
	File deleted. Contents moved to windows/keyboard.c.

	* [misc/main.c]
	Added putenv XKB_DISABLE to disable XKB extension (which, when
	present, causes AltGr to change keyboard group instead of being a
	modifier).

Tue Jan 14 22:56:43 1997  Philippe De Muyter  <phdm@info.ucl.ac.be>

	* [windows/event.c]
	Do not assume NumLockMask is Mod2Mask, but compute it by scanning
	output of XGetModifierMapping for XK_Num_Lock.

Tue Jan 14 15:49:49 1997  Marcus Meissner <msmeissn@cip.informatik.uni-erlangen.de>

	* [loader/pe_*.c] [include/peexe.h] [include/resource32.h]
	  [debugger/*.c]
	General clean up.
	Changed defines/structures to match Windows NT SDK.

	* [loader/main.c]
	Don't crash on empty command-line.

	* [windows/winpos.c]
	winpos.c made win32 clean.

	* [misc/ntdll.c]
	Some string conversion additions.

	* [files/file.c]
	GetFileAttributes/GetTempFileName fixed.

	* [misc/ver.c]
	VerInstallFile implemented.

Mon Jan 13 15:03:11 1997  Philippe De Muyter  <phdm@info.ucl.ac.be>

	* [tools/build.c]: Use PREFIX also in stabs messages.

Mon Jan 13 10:40:33 1997  John Harvey <john@division.co.uk>

	* [graphics/win16drv/*] [include/win16drv.h]
	Many fixes and some new features.

	* [graphics/x11drv/font.c] [graphics/x11drv/init.c]
	  [include/x11drv.h] [objects/font.c]
	GetTextMetrics() moved to graphics driver.

	* [if1632/gdi.spec] [misc/fontengine.c] [misc/Makefile.in]
	New dummy EngineEnumerateFont, EngineRealizeFont functions.

	* [include/windows.h]
	TEXTFORM16 and FONTINFO16 structure definitions moved here from
	include/win16drv.h
diff --git a/windows/msgbox.c b/windows/msgbox.c
index 40d9344..f5a5d26 100644
--- a/windows/msgbox.c
+++ b/windows/msgbox.c
@@ -42,33 +42,33 @@
    case WM_INITDIALOG:
     lpmb = (LPMSGBOX)lParam;
     if (lpmb->title) SetWindowText32A(hwnd, lpmb->title);
-    SetWindowText32A(GetDlgItem(hwnd, 100), lpmb->text);
+    SetWindowText32A(GetDlgItem32(hwnd, 100), lpmb->text);
     /* Hide not selected buttons */
     switch(lpmb->type & MB_TYPEMASK) {
      case MB_OK:
-      ShowWindow(GetDlgItem(hwnd, 2), SW_HIDE);
+      ShowWindow32(GetDlgItem32(hwnd, 2), SW_HIDE);
       /* fall through */
      case MB_OKCANCEL:
-      ShowWindow(GetDlgItem(hwnd, 3), SW_HIDE);
-      ShowWindow(GetDlgItem(hwnd, 4), SW_HIDE);
-      ShowWindow(GetDlgItem(hwnd, 5), SW_HIDE);
-      ShowWindow(GetDlgItem(hwnd, 6), SW_HIDE);
-      ShowWindow(GetDlgItem(hwnd, 7), SW_HIDE);
+      ShowWindow32(GetDlgItem32(hwnd, 3), SW_HIDE);
+      ShowWindow32(GetDlgItem32(hwnd, 4), SW_HIDE);
+      ShowWindow32(GetDlgItem32(hwnd, 5), SW_HIDE);
+      ShowWindow32(GetDlgItem32(hwnd, 6), SW_HIDE);
+      ShowWindow32(GetDlgItem32(hwnd, 7), SW_HIDE);
       break;
      case MB_ABORTRETRYIGNORE:
-      ShowWindow(GetDlgItem(hwnd, 1), SW_HIDE);
-      ShowWindow(GetDlgItem(hwnd, 2), SW_HIDE);
-      ShowWindow(GetDlgItem(hwnd, 6), SW_HIDE);
-      ShowWindow(GetDlgItem(hwnd, 7), SW_HIDE);
+      ShowWindow32(GetDlgItem32(hwnd, 1), SW_HIDE);
+      ShowWindow32(GetDlgItem32(hwnd, 2), SW_HIDE);
+      ShowWindow32(GetDlgItem32(hwnd, 6), SW_HIDE);
+      ShowWindow32(GetDlgItem32(hwnd, 7), SW_HIDE);
       break;
      case MB_YESNO:
-      ShowWindow(GetDlgItem(hwnd, 2), SW_HIDE);
+      ShowWindow32(GetDlgItem32(hwnd, 2), SW_HIDE);
       /* fall through */
      case MB_YESNOCANCEL:
-      ShowWindow(GetDlgItem(hwnd, 1), SW_HIDE);
-      ShowWindow(GetDlgItem(hwnd, 3), SW_HIDE);
-      ShowWindow(GetDlgItem(hwnd, 4), SW_HIDE);
-      ShowWindow(GetDlgItem(hwnd, 5), SW_HIDE);
+      ShowWindow32(GetDlgItem32(hwnd, 1), SW_HIDE);
+      ShowWindow32(GetDlgItem32(hwnd, 3), SW_HIDE);
+      ShowWindow32(GetDlgItem32(hwnd, 4), SW_HIDE);
+      ShowWindow32(GetDlgItem32(hwnd, 5), SW_HIDE);
       break;
     }
     /* Set the icon */
@@ -100,23 +100,23 @@
     borheight -= rect.bottom - rect.top;
 
     /* Get the icon height */
-    GetWindowRect32(GetDlgItem(hwnd, 1088), &rect);
+    GetWindowRect32(GetDlgItem32(hwnd, 1088), &rect);
     iheight = rect.bottom - rect.top;
     
     /* Get the number of visible buttons and their width */
-    GetWindowRect32(GetDlgItem(hwnd, 2), &rect);
+    GetWindowRect32(GetDlgItem32(hwnd, 2), &rect);
     bheight = rect.bottom - rect.top;
     bwidth = rect.left;
-    GetWindowRect32(GetDlgItem(hwnd, 1), &rect);
+    GetWindowRect32(GetDlgItem32(hwnd, 1), &rect);
     bwidth -= rect.left;
     for (buttons = 0, i = 1; i < 8; i++)
     {
-      hItem = GetDlgItem(hwnd, i);
+      hItem = GetDlgItem32(hwnd, i);
       if (GetWindowLong32A(hItem, GWL_STYLE) & WS_VISIBLE) buttons++;
     }
     
     /* Get the text size */
-    hItem = GetDlgItem(hwnd, 100);
+    hItem = GetDlgItem32(hwnd, 100);
     GetWindowRect32(hItem, &textrect);
     MapWindowPoints32(0, hwnd, (LPPOINT32)&textrect, 2);
     
@@ -129,34 +129,34 @@
     ReleaseDC32(hItem, hdc);
     
     /* Position the text */
-    SetWindowPos(hItem, 0, textrect.left, (tiheight - theight) / 2, 
-		 rect.right - rect.left, theight,
-		 SWP_NOZORDER | SWP_NOACTIVATE | SWP_NOREDRAW);
+    SetWindowPos32(hItem, 0, textrect.left, (tiheight - theight) / 2, 
+		   rect.right - rect.left, theight,
+		   SWP_NOZORDER | SWP_NOACTIVATE | SWP_NOREDRAW);
     
     /* Position the icon */
-    hItem = GetDlgItem(hwnd, 1088);
+    hItem = GetDlgItem32(hwnd, 1088);
     GetWindowRect32(hItem, &rect);
     MapWindowPoints32(0, hwnd, (LPPOINT32)&rect, 2);
-    SetWindowPos(hItem, 0, rect.left, (tiheight - iheight) / 2, 0, 0,
-		 SWP_NOSIZE | SWP_NOZORDER | SWP_NOACTIVATE | SWP_NOREDRAW);
+    SetWindowPos32(hItem, 0, rect.left, (tiheight - iheight) / 2, 0, 0,
+		   SWP_NOSIZE | SWP_NOZORDER | SWP_NOACTIVATE | SWP_NOREDRAW);
     
     /* Resize the window */
-    SetWindowPos(hwnd, 0, 0, 0, wwidth, 8 + tiheight + bheight + borheight,
-		 SWP_NOMOVE | SWP_NOZORDER | SWP_NOACTIVATE | SWP_NOREDRAW);
+    SetWindowPos32(hwnd, 0, 0, 0, wwidth, 8 + tiheight + bheight + borheight,
+		   SWP_NOMOVE | SWP_NOZORDER | SWP_NOACTIVATE | SWP_NOREDRAW);
     
     /* Position the buttons */
     bpos = (wwidth - bwidth * buttons) / 2;
-    GetWindowRect32(GetDlgItem(hwnd, 1), &rect);
+    GetWindowRect32(GetDlgItem32(hwnd, 1), &rect);
     for (buttons = i = 0; i < 7; i++) {
       /* some arithmetic to get the right order for YesNoCancel windows */
-      hItem = GetDlgItem(hwnd, (i + 5) % 7 + 1);
+      hItem = GetDlgItem32(hwnd, (i + 5) % 7 + 1);
       if (GetWindowLong32A(hItem, GWL_STYLE) & WS_VISIBLE) {
 	if (buttons++ == ((lpmb->type & MB_DEFMASK) >> 8)) {
 	  SetFocus32(hItem);
 	  SendMessage32A( hItem, BM_SETSTYLE32, BS_DEFPUSHBUTTON, TRUE );
 	}
-	SetWindowPos(hItem, 0, bpos, tiheight, 0, 0,
-		     SWP_NOSIZE | SWP_NOZORDER | SWP_NOACTIVATE | SWP_NOREDRAW);
+	SetWindowPos32(hItem, 0, bpos, tiheight, 0, 0,
+		       SWP_NOSIZE|SWP_NOZORDER|SWP_NOACTIVATE|SWP_NOREDRAW);
 	bpos += bwidth;
       }
     }