#include <windows.h>
+#ifdef __WXMICROWIN__
+/* Extra prototypes and symbols not defined by MicroWindows */
+#include "wx/msw/microwin.h"
+#endif
+
// undefine conflicting symbols which were defined in windows.h
#include "wx/msw/winundef.h"
// define things missing from some compilers' headers
// ---------------------------------------------------------------------------
-#if defined(__GNUWIN32__) && !defined(wxUSE_NORLANDER_HEADERS)
+#if defined(__GNUWIN32__) && !wxUSE_NORLANDER_HEADERS
#ifndef ZeroMemory
inline void ZeroMemory(void *buf, size_t len) { memset(buf, 0, len); }
#endif
// this defines a CASTWNDPROC macro which casts a pointer to the type of a
// window proc
-#ifdef __GNUWIN32_OLD__
-# define CASTWNDPROC (long unsigned)
-#else
-# ifdef __BORLANDC__
-# ifdef __WIN32__
-#if __BORLANDC__ > 0x530
- typedef long (__stdcall * WndProcCast)( HWND__*, unsigned int, unsigned int, long) ;
+#if defined(__GNUWIN32_OLD__) && !defined(__CYGWIN10__)
+ #define CASTWNDPROC (long unsigned)
#else
- typedef int (pascal * WndProcCast) ();
-#endif
-# define CASTWNDPROC (WndProcCast)
-# else
- typedef int (pascal * WndProcCast) ();
-# define CASTWNDPROC (WndProcCast)
-# endif
-
-# else
-# if defined (__WIN32__) && defined(STRICT)
- typedef long (_stdcall * WndProcCast) (HWND, unsigned int, unsigned int, long);
-# define CASTWNDPROC (WndProcCast)
-# elif defined(__WIN16__)
-# ifdef __BORLANDC__
- typedef int (pascal * WndProcCast) ();
-# define CASTWNDPROC (WndProcCast)
-# else
-# if defined(__VISUALC__) && defined(STRICT)
-# define CASTWNDPROC (WNDPROC)
-# else
- typedef int (PASCAL * WndProcCast) ();
-# define CASTWNDPROC (WndProcCast)
-# endif
-# endif
-# else
-# define CASTWNDPROC
-# endif
-# endif
-#endif
+ #if defined(STRICT) || defined(__GNUC__)
+ typedef WNDPROC WndProcCast;
+ #else
+ typedef FARPROC WndProcCast;
+ #endif
+ #define CASTWNDPROC (WndProcCast)
+#endif // __GNUWIN32_OLD__
// ---------------------------------------------------------------------------
// some stuff for old Windows versions (FIXME: what does it do here??)
#define DEFAULT_ITEM_HEIGHT 80
// Scale font to get edit control height
-#define EDIT_HEIGHT_FROM_CHAR_HEIGHT(cy) (3*(cy)/2)
+//#define EDIT_HEIGHT_FROM_CHAR_HEIGHT(cy) (3*(cy)/2)
+#define EDIT_HEIGHT_FROM_CHAR_HEIGHT(cy) (cy+8)
// Generic subclass proc, for panel item moving/sizing and intercept
// EDIT control VK_RETURN messages
// ---------------------------------------------------------------------------
// a wrapper macro for ZeroMemory()
-#ifdef __WIN32__
+#if defined(__WIN32__) && !defined(__WXMICROWIN__)
#define wxZeroMemory(obj) ::ZeroMemory(&obj, sizeof(obj))
#else
#define wxZeroMemory(obj) memset((void*) & obj, 0, sizeof(obj))
#endif
+#if wxUSE_GUI
+
#include <wx/gdicmn.h>
// make conversion from wxColour and COLORREF a bit less painful
#define GetHcursor() ((HCURSOR)GetHCURSOR())
#define GetHcursorOf(cursor) ((HCURSOR)(cursor).GetHCURSOR())
+#define GetHfont() ((HFONT)GetHFONT())
+#define GetHfontOf(font) ((HFONT)(font).GetHFONT())
+
+#define GetHrgn() ((HRGN)GetHRGN())
+#define GetHrgnOf(rgn) ((HRGN)(rgn).GetHRGN())
+
+#endif // wxUSE_GUI
+
// ---------------------------------------------------------------------------
// global data
// ---------------------------------------------------------------------------
-#if 0 // where is this??
-// The MakeProcInstance version of the function wxSubclassedGenericControlProc
-WXDLLEXPORT_DATA(extern FARPROC) wxGenericControlSubClassProc;
-#endif // 0
-
WXDLLEXPORT_DATA(extern wxChar*) wxBuffer;
WXDLLEXPORT_DATA(extern HINSTANCE) wxhInstance;
WXDLLEXPORT void wxGetCharSize(WXHWND wnd, int *x, int *y, const wxFont *the_font);
WXDLLEXPORT void wxFillLogFont(LOGFONT *logFont, const wxFont *font);
WXDLLEXPORT wxFont wxCreateFontFromLogFont(const LOGFONT *logFont);
+WXDLLEXPORT wxFontEncoding wxGetFontEncFromCharSet(int charset);
WXDLLEXPORT void wxSliderEvent(WXHWND control, WXWORD wParam, WXWORD pos);
WXDLLEXPORT void wxScrollBarEvent(WXHWND hbar, WXWORD wParam, WXWORD pos);