-// check if to use precompiled headers
-#if (defined(__BORLANDC__) || defined(_MSC_VER) || defined(__WATCOMC__) || defined(__GNUWIN32__)) && defined(__WXMSW__)
-#if !NOPCH
-#define WX_PRECOMP
-#endif
+// compiler detection; includes setup.h
+#include "wx/defs.h"
+
+// check if to use precompiled headers: do it for most Windows compilers unless
+// explicitly disabled by defining NOPCH
+#if ( defined(__WXMSW__) && \
+ ( defined(__BORLANDC__) || \
+ defined(__VISUALC__) || \
+ defined(__DIGITALMARS__) || \
+ defined(__WATCOMC__) ) ) || \
+ defined(__VISAGECPP__) || \
+ defined(__MWERKS__)
+
+ // If user did not request NOCPH and we're not building using configure
+ // then assume user wants precompiled headers.
+ #if !defined(NOPCH) && !defined(__WX_SETUP_H__)
+ #define WX_PRECOMP
+ #endif