Release 980517

Sun May 17 16:23:56 1998  Uwe Bonnes <bon@elektron.ikp.physik.tu-darmstadt.de>

	* [file/profile.c]
	Fix the return value of PROFILE_GetSection

	* [misc/crtdll.c]
	Do _getdrive, fix _chdrive.

	* [misc/commdlg.c]
	First cut at ChooseColor[WA].

	* [misc/network.c]
	Do something sensible for WNetGetDirectoryType16.

Sun May 17 10:21:35 1998  Andreas Mohr <100.30936@germany.net>

	* [controls/menu.c]
	Fixed disabled sub menus with MF_BYPOSITION that were not disabled.

	* [misc/crtdll.c] [relay32/crtdll.spec] [include/winerror.h]
	Implemented fscanf, fsetpos, _access, _fpreset (thanks to Uwe Bonnes),
	and _ltoa. 

	* [loader/task.c]
	MakeProcInstance: must use CURRENT_DS if hInst == NULL.

	* [misc/shell.c]
	SHELL_GetResourceTable, InternalExtractIcon: fixed broken .ICO handling

	* [windows/winpos.c]
	DeferWindowPos: removed "same parent" requirement.
	Which doc states that this is required ?

Sat May 16 20:08:11 1998  Alexandre Julliard  <julliard@lrc.epfl.ch>

	* [loader/module.c] [loader/ne/module.c]
	More NE module cleanups.

	* [loader/task.c]
	Fixed SwitchStackBack().

Fri May 15 10:04:27 1998  Marcus Meissner <marcus@jet.franken.de>

	* [configure.in][inlcude/acconfig.h]
	Fixed broken OSS check, added check for working sigaltstack,
	fixed broken statfs checks on some linux systems.

	* [files/directory.c][loader/pe_image.c][relay32/builtin.c]
	  [loader/module.c]
	Added handling of win32 module pathnames.

	* [relay32/wnaspi32.spec]
	New file.

	* [misc/lzexpand.c]
	LZCopy auto-decompresses LZ compressed files, even if they are not
	specially flagged. Fixes some InstallShield problems.

	* [misc/registry.c]
	Some fixes for RegQueryInfoKey (reference program monkey.exe
	from Win32 SDK works now better). Probably still has faults.

Fri May 15 08:58:58 1998  Martin Boehme <boehme@informatik.mu-luebeck.de>

	* [graphics/mapping.c] [include/dc.h] [include/gdi.h] [objects/dc.c]
	Reworked the way world transformations and mapping modes are handled
	so that both of these transformations can be computed in a single
	step.

	* [graphics/painting.c] [graphics/path.c] [include/path.h]
	More GDI path support.

	* [graphics/x11drv/graphics.c]
	Fixed the return value of GRAPH_DrawArc for the zero height /
	zero width case to reflect Windows' behaviour.

	* [include/windows.h] [relay32/gdi32.spec] [objects/dc.c]
	Implemented ModifyWorldTransform and CombineTransform.

Tue May 14 18:03:46 1998  Eric Kohl <ekohl@abo.rhein-zeitung.de>

	* [controls/commctrl.c][relay32/comctl32.spec]
	  [controls/*.c][include/*.h]
	Implemented InitCommonControlsEx (dll version 4.72 compatible).
	InitCommonControls calls ImageCommonControlsEx.
	Registering code of the common controls had to be changed
	(see XXXX_Register functions).

	* [controls/status.c][include/commctrl.h][include/status.h]
	Implemented most new features and fixed the look and feel.

	* [contols/commctrl.c][include/commctrl.h][relay32/comctl32.spec]
	Implemented MenuHelp (incomplete).

	* [controls/status.c][controls/progress.c]
	Changed allocation strategy for control specific memory.

	* [controls/header.c][include/header.h][include/commctrl.h]
	First implementation of header control.

	* [windows/defwnd.c][windows/syscolors.c]
	Fixed default control colors for Win95 look.

	* [windows/nonclient.c]
	Fixed off by one error for Win95 look. Top border of child windows
	should be visible.

	* [misc/imagelist.h]
	Improved documentation and fixed some bugs.

Thu May 14 15:42:21 1998  Robert Wilhelm  <robert@physiol.med.tu-muenchen.de>

	* [relay32/crtdll.spec]
	Added hypot,j0,j1,jn and ceil.

Wed May 13 19:10:10 1998  Pascal Cuoq <pcuoq@ens-lyon.fr>

	* [controls/listbox.c]
	Item height is now exactly font height.
	Wine listboxes now behave like Windows' when they are 
	created without WS_VSCROLL but the program subsequently 
	calls ShowScrollBar or SetScrollInfo.

Wed May 13 18:33:01 1998  Ulrich Weigand <weigand@informatik.uni-erlangen.de>

	* [relay32/relay386.c]
	Restore ES also in the non-debug case.

	* [windows/event.c]
	Bugfix: Blocking TSXNextEvent could deadlock Wine.

	* [win32/process.c] [windows/message.c]
	Silly stubs for MsgWaitForMultipleObjects / PostThreadMessage
	that make some programs run better.

	* [windows/winproc.c]
	WINPROC_MapMsg32Ato16/16To32A: added WM_NOTIFY.  

        * [win32/kernel32.c]
	Added 16->32 thunking and improved 32->16 thunking functions.

	* [tools/build.c]
	Added new variant of CallFrom16 stub for use with Win95 thunks.

	* [if1632/kernel.spec] [if1632/builtin.c] [win32/kernel32.c]
	Added a few undocumented KERNEL functions.

	* [loader/ne/module.c] [loader/ne/segment.c]
	Call DllEntryPoint for 16-bit DLLs with subsystem >= 4.0.

	* [win32/kernel32.spec] [win32/wow32.spec] [win32/ordinals.c]
	Use names from the Oct 94 beta release for undoc. functions.

Wed May 13 14:18:26 1998  Matthew Becker <mbecker@glasscity.net>

	* [misc/registry.c]
	Code cleanup.

	* [misc/cpu.c]
	Commented out the registry puts temporarily.

	* [programs/regtest/*]
	New registry testing program.

Tue May 12 22:54:03 1998  Michael Mess <michael@kawo2.rwth-aachen.de>

	* [multimedia/audio.c]
	ioctl's do not commute in /dev/dsp initialization.

Tue May 12 20:11:42 1998  Karl Garrison <karlos@eznet.net>

	* [win32/console.c]
	Implemented SetConsoleTextAttribute, FillConsoleOutputCharacter.
	Improved cursor positioning.
	This allows for text colors in an xterm, rxvt, or console.

Tue May 12 17:57:52 1998  Petter Reinholdtsen <pere@td.org.uit.no>

	* [Makefile.in]
	Create prefix/{bin|lib} directories if missing during install.

Sun May 10 19:37:51 1998  Jan Willamowius <jan@janhh.shnet.org>

	* [multimedia/mmio.c]
	Have mmioSetBuffer return success (0), so Corel Draw 4
	keeps working. (IO is still unbuffered)

Wed May  6 16:57:55 1998  James Juran <jrj120@psu.edu>

        * [Makefile.in] [Make.rules.in]
	Changed "make clean" to remove `textedit` backup files (*%)

	* [controls/menu.c][graphics/x11drv/xfont.c][include/libres.h]
	  [loader/main.c][loader/ne/module.c][scheduler/synchro.c]
	  [win32/time.c][windows/winpos.c][include/windows.h]
	Fixed miscellaneous compilation warnings.

	* [misc/main.c][miscemu/main.c][include/main.h]
	Moved prototypes to new include file main.h, various cleanups.

Tue May  5 21:05:06 1998  Morten Welinder  <terra@diku.dk>

	* [misc/winsock.c]
	Don't refer to __FreeBSD__ when HAVE_STRERROR is meant.

	* [misc/debugstr.c]
	For debug_dumpstrSend, send strings to stderr.

Tue May  5 21:47:40 1998  Huw D M Davies <h.davies1@physics.oxford.ac.uk>

	* [objects/region.c]
	Fix for REGION_RegionOp() if newReg is one of the source regions.

Tue May  5 18:27:32 1998  Jim Peterson <jspeter@roanoke.infi.net>

	* [misc/main.c]
	Add '-h/-help' option and print WINE_RELEASE_INFO with usage message.

	* [misc/spy.c]
	Realign trace messages.

Tue May  5 15:46:47 1998  Donnie V. Savage <dsavage@cisco.com>

	* [graphics/ddraw.c]
	Fixed compile warnings

	* [misc/winsock.c]
	Warnings should not be errors.

Tue May  5 13:40:42 1998  Jim Peterson <jspeter@roanoke.infi.net>

	* [*/*]
	Remove many warnings through explicit casts, added #include's,
	and corrected printf formats.

Tue May  5 05:18:12 1998  Insomnia (Stea Greene) <insomnia@core.binghamton.edu>

	* [graphics/ddraw.c]
	Kept unchanged portion of old palette when changing only a few
	palette entries.  Really should only deallocate the changed cells.
	This make StarCraft work almost perfectly (sound overflows still
	cause static).

Mon May  4 15:04:57 1998  Alexander V. Lukyanov <lav@long.yar.ru>

	* [misc/lstr.c]
	FormatMessage: terminate string on %0, undo linefeed strip.
diff --git a/include/commctrl.h b/include/commctrl.h
index 2ed95f6..a2670e8 100644
--- a/include/commctrl.h
+++ b/include/commctrl.h
@@ -9,6 +9,30 @@
 
 void WINAPI InitCommonControls(void);
 
+typedef struct tagINITCOMMONCONTROLSEX {
+    DWORD dwSize;
+    DWORD dwICC;
+} INITCOMMONCONTROLSEX, *LPINITCOMMONCONTROLSEX;
+
+BOOL32 WINAPI InitCommonControlsEx(LPINITCOMMONCONTROLSEX);
+
+#define ICC_LISTVIEW_CLASSES   0x00000001  /* listview, header */
+#define ICC_TREEVIEW_CLASSES   0x00000002  /* treeview, tooltips */
+#define ICC_BAR_CLASSES        0x00000004  /* toolbar, statusbar, trackbar, tooltips */
+#define ICC_TAB_CLASSES        0x00000008  /* tab, tooltips */
+#define ICC_UPDOWN_CLASS       0x00000010  /* updown */
+#define ICC_PROGRESS_CLASS     0x00000020  /* progress */
+#define ICC_HOTKEY_CLASS       0x00000040  /* hotkey */
+#define ICC_ANIMATE_CLASS      0x00000080  /* animate */
+#define ICC_WIN95_CLASSES      0x000000FF
+#define ICC_DATE_CLASSES       0x00000100  /* month picker, date picker, time picker, updown */
+#define ICC_USEREX_CLASSES     0x00000200  /* comboex */
+#define ICC_COOL_CLASSES       0x00000400  /* rebar (coolbar) */
+#define ICC_INTERNET_CLASSES   0x00000800  /* IP address, ... */
+#define ICC_PAGESCROLLER_CLASS 0x00001000  /* page scroller */
+#define ICC_NATIVEFNTCTL_CLASS 0x00002000  /* native font control ???*/
+
+
 /* common control styles */
 
 #define CCS_TOP             0x00000001L
@@ -25,10 +49,31 @@
 
 
 /* common control shared messages */
-
 #define CCM_FIRST           0x2000
 
-#define CCM_SETBKCOLOR      (CCM_FIRST+1)     // lParam = bkColor
+#define CCM_SETBKCOLOR      (CCM_FIRST+1)     /* lParam = bkColor */
+
+
+/* common notification codes */
+#define NM_FIRST             (0U-0U)
+#define NM_LAST              (0U-99U)
+
+#define NM_OUTOFMEMORY       (NM_FIRST-1)
+#define NM_CLICK             (NM_FIRST-2)
+#define NM_DBLCLK            (NM_FIRST-3)
+#define NM_RETURN            (NM_FIRST-4)
+#define NM_RCLICK            (NM_FIRST-5)
+#define NM_RDBLCLK           (NM_FIRST-6)
+#define NM_SETFOCUS          (NM_FIRST-7)
+#define NM_KILLFOCUS         (NM_FIRST-8)
+#define NM_CUSTOMDRAW        (NM_FIRST-12)
+#define NM_HOVER             (NM_FIRST-13)
+#define NM_NCHITTEST         (NM_FIRST-14)
+#define NM_KEYDOWN           (NM_FIRST-15)
+#define NM_RELEASEDCAPTURE   (NM_FIRST-16)
+#define NM_SETCURSOR         (NM_FIRST-17)
+#define NM_CHAR              (NM_FIRST-18)
+#define NM_TOOLTIPSCREATED   (NM_FIRST-19)
 
 
 /* StatusWindow */
@@ -54,14 +99,26 @@
 #define SB_SETMINHEIGHT       (WM_USER+8)
 #define SB_SIMPLE             (WM_USER+9)
 #define SB_GETRECT            (WM_USER+10)
+#define SB_ISSIMPLE           (WM_USER+14)
+#define SB_SETICON            (WM_USER+15)
+#define SB_GETICON            (WM_USER+20)
+#define SB_SETBKCOLOR         CCM_SETBKCOLOR   /* lParam = bkColor */
 
 #define SBT_NOBORDERS         0x0100
 #define SBT_POPOUT            0x0200
-#define SBT_RTLREADING        0x0400
+#define SBT_RTLREADING        0x0400  /* not supported */
 #define SBT_OWNERDRAW         0x1000
 
 #define SBARS_SIZEGRIP        0x0100
 
+#define SBN_FIRST             (0U-880U)
+#define SBN_LAST              (0U-899U)
+#define SBN_SIMPLEMODECHANGE  (SBN_FIRST-0)
+
+void WINAPI MenuHelp (UINT32, WPARAM32, LPARAM, HMENU32,
+                      HINSTANCE32, HWND32, LPUINT32);
+
+
 /* UpDown */
 
 #define UPDOWN_CLASS16        "msctls_updown"
@@ -200,22 +257,22 @@
 
 
 typedef struct _IMAGELISTDRAWPARAMS
-{ 
-    DWORD       cbSize; 
-    HIMAGELIST  himl; 
-    INT32       i; 
-    HDC32       hdcDst; 
-    INT32       x; 
-    INT32       y; 
-    INT32       cx; 
-    INT32       cy; 
-    INT32       xBitmap;        // x offest from the upperleft of bitmap 
-    INT32       yBitmap;        // y offset from the upperleft of bitmap 
-    COLORREF    rgbBk; 
-    COLORREF    rgbFg; 
-    UINT32      fStyle; 
-    DWORD       dwRop; 
-} IMAGELISTDRAWPARAMS, *LPIMAGELISTDRAWPARAMS; 
+{
+    DWORD       cbSize;
+    HIMAGELIST  himl;
+    INT32       i;
+    HDC32       hdcDst;
+    INT32       x;
+    INT32       y;
+    INT32       cx;
+    INT32       cy;
+    INT32       xBitmap;  /* x offest from the upperleft of bitmap */
+    INT32       yBitmap;  /* y offset from the upperleft of bitmap */
+    COLORREF    rgbBk;
+    COLORREF    rgbFg;
+    UINT32      fStyle;
+    DWORD       dwRop;
+} IMAGELISTDRAWPARAMS, *LPIMAGELISTDRAWPARAMS;
 
  
 INT32      WINAPI ImageList_Add(HIMAGELIST,HBITMAP32,HBITMAP32);
@@ -265,4 +322,144 @@
 #define ImageList_RemoveAll(himl) ImageList_Remove(himl,-1)
 
 
+/* Header control */
+
+#define WC_HEADER16    "SysHeader" 
+#define WC_HEADER32A   "SysHeader32" 
+#define WC_HEADER32W  L"SysHeader32" 
+
+#define WC_HEADER     WINELIB_NAME_AW(WC_HEADER)
+ 
+#define HDS_HORZ                0x0000 
+#define HDS_BUTTONS             0x0002 
+#define HDS_HOTTRACK            0x0004 
+#define HDS_HIDDEN              0x0008 
+#define HDS_DRAGDROP            0x0040 
+#define HDS_FULLDRAG            0x0080 
+
+#define HDI_WIDTH               0x0001
+#define HDI_HEIGHT              HDI_WIDTH
+#define HDI_TEXT                0x0002
+#define HDI_FORMAT              0x0004
+#define HDI_LPARAM              0x0008
+#define HDI_BITMAP              0x0010
+#define HDI_IMAGE               0x0020
+#define HDI_DI_SETITEM          0x0040
+#define HDI_ORDER               0x0080
+
+#define HDF_LEFT                0x0000
+#define HDF_RIGHT               0x0001
+#define HDF_CENTER              0x0002
+#define HDF_JUSTIFYMASK         0x0003
+
+#define HDF_IMAGE               0x0800
+#define HDF_BITMAP_ON_RIGHT     0x1000
+#define HDF_BITMAP              0x2000
+#define HDF_STRING              0x4000
+#define HDF_OWNERDRAW           0x8000
+
+#define HHT_NOWHERE             0x0001
+#define HHT_ONHEADER            0x0002
+#define HHT_ONDIVIDER           0x0004
+#define HHT_ONDIVOPEN           0x0008
+#define HHT_ABOVE               0x0100
+#define HHT_BELOW               0x0200
+#define HHT_TORIGHT             0x0400
+#define HHT_TOLEFT              0x0800
+
+#define HDM_FIRST               0x1200
+#define HDM_GETITEMCOUNT        (HDM_FIRST+0)
+#define HDM_INSERTITEM32A       (HDM_FIRST+1)
+#define HDM_INSERTITEM32W       (HDM_FIRST+10)
+#define HDM_INSERTITEM WINELIB_NAME_AW(HDM_INSERTITEM)
+#define HDM_DELETEITEM          (HDM_FIRST+2)
+#define HDM_GETITEM32A          (HDM_FIRST+3)
+#define HDM_GETITEM32W          (HDM_FIRST+11)
+#define HDM_GETITEM WINELIB_NAME_AW(HDM_GETITEM)
+#define HDM_SETITEM32A          (HDM_FIRST+4)
+#define HDM_SETITEM32W          (HDM_FIRST+12)
+#define HDM_SETITEM WINELIB_NAME_AW(HDM_SETITEM)
+#define HDM_LAYOUT              (HDM_FIRST+5)
+#define HDM_HITTEST             (HDM_FIRST+6)
+#define HDM_GETITEMRECT         (HDM_FIRST+7)
+#define HDM_SETIMAGELIST        (HDM_FIRST+8)
+#define HDM_GETIMAGELIST        (HDM_FIRST+9)
+
+
+#define HDM_ORDERTOINDEX        (HDM_FIRST+15)
+#define HDM_CREATEDRAGIMAGE     (HDM_FIRST+16)
+#define HDM_GETORDERARRAY       (HDM_FIRST+17)
+#define HDM_SETORDERARRAY       (HDM_FIRST+18)
+#define HDM_SETHOTDIVIDER       (HDM_FIRST+19)
+
+#define HDN_FIRST               (0U-300U)
+#define HDN_LAST                (0U-399U)
+#define HDN_ITEMCHANGING32A     (HDN_FIRST-0)
+#define HDN_ITEMCHANGING32W     (HDN_FIRST-20)
+#define HDN_ITEMCHANGED32A      (HDN_FIRST-1)
+#define HDN_ITEMCHANGED32W      (HDN_FIRST-21)
+#define HDN_ITEMCLICK32A        (HDN_FIRST-2)
+#define HDN_ITEMCLICK32W        (HDN_FIRST-22)
+#define HDN_ITEMDBLCLICK32A     (HDN_FIRST-3)
+#define HDN_ITEMDBLCLICK32W     (HDN_FIRST-23)
+#define HDN_DIVIDERDBLCLICK32A  (HDN_FIRST-5)
+#define HDN_DIVIDERDBLCLICK32W  (HDN_FIRST-25)
+#define HDN_BEGINTRACK32A       (HDN_FIRST-6)
+#define HDN_BEGINTRACK32W       (HDN_FIRST-26)
+#define HDN_ENDTRACK32A         (HDN_FIRST-7)
+#define HDN_ENDTRACK32W         (HDN_FIRST-27)
+#define HDN_TRACK32A            (HDN_FIRST-8)
+#define HDN_TRACK32W            (HDN_FIRST-28)
+#define HDN_GETDISPINFO32A      (HDN_FIRST-9)
+#define HDN_GETDISPINFO32W      (HDN_FIRST-29)
+#define HDN_BEGINDRACK          (HDN_FIRST-10)
+#define HDN_ENDDRACK            (HDN_FIRST-11)
+
+
+#define Header_Layout(hwndHD,playout) \
+  (BOOL32)SendMessage32A((hwndHD),HDM_LAYOUT,0,(LPARAM)(LPHDLAYOUT)(playout))
+
+
+typedef struct _HD_LAYOUT
+{
+    RECT32      *prc;
+    WINDOWPOS32 *pwpos;
+} HDLAYOUT, *LPHDLAYOUT;
+
+#define HD_LAYOUT   HDLAYOUT
+
+
+typedef struct _HD_ITEMA
+{
+    UINT32    mask;
+    INT32     cxy;
+    LPSTR     pszText;
+    HBITMAP32 hbm;
+    INT32     cchTextMax;
+    INT32     fmt;
+    LPARAM    lParam;
+    INT32     iImage;
+    INT32     iOrder;
+} HD_ITEMA;
+
+
+typedef struct _HD_HITTESTINFO
+{
+    POINT32 pt;
+    UINT32  flags;
+    INT32   iItem;
+} HDHITTESTINFO, *LPHDHITTESTINFO;
+
+#define HD_HITTESTINFO   HDHITTESTINFO
+
+
+typedef struct tagNMHEADERA
+{
+    NMHDR    hdr;
+    INT32    iItem;
+    INT32    iButton;
+    HD_ITEMA *pitem;
+} NMHEADERA, *LPNMHEADERA;
+
+
 #endif  /* __WINE_COMMCTRL_H */