Release 980301

Sun Mar  1 10:45:23 1998  Andreas Mohr <100.30936@germany.net>

	* [loader/ne_image.c]
	Fixed problem with weird DLLs (NE_FFLAGS_SINGLEDATA && DGROUP = 0).

	* [msdos/dosmem.c]
	Export address for __0000H, too.

	* [msdos/dpmi.c]
	Changed MemAlloc functions to return less fragmented addresses.

Sat Feb 28 18:50:12 1998  Alexandre Julliard  <julliard@lrc.epfl.ch>

	* [scheduler/process.c] [scheduler/sysdeps.c]
	Don't use %fs register before threading initialization.

Sat Feb 28 14:04:56 1998  Kristian Nielsen  <kristian.nielsen@risoe.dk>

	* [configure.in] [include/acconfig.h]
	Autoconf macro to check for non-reentrant X libraries.

	* [windows/winpos.c]
	In SetWindowPos32(), do not cause WM_SIZE messages when the
	SWP_NOSIZE flag is specified. This fixes the division-by-zero in
	Borland C++ 4.0 "Open Project" menu item.

Sat Feb 28 13:11:26 1998  James Moody  <013263m@dragon.acadiau.ca>

	* [ole/ole2nls.c]
	Changed "English" values from German to English.

	* [files/dos_fs.c]
	Fixed off-by-one month bug.

Fri Feb 27 22:12:01 1998  Douglas Ridgway  <ridgway@winehq.com>

	* [windows/win.c]
	Fix winelib class menu loading bug.

	* [include/module.h] [loader/module.c]
	LoadModule32 should be implemented in terms of CreateProcess.

	* [programs/view/*]
	Metafile viewer sample program.

	* [documentation/wine.texinfo] [documentation/Makefile.in]
	Improvements and additions, HTML target.

Fri Feb 27 04:27:48 1998  Dimitrie O. Paun <dimi@cs.toronto.edu>

	* [*/*]
	Switched to the new debug messages interface. For more information
	please refer to documentation/debug-msgs. Because the new scheme
	introduces a new semantic level, I had to manually do through
	about 530 dprintf_xxx!  The rest of about 2400 where transformed
	via a script.  Because of the large number of changes that I had
	to do, some may have not come out as nicely as I wanted them.  If
	this is the case, please let me know. There is a lot of work left
	to do: -- a few hundred printf's to be converted -- about 2300
	fprintf's to be converted -- about 600 FIXME's to be transformed
	The problem is that in the above mentioned cases, a lot of manual
	intervention is required because a lot of the information is
	missing.  There are also a lot of other things to be done to the
	interface and so forth. I have now ideas for a at least a month
	worth of full time work :) I will proceed with many changes in the
	next few releases, so please do not start modifing things because
	there will be a hell of a lot of conflicts. If you have ideas that
	you want to integrate or you want to work on different things,
	please coordinate with me.

Thu Feb 26 13:04:29 1998  David Lee Lambert <lamber45@egr.msu.edu>

	* [ole/ole2nls.c] [include/windows.h]
	First try at OLE date- and time-formatting functions.

Wed Feb 25 11:20:35 1998 Marcus Meissner <msmeissn@cip.informatik.uni-erlangen.de>

	* [files/*.c]
	Changed dos device handling, added 'CON' devicehandling.

	* [graphics/ddraw.c]
	Bug fixes, some additions.

	* [if1632/builtin.c][loader/module.c][library/winestub.c]
	Small hack so we don't need a dummy BUILTIN_LoadModule
	in winestub.c.

	* [ole/*][relay32/ole32.spec][if1632/storage.spec]
	storage.dll started. winword loads documents (saving
	doesn't work yet, dunno why).
	Several ole additions, some cleanups and bugfixes.
	IMalloc16 implemented.

	* [loader/pe_image.c]
	Added some comments, fixed circular dll references,
	fixed modref ordering, fixed tls allocation.

	* [memory/global.c]
	Added validity checks before every GET_ARENA_PTR.
	(several functions rely on Global* return values
	 on invalid handles, like IsTask).
	Implemented GlobalUnlockFree16.

	* [memory/virtual.c]
	Replaced dprintf_virtual by fprintf, so we can
	do 'info map' again in the debugger. Increase read
	linesize for Linux2.1 cases.

	* [misc/cpu.c][misc/registry.c]
	Moved cpu registry initialization to misc/cpu.c.

	* [multimedia/dsound.c]
	Enhanced, replaced GETOSPACE bufferingcheck by SETFRAGMENT.

	* [relay32/crtdll.spec][relay32/ntdll.spec]
	Replaced some ptr by respective 'str' and 'wstr' arguments
	for libc functions.

	* [scheduler/thread.c]
	Added some sanity checks to stackallocation, tlshandling fixed.

	* [tools/build.c]
	Fixed cdecl argumenttype order (was reversed).

	* [win32/ordinals.c]
	Implemented KERNEL_449.

	* [windows/dinput.c]
	Some fixes, needs much more work. Tomb Raider2 works with keyboard ;)

Tue Feb 24 20:46:37 1998  James Juran   <jrj120@psu.edu>

	* [windows/win.c]
	Fixed USER32 ordinal numbers in documentation.

Sat Feb 21 12:30:38 1998  John Richardson <jrichard@zko.dec.com>

	* [files/file.c] [include/k32obj.h] [memory/virtual.c]
	[scheduler/critsection.c] [scheduler/event.c] [scheduler/handle.c]
	[scheduler/k32obj.c] [scheduler/mutex.c] [scheduler/process.c]
	[scheduler/semaphore.c] [scheduler/thread.c]
	Added generic k32obj read and write routines for k32objs that
	support I/O.

	* [documentation/console]
	Updated console docs.

	* [win32/console.c]
	Make console work like a k32obj that supports I/O.

	* [include/windows.h]
	Make WriteFile and ReadFile take HANDLE32 for handle.

Sun Feb 15 14:07:07 1998  Dimitrie O. Paun  <dimi@mail.cs.toronto.edu>

	* [controls/menu.c] [misc/ver.c] [multimedia/dsound.c]
	  [multimedia/joystick.c] [windows/dialog.c]
	Modified some dprintf_xxx's to prepare them for a new
	dprintf_ scheme. Basically, I changed the dprintf's that
	outputed a line with many dprintf calls to do just one
	dprintf call.
diff --git a/windows/message.c b/windows/message.c
index 5ac2407..6b627a0 100644
--- a/windows/message.c
+++ b/windows/message.c
@@ -24,8 +24,6 @@
 #include "queue.h"
 #include "winproc.h"
 #include "options.h"
-#include "stddebug.h"
-/* #define DEBUG_MSG */
 #include "debug.h"
 
 #define WM_NCMOUSEFIRST         WM_NCMOUSEMOVE
@@ -357,7 +355,7 @@
   tmpMsg = SEGPTR_NEW(EVENTMSG16);
   wtime=HOOK_CallHooks16( WH_JOURNALPLAYBACK, HC_GETNEXT, 0,
 			  (LPARAM)SEGPTR_GET(tmpMsg));
-  /*  dprintf_msg(stddeb,"Playback wait time =%ld\n",wtime); */
+  /*  dprintf_info(msg,"Playback wait time =%ld\n",wtime); */
   if (wtime<=0)
   {
    wtime=0;
@@ -598,12 +596,12 @@
     if (IsTaskLocked() || !IsWindow32(hwnd)) return 0;
 
     debugSMRL+=4;
-    dprintf_sendmsg(stddeb,"%*sSM: %s [%04x] (%04x -> %04x)\n", 
+    dprintf_info(sendmsg,"%*sSM: %s [%04x] (%04x -> %04x)\n", 
 		    prevSMRL, "", SPY_GetMsgName(msg), msg, queue->self, hDestQueue );
 
     if( !(queue->wakeBits & QS_SMPARAMSFREE) )
     {
-      dprintf_sendmsg(stddeb,"\tIntertask SendMessage: sleeping since unreplied SendMessage pending\n");
+      dprintf_info(sendmsg,"\tIntertask SendMessage: sleeping since unreplied SendMessage pending\n");
       queue->changeBits &= ~QS_SMPARAMSFREE;
       QUEUE_WaitBits( QS_SMPARAMSFREE );
     }
@@ -621,7 +619,7 @@
     queue->wakeBits &= ~QS_SMPARAMSFREE;
     queue->flags = (queue->flags & ~(QUEUE_SM_WIN32|QUEUE_SM_UNICODE)) | flags;
 
-    dprintf_sendmsg(stddeb,"%*ssm: smResultInit = %08x\n", prevSMRL, "", (unsigned)&qCtrl);
+    dprintf_info(sendmsg,"%*ssm: smResultInit = %08x\n", prevSMRL, "", (unsigned)&qCtrl);
 
     queue->smResultInit = &qCtrl;
 
@@ -636,11 +634,11 @@
         queue->changeBits &= ~QS_SMRESULT;
         DirectedYield( destQ->hTask );
         QUEUE_WaitBits( QS_SMRESULT );
-	dprintf_sendmsg(stddeb,"\tsm: have result!\n");
+	dprintf_info(sendmsg,"\tsm: have result!\n");
       }
       /* got something */
 
-      dprintf_sendmsg(stddeb,"%*ssm: smResult = %08x\n", prevSMRL, "", (unsigned)queue->smResult );
+      dprintf_info(sendmsg,"%*ssm: smResult = %08x\n", prevSMRL, "", (unsigned)queue->smResult );
 
       if (queue->smResult) { /* FIXME, smResult should always be set */
         queue->smResult->lResult = queue->SendMessageReturn;
@@ -649,11 +647,11 @@
       queue->wakeBits &= ~QS_SMRESULT;
 
       if( queue->smResult != &qCtrl )
-	  dprintf_sendmsg(stddeb,"%*ssm: weird scenes inside the goldmine!\n", prevSMRL, "");
+	  dprintf_err(sendmsg, "%*ssm: weird scenes inside the goldmine!\n", prevSMRL, "");
     }
     queue->smResultInit = NULL;
     
-    dprintf_sendmsg(stddeb,"%*sSM: [%04x] returning %08lx\n", prevSMRL, "", msg, qCtrl.lResult);
+    dprintf_info(sendmsg,"%*sSM: [%04x] returning %08lx\n", prevSMRL, "", msg, qCtrl.lResult);
     debugSMRL-=4;
 
     return qCtrl.lResult;
@@ -670,11 +668,11 @@
 
     if (!(queue = (MESSAGEQUEUE*)GlobalLock16( GetTaskQueue(0) ))) return;
 
-    dprintf_msg(stddeb,"ReplyMessage, queue %04x\n", queue->self);
+    dprintf_info(msg,"ReplyMessage, queue %04x\n", queue->self);
 
     while( (senderQ = (MESSAGEQUEUE*)GlobalLock16( queue->InSendMessageHandle)))
     {
-      dprintf_msg(stddeb,"\trpm: replying to %04x (%04x -> %04x)\n",
+      dprintf_info(msg,"\trpm: replying to %04x (%04x -> %04x)\n",
                           queue->msg, queue->self, senderQ->self);
 
       if( queue->wakeBits & QS_SENDMESSAGE )
@@ -686,10 +684,10 @@
       if(!(senderQ->wakeBits & QS_SMRESULT) ) break;
       OldYield();
     } 
-    if( !senderQ ) { dprintf_msg(stddeb,"\trpm: done\n"); return; }
+    if( !senderQ ) { dprintf_info(msg,"\trpm: done\n"); return; }
 
     senderQ->SendMessageReturn = result;
-    dprintf_msg(stddeb,"\trpm: smResult = %08x, result = %08lx\n", 
+    dprintf_info(msg,"\trpm: smResult = %08x, result = %08lx\n", 
 			(unsigned)queue->smResultCurrent, result );
 
     senderQ->smResult = queue->smResultCurrent;
@@ -939,7 +937,7 @@
     MSG_PeekMessage( lpmsg,
                      hwnd, first, last, PM_REMOVE, FALSE );
 
-    dprintf_msg(stddeb,"message %04x, hwnd %04x, filter(%04x - %04x)\n", lpmsg->message,
+    dprintf_info(msg,"message %04x, hwnd %04x, filter(%04x - %04x)\n", lpmsg->message,
 		     				                 hwnd, first, last );
     HOOK_CallHooks16( WH_GETMESSAGE, HC_ACTION, 0, (LPARAM)msg );
     return (lpmsg->message != WM_QUIT);
@@ -970,17 +968,17 @@
     
     if (hwnd == HWND_BROADCAST)
     {
-        dprintf_msg(stddeb,"PostMessage // HWND_BROADCAST !\n");
+        dprintf_info(msg,"PostMessage // HWND_BROADCAST !\n");
         for (wndPtr = WIN_GetDesktop()->child; wndPtr; wndPtr = wndPtr->next)
         {
             if (wndPtr->dwStyle & WS_POPUP || wndPtr->dwStyle & WS_CAPTION)
             {
-                dprintf_msg(stddeb,"BROADCAST Message to hWnd=%04x m=%04X w=%04X l=%08lX !\n",
+                dprintf_info(msg,"BROADCAST Message to hWnd=%04x m=%04X w=%04X l=%08lX !\n",
                             wndPtr->hwndSelf, message, wParam, lParam);
                 PostMessage16( wndPtr->hwndSelf, message, wParam, lParam );
             }
         }
-        dprintf_msg(stddeb,"PostMessage // End of HWND_BROADCAST !\n");
+        dprintf_info(msg,"PostMessage // End of HWND_BROADCAST !\n");
         return TRUE;
     }
 
@@ -1053,20 +1051,20 @@
     {
         if (!(list = WIN_BuildWinArray( WIN_GetDesktop(), 0, NULL )))
             return TRUE;
-        dprintf_msg(stddeb,"SendMessage // HWND_BROADCAST !\n");
+        dprintf_info(msg,"SendMessage // HWND_BROADCAST !\n");
         for (ppWnd = list; *ppWnd; ppWnd++)
         {
             wndPtr = *ppWnd;
             if (!IsWindow32(wndPtr->hwndSelf)) continue;
             if (wndPtr->dwStyle & WS_POPUP || wndPtr->dwStyle & WS_CAPTION)
             {
-                dprintf_msg(stddeb,"BROADCAST Message to hWnd=%04x m=%04X w=%04lX l=%08lX !\n",
+                dprintf_info(msg,"BROADCAST Message to hWnd=%04x m=%04X w=%04lX l=%08lX !\n",
                             wndPtr->hwndSelf, msg, (DWORD)wParam, lParam);
                 SendMessage16( wndPtr->hwndSelf, msg, wParam, lParam );
             }
         }
         HeapFree( SystemHeap, 0, list );
-        dprintf_msg(stddeb,"SendMessage // End of HWND_BROADCAST !\n");
+        dprintf_info(msg,"SendMessage // End of HWND_BROADCAST !\n");
         return TRUE;
     }
 
@@ -1424,15 +1422,16 @@
     static int dead_char;
     BYTE wp[2];
     
-    if ((debugging_msg && message != WM_MOUSEMOVE && message != WM_TIMER)
-        || (debugging_key
-            && message >= WM_KEYFIRST && message <= WM_KEYLAST))
-        fprintf(stddeb, "TranslateMessage(%s, %04X, %08lX)\n",
-		SPY_GetMsgName(message), wParam, lParam );
+    if (message != WM_MOUSEMOVE && message != WM_TIMER)
+        dprintf_info(msg, "TranslateMessage(%s, %04X, %08lX)\n",
+		     SPY_GetMsgName(message), wParam, lParam );
+    if(message >= WM_KEYFIRST && message <= WM_KEYLAST)
+        dprintf_info(key, "TranslateMessage(%s, %04X, %08lX)\n",
+		     SPY_GetMsgName(message), wParam, lParam );
 
     if ((message != WM_KEYDOWN) && (message != WM_SYSKEYDOWN)) return FALSE;
 
-    dprintf_key( stddeb, "Translating key %04X, scancode %04X\n",
+    dprintf_info(key, "Translating key %04X, scancode %04X\n",
                  wParam, HIWORD(lParam) );
 
     /* FIXME : should handle ToAscii yielding 2 */
@@ -1463,14 +1462,14 @@
                 }
             dead_char = 0;
         }
-        dprintf_key(stddeb, "1 -> PostMessage(%s)\n", SPY_GetMsgName(message));
+        dprintf_info(key, "1 -> PostMessage(%s)\n", SPY_GetMsgName(message));
         PostMessage16( hwnd, message, wp[0], lParam );
         return TRUE;
 
     case -1 :
         message = (message == WM_KEYDOWN) ? WM_DEADCHAR : WM_SYSDEADCHAR;
         dead_char = wp[0];
-        dprintf_key( stddeb, "-1 -> PostMessage(%s)\n",
+        dprintf_info(key, "-1 -> PostMessage(%s)\n",
                      SPY_GetMsgName(message));
         PostMessage16( hwnd, message, wp[0], lParam );
         return TRUE;
@@ -1643,7 +1642,7 @@
  */
 WORD WINAPI RegisterWindowMessage16( SEGPTR str )
 {
-    dprintf_msg(stddeb, "RegisterWindowMessage16: %08lx\n", (DWORD)str );
+    dprintf_info(msg, "RegisterWindowMessage16: %08lx\n", (DWORD)str );
     return GlobalAddAtom16( str );
 }
 
@@ -1653,7 +1652,7 @@
  */
 WORD WINAPI RegisterWindowMessage32A( LPCSTR str )
 {
-    dprintf_msg(stddeb, "RegisterWindowMessage32A: %s\n", str );
+    dprintf_info(msg, "RegisterWindowMessage32A: %s\n", str );
     return GlobalAddAtom32A( str );
 }
 
@@ -1663,7 +1662,7 @@
  */
 WORD WINAPI RegisterWindowMessage32W( LPCWSTR str )
 {
-    dprintf_msg(stddeb, "RegisterWindowMessage32W: %p\n", str );
+    dprintf_info(msg, "RegisterWindowMessage32W: %p\n", str );
     return GlobalAddAtom32W( str );
 }