// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
-// check if to use precompiled headers
-#if (defined(__BORLANDC__) || defined(__VISUALC__) || defined(__WATCOMC__)) && defined(__WXMSW__)
- #if !NOPCH
+// compiler detection; includes setup.h
+#include "wx/defs.h"
+
+// check if to use precompiled headers: do it for most Windows compilers unless
+// adding DigitalMars here appears to amke it slower!
+// explicitly disabled by defining NOPCH
+#if ((defined(__BORLANDC__) || defined(__VISUALC__) || defined(__DIGITALMARS__) || defined(__WATCOMC__)) && defined(__WXMSW__)) || defined(__VISAGECPP__) || defined(__MWERKS__)
+ #if !defined(NOPCH)
#define WX_PRECOMP
#endif
#endif
// For some reason, this must be defined for common dialogs to work.
#ifdef __WATCOMC__
-#define INCLUDE_COMMDLG_H 1
+ #define INCLUDE_COMMDLG_H 1
#endif
-// include the wx definitions
#ifdef WX_PRECOMP
-#include "wx/wx.h"
-
-// Comment this out if you don't mind slower compilation of the wxWindows
-// library
-#if !defined(__WXMAC__) && !defined(__SALFORDC__)
-#include <windows.h>
-#endif
-
-#ifdef GetClassInfo
-#undef GetClassInfo
-#endif
-
-#ifdef GetClassName
-#undef GetClassName
-#endif
-
-#ifdef DrawText
-#undef DrawText
-#endif
-#ifdef GetCharWidth
-#undef GetCharWidth
-#endif
-
-#ifdef StartDoc
-#undef StartDoc
-#endif
-
-#ifdef FindWindow
-#undef FindWindow
-#endif
+// include <wx/wxchar.h> first to ensure that UNICODE macro is correctly set
+// _before_ including <windows.h>
+#include "wx/wxchar.h"
-#ifdef FindResource
-#undef FindResource
+// include standard Windows headers
+#if defined(__WXMSW__) && !wxUSE_MFC
+ #include "wx/msw/wrapwin.h"
#endif
-#ifdef LoadAccelerators
-#undef LoadAccelerators
-#endif
-
-#else
- // always include this file (under Unix it's generated by configure)
- #include "wx/setup.h"
-#endif
+// include the most common wx headers
+#include "wx/wx.h"
+#endif // WX_PRECOMP