Release 980215

Sun Feb 15 12:02:59 1998  Alexandre Julliard  <julliard@lrc.epfl.ch>

	* [graphics/x11drv/*.c] [objects/*.c]
	A few X11 critical section optimizations, mostly with XGet/PutPixel.

	* [scheduler/sysdeps.c] [misc/main.c]
	Make sure X11 critical section is available before any Xlib call.

	* [if1632/relay.c] [tools/build.c]
	Yet another attempt at fixing Catch/Throw.

	* [loader/pe_image.c]
	Fixed broken PE DLL loading.

	* [include/winnt.h] [scheduler/handle.c] [scheduler/*.c]
	Implemented handle access rights.
	Added Get/SetHandleInformation.

Sun Feb 15 09:45:23 1997  Andreas Mohr <100.30936@germany.net>

	* [misc/winsock.c]
	Fixed bug in WSACleanup which lead to crashes in WINSOCK_HandleIO.

	* [graphics/fontengine.c] [include/font.h]
	Minor improvements.

	* [memory/global.c]
	Implemented GlobalEntryHandle.

	* [misc/toolhelp.c]
	Fixed a memory bug in Notify*register.

	* [misc/w32scomb.c]
	Improved Get16DLLAddress.

	* [objects/gdiobj.c]
	Implemented GdiSeeGdiDo.


Sat Feb 14 14:57:39 1998  John Richardson <jrichard@zko.dec.com>

	* [win32/console.c]
	Added the console implementation, AllocConsole, FreeConsole,
	CONSOLE_InheritConsole.

	* [documentation/console]
	Some documentation on the console.

	* [include/winerror.h]
	Added some error defines.

	* [scheduler/k32obj.c]
	Registered the scheduler ops.

Fri Feb 13 19:35:35 1998  James Moody  <013263m@dragon.acadiau.ca>

	* [ole/ole2nls.c]
	Some English language fixes for missing values.

	* [controls/listbox.c]
	Fix to allow an empty listbox to deselect all items.

	* [relay32/user32.spec] [windows/keyboard.c]
	CreateAcceleratorTableA stub method.

	* [windows/sysmetrics.c]
	Added missing SM_CXCURSOR & SM_CYCURSOR initializers.

	* [windows/message.c]
	PostThreadMessage32A stub method.

Fri Feb 13 17:12:24 1998  Jim Peterson <jspeter@roanoke.infi.net>

	* [libtest/hello3res.rc] [libtest/hello3.c] [libtest/Makefile.in]
	Updated the 'hello3' test so that it functions properly again.

Fri Feb 13 14:08:07 1998  Martin Boehme  <boehme@informatik.mu-luebeck.de>
	
	* [graphics/mapping.c]
	Fixed the embarrassing bugs I introduced into DPtoLP and
	LPtoDP.

	* [windows/scroll.c]
	Prevent ScrollWindow32 from sending WM_ERASEBKGND.

Thu Feb 12 22:46:53 1998  Huw D M Davies <h.davies1@physics.oxford.ac.uk>

	* [objects/metafile] [include/ldt.h]
	Fix to cope with records longer than 64K.

	* [windows/clipboard.c]
	Clean up bitmaps and metapicts properly.

Mon Feb  3 21:52:18 1998  Karl Backström <karl_b@geocities.com>

	* [programs/winhelp/Sw.rc] [resources/sysres_Sw.rc]
	Minor update of Swedish language support.
diff --git a/windows/dialog.c b/windows/dialog.c
index f469c61..59ddae6 100644
--- a/windows/dialog.c
+++ b/windows/dialog.c
@@ -99,6 +99,7 @@
 static LPCSTR DIALOG_GetControl16( LPCSTR p, DLG_CONTROL_INFO *info )
 {
     static char buffer[10];
+    int int_id;
 
     info->x       = GET_WORD(p);  p += sizeof(WORD);
     info->y       = GET_WORD(p);  p += sizeof(WORD);
@@ -128,28 +129,34 @@
 	info->className = p;
 	p += strlen(p) + 1;
     }
-    dprintf_dialog(stddeb, "   %s ", info->className );
 
-    if ((BYTE)*p == 0xff)
+    int_id = ((BYTE)*p == 0xff);
+    if (int_id)
     {
 	  /* Integer id, not documented (?). Only works for SS_ICON controls */
 	info->windowName = (LPCSTR)(UINT32)GET_WORD(p+1);
 	p += 3;
-        dprintf_dialog( stddeb,"%04x", LOWORD(info->windowName) );
     }
     else
     {
 	info->windowName = p;
 	p += strlen(p) + 1;
-        dprintf_dialog(stddeb,"'%s'", info->windowName );
     }
 
     info->data = (LPVOID)(*p ? p + 1 : NULL);  /* FIXME: should be a segptr */
     p += *p + 1;
 
-    dprintf_dialog( stddeb," %d, %d, %d, %d, %d, %08lx, %08lx\n", 
-                    info->id, info->x, info->y, info->cx, info->cy,
-                    info->style, (DWORD)info->data);
+    if(int_id)
+      dprintf_dialog( stddeb,"   %s %04x %d, %d, %d, %d, %d, %08lx, %08lx\n", 
+		      info->className,  LOWORD(info->windowName),
+		      info->id, info->x, info->y, info->cx, info->cy,
+		      info->style, (DWORD)info->data);
+    else
+      dprintf_dialog( stddeb,"   %s '%s' %d, %d, %d, %d, %d, %08lx, %08lx\n", 
+		      info->className,  info->windowName,
+		      info->id, info->x, info->y, info->cx, info->cy,
+		      info->style, (DWORD)info->data);
+
     return p;
 }
 
@@ -163,6 +170,7 @@
 static const WORD *DIALOG_GetControl32( const WORD *p, DLG_CONTROL_INFO *info )
 {
     static WCHAR buffer[10];
+    int int_id;
 
     info->style   = GET_DWORD(p); p += 2;
     info->exStyle = GET_DWORD(p); p += 2;
@@ -192,19 +200,17 @@
         info->className = (LPCSTR)p;
         p += lstrlen32W( (LPCWSTR)p ) + 1;
     }
-    dprintf_dialog(stddeb, "   %p ", info->className );
 
-    if (GET_WORD(p) == 0xffff)
+    int_id = (GET_WORD(p) == 0xffff);
+    if (int_id)
     {
 	info->windowName = (LPCSTR)(p + 1);
 	p += 2;
-        dprintf_dialog( stddeb,"%04x", LOWORD(info->windowName) );
     }
     else
     {
 	info->windowName = (LPCSTR)p;
         p += lstrlen32W( (LPCWSTR)p ) + 1;
-        dprintf_dialog(stddeb,"'%p'", info->windowName );
     }
 
     if (GET_WORD(p))
@@ -215,9 +221,17 @@
     else info->data = NULL;
     p++;
 
-    dprintf_dialog( stddeb," %d, %d, %d, %d, %d, %08lx, %08lx, %08lx\n", 
-                    info->id, info->x, info->y, info->cx, info->cy,
-                    info->style, info->exStyle, (DWORD)info->data);
+    if(int_id)
+      dprintf_dialog( stddeb,"   %p %04x %d, %d, %d, %d, %d, %08lx, %08lx, %08lx\n", 
+		      info->className, LOWORD(info->windowName),
+		      info->id, info->x, info->y, info->cx, info->cy,
+		      info->style, info->exStyle, (DWORD)info->data);
+    else
+      dprintf_dialog( stddeb,"   %p '%p' %d, %d, %d, %d, %d, %08lx, %08lx, %08lx\n", 
+		      info->className, info->windowName,
+		      info->id, info->x, info->y, info->cx, info->cy,
+		      info->style, info->exStyle, (DWORD)info->data);
+
     /* Next control is on dword boundary */
     return (const WORD *)((((int)p) + 3) & ~3);
 }