From ce4169a4d129fc6cd165b2e9ccc5cf5d48356020 Mon Sep 17 00:00:00 2001
From: Robert Roebling <robert@roebling.de>
Date: Tue, 15 Jun 1999 20:21:59 +0000
Subject: [PATCH]   Added a few #if wxUSE_XXX   Regrouped image format handlers
   Updated the rest accordingly   Added changes.txt for wxGTK

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@2795 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
---
 acconfig.h                    |  11 +-
 configure.in                  | 234 +++++++++--------
 docs/gtk/changes.txt          | 464 ++++++++++++++++++++++++++++++++++
 include/wx/datstrm.h          |   5 +
 include/wx/file.h             |   4 +
 include/wx/fileconf.h         |  18 +-
 include/wx/generic/dcpsg.h    |   5 +
 include/wx/generic/dirdlgg.h  |   8 +-
 include/wx/generic/printps.h  |   4 +
 include/wx/generic/prntdlgg.h |   5 +
 include/wx/generic/progdlgg.h |   5 +-
 include/wx/gtk/choice.h       |   5 +
 include/wx/gtk1/choice.h      |   5 +
 include/wx/image.h            |  23 +-
 include/wx/imaggif.h          |  46 ----
 include/wx/mimetype.h         |  14 +-
 include/wx/mstream.h          |   6 +
 include/wx/msw/setup0.h       |   5 +
 include/wx/objstrm.h          |   7 +
 include/wx/sckstrm.h          |   7 +
 include/wx/socket.h           |   8 +
 include/wx/stream.h           |   8 +
 include/wx/textfile.h         |  14 +-
 include/wx/valgen.h           |   8 +-
 include/wx/valtext.h          |  10 +-
 include/wx/wfstream.h         |   8 +
 include/wx/zstream.h          |   4 +-
 src/common/config.cpp         |  15 +-
 src/common/date.cpp           |   6 +-
 src/common/datstrm.cpp        |  10 +-
 src/common/docview.cpp        |  11 +-
 src/common/event.cpp          |  16 +-
 src/common/file.cpp           |  11 +-
 src/common/http.cpp           |   7 +-
 src/common/image.cpp          | 364 +-------------------------
 src/common/imaggif.cpp        |  32 +--
 src/common/imagjpeg.cpp       |  25 +-
 src/common/imagpng.cpp        |  27 +-
 src/common/layout.cpp         |  16 +-
 src/common/mimetype.cpp       |  30 ++-
 src/common/mstream.cpp        |  17 +-
 src/common/objstrm.cpp        |   7 +-
 src/common/sckfile.cpp        |   7 +-
 src/common/sckstrm.cpp        |   8 +-
 src/common/stream.cpp         |  18 +-
 src/common/textfile.cpp       |  11 +-
 src/common/valgen.cpp         |  67 +++--
 src/common/validate.cpp       |  15 +-
 src/common/valtext.cpp        |  23 +-
 src/common/wfstream.cpp       |  18 +-
 src/common/zstream.cpp        |  21 +-
 src/generic/dcpsg.cpp         |   5 +
 src/generic/dirdlgg.cpp       |   5 +
 src/generic/helphtml.cpp      |   2 +
 src/generic/listctrl.cpp      |   2 +
 src/generic/printps.cpp       |   3 +
 src/generic/prntdlgg.cpp      |   3 +
 src/generic/progdlgg.cpp      |   4 +
 src/generic/treectrl.cpp      |   2 +
 src/gtk/Makefile.am           |   1 +
 src/gtk/bmpbuttn.cpp          |   2 +
 src/gtk/checkbox.cpp          |   3 +
 src/gtk/choice.cpp            |   5 +
 src/gtk/combobox.cpp          |   2 +
 src/gtk/gauge.cpp             |   4 +-
 src/gtk/listbox.cpp           |   2 +
 src/gtk/radiobox.cpp          |   2 +
 src/gtk/radiobut.cpp          |   2 +
 src/gtk/scrolbar.cpp          |   2 +
 src/gtk/slider.cpp            |   2 +
 src/gtk1/Makefile.am          |   1 +
 src/gtk1/bmpbuttn.cpp         |   2 +
 src/gtk1/checkbox.cpp         |   3 +
 src/gtk1/choice.cpp           |   5 +
 src/gtk1/combobox.cpp         |   2 +
 src/gtk1/gauge.cpp            |   4 +-
 src/gtk1/listbox.cpp          |   2 +
 src/gtk1/radiobox.cpp         |   2 +
 src/gtk1/radiobut.cpp         |   2 +
 src/gtk1/scrolbar.cpp         |   2 +
 src/gtk1/slider.cpp           |   2 +
 src/motif/Makefile.am         |   1 +
 src/msw/Makefile.am           |   1 +
 src/msw/makefile.b32          |   3 +
 src/msw/makefile.g95          |   1 +
 src/msw/makefile.twn          |   1 +
 src/msw/makefile.vc           |   1 +
 src/msw/makefile.wat          |   4 +
 88 files changed, 1121 insertions(+), 694 deletions(-)
 create mode 100644 docs/gtk/changes.txt
 delete mode 100644 include/wx/imaggif.h

diff --git a/acconfig.h b/acconfig.h
index 54d1593744..4625ab0c8f 100644
--- a/acconfig.h
+++ b/acconfig.h
@@ -144,6 +144,11 @@
  */
 #define wxUSE_TEXTDLG 0
 
+/*
+ * Use progress dialog
+ */
+#define wxUSE_PROGRESSDLG 0
+
 /*
  * Use directory chooser dialog
  */
@@ -178,6 +183,10 @@
  * Use this control
  */
 #define wxUSE_COMBOBOX 0
+/*
+ * Use this control
+ */
+#define wxUSE_CHOICE 0
 /*
  * Use this control
  */
@@ -288,7 +297,7 @@
 /*
  * Use log classes and logging functions
  */
-#define wxUSE_LOG 1
+#define wxUSE_LOG 0
 /*
  * Use time and date classes
  */
diff --git a/configure.in b/configure.in
index 0918f33010..f4d3b69342 100644
--- a/configure.in
+++ b/configure.in
@@ -284,6 +284,8 @@ if test $DEBUG_CONFIGURE = 1; then
   DEFAULT_wxUSE_METAFILE=no
 
   DEFAULT_wxUSE_COMMONDLGS=no
+  DEFAULT_wxUSE_DIRDLG=no
+  DEFAULT_wxUSE_PROGRESSDLG=no
   DEFAULT_wxUSE_MINIFRAME=no
   DEFAULT_wxUSE_VALIDATORS=yes
 
@@ -292,6 +294,7 @@ if test $DEBUG_CONFIGURE = 1; then
   DEFAULT_wxUSE_BMPBUTTON=no
   DEFAULT_wxUSE_CHECKBOX=no
   DEFAULT_wxUSE_CHECKLST=no
+  DEFAULT_wxUSE_CHOICE=no
   DEFAULT_wxUSE_COMBOBOX=no
   DEFAULT_wxUSE_GAUGE=no
   DEFAULT_wxUSE_GRID=no
@@ -375,6 +378,8 @@ else
   DEFAULT_wxUSE_METAFILE=yes
 
   DEFAULT_wxUSE_COMMONDLGS=yes
+  DEFAULT_wxUSE_DIRDLG=yes
+  DEFAULT_wxUSE_PROGRESSDLG=yes
   DEFAULT_wxUSE_MINIFRAME=yes
   DEFAULT_wxUSE_VALIDATORS=yes
 
@@ -383,6 +388,7 @@ else
   DEFAULT_wxUSE_BMPBUTTON=yes
   DEFAULT_wxUSE_CHECKBOX=yes
   DEFAULT_wxUSE_CHECKLST=yes
+  DEFAULT_wxUSE_CHOICE=yes
   DEFAULT_wxUSE_COMBOBOX=yes
   DEFAULT_wxUSE_GAUGE=yes
   DEFAULT_wxUSE_GRID=yes
@@ -565,6 +571,7 @@ if test "$wxUSE_CONTROLS" = "yes"; then
   DEFAULT_wxUSE_BMPBUTTON=yes
   DEFAULT_wxUSE_CHECKBOX=yes
   DEFAULT_wxUSE_CHECKLISTBOX=yes
+  DEFAULT_wxUSE_CHOICE=yes
   DEFAULT_wxUSE_GAUGE=yes
   DEFAULT_wxUSE_GRID=yes
   DEFAULT_wxUSE_IMAGLIST=yes
@@ -593,6 +600,7 @@ elif test "$wxUSE_CONTROLS" = "no"; then
   DEFAULT_wxUSE_BMPBUTTON=no
   DEFAULT_wxUSE_CHECKBOX=no
   DEFAULT_wxUSE_CHECKLISTBOX=no
+  DEFAULT_wxUSE_CHOICE=no
   DEFAULT_wxUSE_GAUGE=no
   DEFAULT_wxUSE_GRID=no
   DEFAULT_wxUSE_IMAGLIST=no
@@ -621,7 +629,8 @@ WX_ARG_ENABLE(caret,       [  --enable-caret          use wxCaret class], wxUSE_
 WX_ARG_ENABLE(bmpbutton,   [  --enable-bmpbutton      use wxBitmapButton class], wxUSE_BMPBUTTON)
 WX_ARG_ENABLE(checkbox,    [  --enable-checkbox       use wxCheckBox class], wxUSE_CHECKBOX)
 WX_ARG_ENABLE(checklst,    [  --enable-checklst       use wxCheckListBox (listbox with checkboxes) class], wxUSE_CHECKLST)
-WX_ARG_ENABLE(combobox,    [  --enable-combobox       use wxChoice and wxComboBox classes], wxUSE_COMBOBOX)
+WX_ARG_ENABLE(choice,      [  --enable-choice         use wxChoice class], wxUSE_CHOICE)
+WX_ARG_ENABLE(combobox,    [  --enable-combobox       use wxComboBox classes], wxUSE_COMBOBOX)
 WX_ARG_ENABLE(gauge,       [  --enable-gauge          use wxGauge class], wxUSE_GAUGE)
 WX_ARG_ENABLE(grid,        [  --enable-grid           use wxGrid class], wxUSE_GRID)
 WX_ARG_ENABLE(imaglist,    [  --enable-imaglist       use wxImageList class], wxUSE_IMAGLIST)
@@ -648,6 +657,8 @@ dnl misc GUI options
 dnl ---------------------------------------------------------------------------
 
 WX_ARG_ENABLE(commondlg,   [  --enable-commondlg      use common dialogs (wxDirDialog, wxProgressDialog, wxTextDialog, ...)], wxUSE_COMMONDLGS)
+WX_ARG_ENABLE(dirdlg,      [  --enable-dirdlg         use wxDirDialog], wxUSE_DIRDLG)
+WX_ARG_ENABLE(progressdlg, [  --enable-progressdlg    use wxProgressDialog], wxUSE_PROGRESSDLG)
 WX_ARG_ENABLE(miniframe,   [  --enable-miniframe      use wxMiniFrame class], wxUSE_MINIFRAME)
 WX_ARG_ENABLE(tooltips,    [  --enable-tooltips       use wxToolTip class], wxUSE_TOOLTIPS)
 WX_ARG_ENABLE(splines,     [  --enable-splines        use spline drawing code], wxUSE_SPLINES)
@@ -1368,7 +1379,7 @@ if test "$wxUSE_OPTIMISE" = "no" ; then
   OPTIMISE=
 else
   if test "$GCC" = yes ; then
-    OPTIMISE="-O2"
+    OPTIMISE="-O2 -fno-rtti -fno-exceptions"
     case "${host}" in
       i586-*-*|i686-*-* )
         OPTIMISE="${OPTIMISE} "
@@ -1666,48 +1677,52 @@ dnl big GUI components: MDI, doc/view, printing, help, ...
 dnl ---------------------------------------------------------------------------
 
 if test "$wxUSE_CONSTRAINTS" = "yes"; then
-  AC_DEFINE(wxUSE_CONSTRAINTS)
-  SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS layout"
+    AC_DEFINE(wxUSE_CONSTRAINTS)
+    SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS layout"
 fi
 
 if test "$wxUSE_MDI_ARCHITECTURE" = "yes"; then
-  AC_DEFINE(wxUSE_MDI_ARCHITECTURE)
-  SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS mdi"
+    AC_DEFINE(wxUSE_MDI_ARCHITECTURE)
+    SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS mdi"
 fi
 
 if test "$wxUSE_DOC_VIEW_ARCHITECTURE" = "yes" ; then
-  AC_DEFINE(wxUSE_DOC_VIEW_ARCHITECTURE)
-  SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS docview"
-  if test "$wxUSE_MDI_ARCHITECTURE" = "yes"; then
-    SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS docvwmdi"
-  fi
+    AC_DEFINE(wxUSE_DOC_VIEW_ARCHITECTURE)
+    SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS docview"
+    if test "$wxUSE_MDI_ARCHITECTURE" = "yes"; then
+        SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS docvwmdi"
+    fi
 fi
 
 if test "$wxUSE_HELP" = "yes"; then
-  AC_DEFINE(wxUSE_HELP)
-  SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS help"
+    AC_DEFINE(wxUSE_HELP)
+    SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS help"
 fi
 
 if test "$wxUSE_PRINTING_ARCHITECTURE" = "yes" ; then
-  AC_DEFINE(wxUSE_PRINTING_ARCHITECTURE)
-  SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS printing"
+    if test "$wxUSE_CONSTRAINTS" != "yes"; then
+        AC_MSG_WARN(Printing support cannot be used without constraints so it won't be compiled without it)
+    else
+        AC_DEFINE(wxUSE_PRINTING_ARCHITECTURE)
+    fi
+    SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS printing"
 fi
 
 if test "$wxUSE_PROLOGIO" = "yes" ; then
-  AC_DEFINE(wxUSE_PROLOGIO)
+    AC_DEFINE(wxUSE_PROLOGIO)
 fi
 
 if test "$wxUSE_RESOURCES" = "yes" ; then
-  if test "$wxUSE_PROLOGIO" = "yes" ; then
-    AC_DEFINE(wxUSE_RESOURCES)
-    SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS resource"
-  else
-    AC_MSG_WARN([wxWindows ressource system requires PrologIO and can't be compiled without it.])
-  fi
+    if test "$wxUSE_PROLOGIO" = "yes" ; then
+        AC_DEFINE(wxUSE_RESOURCES)
+        SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS resource"
+    else
+        AC_MSG_WARN([wxWindows ressource system requires PrologIO and can't be compiled without it.])
+    fi
 fi
 
 if test "$wxUSE_X_RESOURCES" = "yes"; then
-  AC_DEFINE(wxUSE_X_RESOURCES)
+    AC_DEFINE(wxUSE_X_RESOURCES)
 fi
 
 dnl ---------------------------------------------------------------------------
@@ -1715,28 +1730,28 @@ dnl IPC: IPC, d-n-d, clipboard, ...
 dnl ---------------------------------------------------------------------------
 
 if test "$wxUSE_IPC" = "yes"; then
-  AC_DEFINE(wxUSE_IPC)
+    AC_DEFINE(wxUSE_IPC)
 fi
 
 if test "$wxUSE_CLIPBOARD" = "yes"; then
-  AC_DEFINE(wxUSE_CLIPBOARD)
+    AC_DEFINE(wxUSE_CLIPBOARD)
 fi
 
 if test "$wxUSE_DRAG_AND_DROP" = "yes" ; then
-  if test "$wxUSE_GTK" = 1; then
-    if test "$WXGTK12" != 1; then
-      AC_MSG_WARN([Drag and drop is only supported under wxGTK 2.1])
+    if test "$wxUSE_GTK" = 1; then
+        if test "$WXGTK12" != 1; then
+            AC_MSG_WARN([Drag and drop is only supported under wxGTK 2.1])
+        fi
     fi
-  fi
 
-  if test "$wxUSE_MOTIF" = 1; then
-    AC_MSG_WARN([Drag and drop is not yet supported under Motif])
-  fi
+    if test "$wxUSE_MOTIF" = 1; then
+        AC_MSG_WARN([Drag and drop is not yet supported under Motif])
+    fi
 
-  if test "$wxUSE_DRAG_AND_DROP" = "yes"; then
-    AC_DEFINE(wxUSE_DRAG_AND_DROP)
-    SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS dnd"
-  fi
+    if test "$wxUSE_DRAG_AND_DROP" = "yes"; then
+        AC_DEFINE(wxUSE_DRAG_AND_DROP)
+        SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS dnd"
+    fi
 fi
 
 if test "$wxUSE_SPLINES" = "yes" ; then
@@ -1760,6 +1775,10 @@ if test "$wxUSE_COMBOBOX" = "yes"; then
   AC_DEFINE(wxUSE_COMBOBOX)
 fi
 
+if test "$wxUSE_CHOICE" = "yes"; then
+  AC_DEFINE(wxUSE_CHOICE)
+fi
+
 if test "$wxUSE_BMPBUTTON" = "yes"; then
   AC_DEFINE(wxUSE_BMPBUTTON)
 fi
@@ -1783,103 +1802,103 @@ if test "$wxUSE_GRID" = "yes"; then
 fi
 
 if test "$wxUSE_IMAGLIST" = "yes"; then
-  AC_DEFINE(wxUSE_IMAGLIST)
+    AC_DEFINE(wxUSE_IMAGLIST)
 fi
 
 if test "$wxUSE_LISTBOX" = "yes"; then
-  AC_DEFINE(wxUSE_LISTBOX)
+    AC_DEFINE(wxUSE_LISTBOX)
 fi
 
 if test "$wxUSE_LISTCTRL" = "yes"; then
-  if test "$wxUSE_IMAGLIST" = "yes"; then
-    AC_DEFINE(wxUSE_LISTCTRL)
-    SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS listctrl"
-  else
-    AC_MSG_WARN([wxListCtrl requires wxImageList and won't be compiled without it])
-  fi
+    if test "$wxUSE_IMAGLIST" = "yes"; then
+        AC_DEFINE(wxUSE_LISTCTRL)
+        SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS listctrl"
+    else
+        AC_MSG_WARN([wxListCtrl requires wxImageList and won't be compiled without it])
+    fi
 fi
 
 if test "$wxUSE_NOTEBOOK" = "yes"; then
-  AC_DEFINE(wxUSE_NOTEBOOK)
-  SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS notebook"
+    AC_DEFINE(wxUSE_NOTEBOOK)
+    SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS notebook"
 fi
 
 if test "$wxUSE_RADIOBOX" = "yes"; then
-  AC_DEFINE(wxUSE_RADIOBOX)
+    AC_DEFINE(wxUSE_RADIOBOX)
 fi
 
 if test "$wxUSE_RADIOBTN" = "yes"; then
-  AC_DEFINE(wxUSE_RADIOBTN)
+    AC_DEFINE(wxUSE_RADIOBTN)
 fi
 
 if test "$wxUSE_SASH" = "yes"; then
-  AC_DEFINE(wxUSE_SASH)
-  SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS sashtest"
+    AC_DEFINE(wxUSE_SASH)
+    SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS sashtest"
 fi
 
 if test "$wxUSE_SCROLLBAR" = "yes"; then
-  AC_DEFINE(wxUSE_SCROLLBAR)
-  SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS scroll"
+    AC_DEFINE(wxUSE_SCROLLBAR)
+    SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS scroll"
 fi
 
 if test "$wxUSE_SLIDER" = "yes"; then
-  AC_DEFINE(wxUSE_SLIDER)
+    AC_DEFINE(wxUSE_SLIDER)
 fi
 
 if test "$wxUSE_SPINBTN" = "yes"; then
-  AC_DEFINE(wxUSE_SPINBTN)
+    AC_DEFINE(wxUSE_SPINBTN)
 fi
 
 if test "$wxUSE_SPLITTER" = "yes"; then
-  AC_DEFINE(wxUSE_SPLITTER)
-  SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS splitter"
+    AC_DEFINE(wxUSE_SPLITTER)
+    SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS splitter"
 fi
 
 if test "$wxUSE_STATBMP" = "yes"; then
-  AC_DEFINE(wxUSE_STATBMP)
+    AC_DEFINE(wxUSE_STATBMP)
 fi
 
 if test "$wxUSE_STATBOX" = "yes"; then
-  AC_DEFINE(wxUSE_STATBOX)
+    AC_DEFINE(wxUSE_STATBOX)
 fi
 
 if test "$wxUSE_STATLINE" = "yes"; then
-  AC_DEFINE(wxUSE_STATLINE)
+    AC_DEFINE(wxUSE_STATLINE)
 fi
 
 if test "$wxUSE_STATUSBAR" = "yes"; then
-  AC_DEFINE(wxUSE_STATUSBAR)
+    AC_DEFINE(wxUSE_STATUSBAR)
 fi
 
 if test "$wxUSE_TABDIALOG" = "yes"; then
-  AC_DEFINE(wxUSE_TAB_DIALOG)
-  SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS tab"
+    AC_DEFINE(wxUSE_TAB_DIALOG)
+    SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS tab"
 fi
 
 if test "$wxUSE_TOOLBAR" = "yes"; then
-  AC_DEFINE(wxUSE_TOOLBAR)
-  SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS toolbar"
+    AC_DEFINE(wxUSE_TOOLBAR)
+    SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS toolbar"
 fi
 
 if test "$wxUSE_TOOLTIPS" = "yes"; then
     if test "$wxUSE_MOTIF" = 1; then
-      AC_MSG_WARN(Tooltips are not supported yet under Motif)
+        AC_MSG_WARN(Tooltips are not supported yet under Motif)
     else
-      if test "$wxUSE_WINE" = 1; then
-        AC_MSG_WARN(Tooltips are not supported yet under WINE)
-      else
-        AC_DEFINE(wxUSE_TOOLTIPS)
-      fi
+        if test "$wxUSE_WINE" = 1; then
+            AC_MSG_WARN(Tooltips are not supported yet under WINE)
+        else
+            AC_DEFINE(wxUSE_TOOLTIPS)
+        fi
     fi
 fi
 
 if test "$wxUSE_TREECTRL" = "yes"; then
-  if test "$wxUSE_IMAGLIST" = "yes"; then
-    AC_DEFINE(wxUSE_TREECTRL)
-    SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS treectrl"
-  else
-    AC_MSG_WARN([wxTreeCtrl requires wxImageList and won't be compiled without it])
-  fi
+    if test "$wxUSE_IMAGLIST" = "yes"; then
+        AC_DEFINE(wxUSE_TREECTRL)
+        SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS treectrl"
+    else
+        AC_MSG_WARN([wxTreeCtrl requires wxImageList and won't be compiled without it])
+    fi
 fi
 
 dnl ---------------------------------------------------------------------------
@@ -1892,38 +1911,37 @@ dnl   AC_DEFINE(wxUSE_WXTREE)
 dnl fi
 
 if test "$wxUSE_METAFILE" = "yes"; then
-  AC_DEFINE(wxUSE_METAFILE)
+    AC_DEFINE(wxUSE_METAFILE)
 fi
 
-if test "$wxUSE_COMMONDLGS" = "yes"; then
-  dnl these classes don't depend on anything at all
-
-  if test "$wxUSE_CONSTRAINTS" != "yes"; then
-    AC_MSG_WARN(many common dialogs cannot be used without constraints so they won't be compiled without them)
-  else
-    AC_DEFINE(wxUSE_CONSTRAINTS)
-    AC_DEFINE(wxUSE_TEXTDLG)
-
-    if test "$wxUSE_TREECTRL" != "yes"; then
-      AC_MSG_WARN(wxDirDialog cannot be used without wxTreeCtrl and it won't be compiled without it)
+if test "$wxUSE_DIRDLG" = "yes"; then
+    if test "$wxUSE_CONSTRAINTS" != "yes"; then
+       AC_MSG_WARN(wxDirDialog requires constraints so it won't be compiled without them)
     else
-      AC_DEFINE(wxUSE_DIRDLG)
+        if test "$wxUSE_TREECTRL" != "yes"; then
+            AC_MSG_WARN(wxDirDialog requires wxTreeCtrl so it won't be compiled without it)
+        else
+            AC_DEFINE(wxUSE_DIRDLG)
+        fi
     fi
-  fi
+fi
 
-  if test "$wxUSE_PRINTING_ARCHITECTURE" = "no"; then
-    AC_MSG_WARN([wxPrintDialog class won't be compiled without printing support])
-  fi
+if test "$wxUSE_PROGRESSDLG" = "yes"; then
+    if test "$wxUSE_CONSTRAINTS" != "yes"; then
+       AC_MSG_WARN(wxProgressDialog requires constraints so it won't be compiled without them)
+    else
+        AC_DEFINE(wxUSE_PROGRESSDLG)
+    fi
 fi
 
 if test "$wxUSE_MINIFRAME" = "yes"; then
-  AC_DEFINE(wxUSE_MINIFRAME)
-  SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS minifram"
+    AC_DEFINE(wxUSE_MINIFRAME)
+    SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS minifram"
 fi
 
 if test "$wxUSE_VALIDATORS" = "yes"; then
-  AC_DEFINE(wxUSE_VALIDATORS)
-  SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS validate"
+    AC_DEFINE(wxUSE_VALIDATORS)
+    SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS validate"
 fi
 
 dnl ---------------------------------------------------------------------------
@@ -1946,11 +1964,11 @@ INCLUDES="-I. -I\${top_builddir}/include -I\${top_srcdir}/include $ZLIB_INCLUDE
 
 dnl C/C++ compiler options used to compile wxWindows
 if test "$ac_cv_prog_gcc" = "yes"; then
-  dnl CXXWARNINGS="-Wall -W -Wcast-qual -Werror"
-  CXXWARNINGS="-Wall"
-  dnl there is one weird warning in docview.h:71 which prevents me from doing
-  dnl this...
-  dnl CXXWARNINGS="-Wall -Werror"
+    dnl CXXWARNINGS="-Wall -W -Wcast-qual -Werror"
+    CXXWARNINGS="-Wall"
+    dnl there is one weird warning in docview.h:71 which prevents me from doing
+    dnl this...
+    dnl CXXWARNINGS="-Wall -Werror"
 fi
 EXTRA_CFLAGS="$WXDEBUG $PROFILE $OPTIMISE $INCLUDES"
 
@@ -1958,13 +1976,13 @@ CFLAGS="$CFLAGS $EXTRA_CFLAGS"
 CXXFLAGS="$CXXFLAGS $EXTRA_CFLAGS $CXXWARNINGS"
 
 if test "$wxUSE_GUI" = "yes"; then
-  dnl TODO add checks that these samples will really compile (i.e. all the
-  dnl      library features they need are present)
+    dnl TODO add checks that these samples will really compile (i.e. all the
+    dnl      library features they need are present)
 
-  dnl TODO some samples are never built so far:
-  dnl      mfc, nativdlg, oleauto, ownerdrw, proplist
-  SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS bombs controls dialogs drawing dynamic \
-                   forty fractal image richedit wxpoem"
+    dnl TODO some samples are never built so far:
+    dnl      mfc, nativdlg, oleauto, ownerdrw, proplist
+    SAMPLES_SUBDIRS="$SAMPLES_SUBDIRS bombs controls dialogs drawing dynamic \
+                     forty fractal image richedit wxpoem"
 fi
 
 dnl for convenience, sort the files to build in alphabetical order
diff --git a/docs/gtk/changes.txt b/docs/gtk/changes.txt
new file mode 100644
index 0000000000..d9ecabc642
--- /dev/null
+++ b/docs/gtk/changes.txt
@@ -0,0 +1,464 @@
+
+15th June '99: Sixth wxGTK 2.1 snapshot released
+  
+ 
+The biggest change is the completely rewritten configure/makefile
+system using automake. The main argument for switching to automake
+is that the resulting makefiles should be more portable so that
+people can use the native make utilities instead of GNU make. The
+new makefile sytem also handles dependencies correctly, allows for
+shared-only compilation, can be invoked from any directory for
+concurrent builds wihtin one source tree, uses libtool for greater
+shared-library platform support, has a functinonal "make uninstall",
+works with GTK, Motif and WINE, conforms better to GNU standards
+as far as configure option names are concerned and is easier to 
+maintain.
+ 
+Applied patches to compile wxGTK on OS/2.
+ 
+Configure checks for byte-order and new defines for byte swapping
+with respect to the byte-order. Added test for this to typetest sample.
+Also made BMP handler bigendian safe so that it should work on 
+Solaris and such. 
+ 
+Small changes to basic drawing stuff: made wxColour actually compare 
+RGB values in the == operator, added new constructor to wxMask,
+corrected initial background colour for DCs, it is now possible
+to use a wxWindowDC etc before there is any window (this doesn't
+make any sense, but it is what wxMSW does.)
+ 
+Added support for the PRIMARY SELECTION to the wxClipboard
+class.
+ 
+Fixed redraw bug when scrolling window-less widgets out
+of the visible area (actually a work-around for a GTK bug).
+ 
+Regrouped some samples, created new one for various versions
+of the wxTextCtrl.
+ 
+Added wxWindow::Reparent() and wxFrame::MakeModal().
+ 
+Improved handling of column width in wxListCtrl and made
+this more compatible with the wxMSW version. Also removed
+a bug from the wxImageList returning an off-by-one id for
+added images.
+ 
+Fixed keyboard hotkeys and resizing for wxMDIChildFrame
+menu bars.
+ 
+Added flag to wxSplitterWindow to update its children's
+sizes "live" instead of moving a XOR'ed bar around - this
+is a resource-draining option. Also corrected cursors
+in splitter window.
+ 
+New way to show "disabled" or greyed toolbar items.
+ 
+Rewrote parts of the tree ctrl to allow multiple selections
+and variable size items (Sylvain). These new function do not
+exist in the native Win32 tree control.
+ 
+Implemented global cursors and wxBusyCursor etc. Also removed
+another cursor misbehaviour.
+ 
+Updated many parts of the documentation to reflect changes
+in wxWindows 2.1, wxPython and more exact description of
+cross-platform issues as well as platform differences.
+ 
+Many other fixes, mainly by others...
+ 
+Further compile fixes for different architectures.
+ 
+
+  
+25th May '99: Fifth wxGTK 2.1 snapshot released
+  
+
+ 
+This is mostly a bug-fix release. We are having funny
+times to make wxGTK work well with different micro
+versions of GTK 1.2 - which is very close to impossible.
+All versions give warnings, although their number might
+vary a lot. I use GTK 1.2.3 and only get wanrnings in
+one sample (notebook) and that one is due to a bug in
+GTK - some people using GTK 1.2.2 reported hundreds of warnings
+getting spitted out for what seems like no reason.
+ 
+This snapshot contains the beginnings of our merging of
+headers, meaning that in the future all ports will
+use the same headers and will share a lot more code.
+We have taken this moment to reorganize some code and
+hope to have eliminated much bad C++ code, as reported
+primarily by SGI's compilers (Vadim Zeitlin).
+ 
+Rewritten char and key event propagation routines
+to reflect documentation and do the same on wxGTK
+as on wxMSW. If you are interested in ascii chars
+and cursor key etc, intercept EVT_CHAR, if you 
+are interested in which key actually got pressed,
+intercept EVT_KEYDOWN (Norbert Irmer).
+ 
+Control that are given -1 as their ID no longer
+get arbitrary positive IDs assigned but arbitrary
+negative IDs. This had caused some trouble with ID clashes.
+ 
+wxWindow and wxScrolledWindow no longer use the
+wxScrollEvent, but the newly invented wxScrollWinEvent
+so that no mixing up of events sent from wxSliders
+or wxScrollbars placed in a wxWindow can occur.
+ 
+Added wxProgressDialog for use with long background
+work such as printing.
+ 
+Added drawing sample and scrolling sample, both of
+which show some misbehaviours...
+ 
+When drawing with the wxXOR logical mode, wxGTK now uses
+GdkXOR (instead of GdkInvert) and when drawing in wxINVERT logical
+mode, wxGTK now uses GdkInvert (as before). When you did some
+rubberband dragging and you used wxXOR and a black pen, then
+you should change wxINVERT.
+ 
+Applied more patches for SGI and HP-UX compilation.
+ 
+More updates for wxSockets (Guilhem Lavaux). Seems to be nearly
+finished.
+ 
+You can now use threads within your GUI again. Well, 
+at least if you know what you are doing and you had a look 
+at the threads sample.
+ 
+wxGLCanvas updated so that it can share display lists
+over several windows and to not exhibit any flicker. 
+(Norber Irmer).
+ 
+wxNotebook revamped so that its process of creation matches
+wxMSW's more closely, also avoiding problems with wrong page
+number. Added InsertPage() and the possibility to prevent
+switching pages by intercepting the PAGE_CHANGING event. Also,
+wxNotebooks now get shown even if all pages are empty.
+ 
+Added Activate() to wxMDIChildFrame (Russel).
+ 
+Improved wxSplitterWindow behaviour and visual feed-back when
+given a minimal size etc (Bruce DeVisser).
+ 
+Minor updates to wxTreeCtrl, wxListBox, printing, wxClipboard,
+wxString, wxThreads and many others.
+ 
+Also wxMSW got a big face-lift, not to mention the new wxMac release...
+ 
+			
+  
+11th May '99: Fourth wxGTK 2.1 snapshot released
+  
+ 
+This is mostly a bug-fix release. This affects wxSocket, wxThread,
+and a few GUI classes. Also more work has been done and window
+placement and decorations etc. which we hope to have finished now.
+ 
+Applied patches for FreeBSD and SGI compilation (not yet finshed).
+ 
+Updated wxPython to beta 9.
+ 
+Made wxGLCanvas work again - strangely it flickers now...
+ 
+wxStaticText is currently broken with GTK 1.2.2 (which I don't
+yet have and thus could not fix). Also, scrolling subwindows
+(although much improved including a sample) doesn't work perfectly
+due to a bug in GTK 1.2.1 (probably 1.2.2 as well).
+ 
+Added wxStaticLine.
+  
+Note that the next release might bring about changes to keyboard
+handling and scroll event intercepting from wxScrolledWindow. 
+ 
+By and large much of the code has stabilized and won't be much
+different in the final wxWindows 2.1 release. Please test as
+much as you can.
+ 
+The next release will have a new build system.
+ 
+
+  
+3rd May '99: Third wxGTK 2.1 snapshot released
+  
+ 
+Updated INSTALL.txt and SYMBOLS.txt.
+ 
+Support for Unicode is now almost complete. Most samples work in
+both Unicode and non-Unicode mode. Thanks to Ove Kaaven and Vadim.
+ 
+Internal changes required for wxOLE and addition of a very experimental
+wxOLE code section using GNOME's Bonobo library (from GNOME's CVS).
+ 
+New version of wxPython that works with the wxGTK 2.1.
+This now includes a very comprensive test/demo suite. Thanks to
+Robin Dunn, Harm v.d. Heijden and others. Beware of the hang-man...
+ 
+More fine tuning of focus handling and GUI widgets.
+ 
+Complete rewrite of wxSocket classes (still experimental).
+Thanks to Guilhem Lavaux.
+  
+wxMenuBar supports underlined shortcuts like Windows does,
+indicated by a leading & character. wxMenus now have hotkeys
+such as in wxXt and wxMSW.
+  
+Rewritten MDI subsystem.
+  
+Correcetions and additions to the printing framework including
+a paper type database (Julian).
+ 
+Several controls now support more style flags for modifying
+look (and feel) of the controls and windows.
+ 
+New implementation of idle handlers, which now send an idle
+event only once after the event queue has been emptied (which
+is what happens in the wxMSW port as well), not regularly.
+This no longer forces wxGTK applications to sleep (by having
+to call usleep()) in idle time - giving more CPU slices to
+the application if desired.
+ 
+wxGLCanvas (the OpenGl for wxWindows) now accepts keyboard input.
+ 
+The usual number of compile and bug fixes from all involved.
+ 
+
+  
+21st April '99: Second wxGTK 2.1 snapshot released
+  
+ 
+Added much code for Unicode support. Still experimental, but looks very
+cool - thanks to Ove Kaaven and Vadim Zeitlin. If you are very brave, then
+you can compile wxGTK with "configure --with-unicode".
+ 
+More updates on the dreaded issue of making frames and dialogs impossible
+to resize etc.
+ 
+Drag and Drop works now under GTK 1.2 - at least basically when dragging
+and dropping text. The API is not entirely fixed yet but seems quite
+good now. Support for different actions (copy/move/link/..) still missing.
+I also removed support for GTK 1.0 Drag and Drop - this is just broken
+and unusable in GTK 1.0 and I don't want to fix it.
+ 
+I now embed the JPEG library and handlers for JPEG and GIF have been
+added to the existing PNG and BMP (and XPM for GTK version only). In
+the future, the RPMs will not contain these libraries but depend on
+the image libraries to be preinstalled whereas the source *.tgz will
+ship with everything that is needed for wxGTK so that no downloading
+of ten image libs will be required - also avoiding problems with ten
+different kinds of libJPEG-6.0.1.7.IV beta 7. We also updated the
+PNG code to the newest PNG version.
+ 
+wxImage now makes use of the fast rendering code as provided by
+GTK 1.2 whenever possible. This should mean a speed-up for graphics
+heavy apps.
+ 
+Many fixes all over. Also should compile with GTK 1.2.0 as opposed
+to only with GTK 1.2.1 now.
+ 
+wxPython still doesn't compile, I think.
+ 
+
+  
+12th April '99: First wxGTK 2.1 snapshot released
+  
+ 
+This is the first developers' version of wxWindows 2.1 for GTK. It's main
+new feature is that it supports GTK 1.2 (as opposed to GTK 1.0) which
+will make development within the GNOME evironment a lot easier.
+ 
+Apart from the move to GTK 1.2 and the changes (some major) that were
+required as part of that work, enhancement or corrections have been
+made to many of the non-GUI classes and functions (such as wxClipboard, 
+wxThread, wxSocket, wxConfig)
+and a few GUI classes (accelerators in menus, listbox always with
+scrollbar, wxFrame honours Motif Window Manager hints, corrected tab
+traversal for broken GTK 1.0 widgets).
+ 
+There have been slight changes to the priting dialogs and their
+setup data (which might break apps using this code in previous
+versions). Also, a bug concerning printing white has been fixed
+(actually not tested).
+ 
+Although this is only the first 2.1 snapshot, there is little reason not
+to use it as many bugs from version 2.0 have been corrected. There are,
+pf course, still a few problem left with GTK 1.2 (some of which relate
+to bugs in GTK).
+ 
+I think I preserved backward compatility with GTK 1.0 and if not it
+should be easy to fix - but mostly I don't care.
+ 
+Drag'N'Drop is currently completely broken. Also, wxPython currently
+doesn't compile with this release. The OpenGL canvas still seems to
+work.
+ 
+Major targets for the final release (still a long way): a new configure
+system, support JPEG and GIF formats, wxHTML, super-duppah frame layout
+stuff, syntax-highlighting editor, possibly Unicode, possibly some GNOME 
+gooddies, possibly world domination.
+ 
+
+  
+5th March '99: wxWindows 2.0 released
+  
+ 
+This is the final version of wxWindows 2.0 for GTK. The versions for
+Windows and Motif (and also this version) are available form Julian Smart's
+site. The Mac version is still under development.
+ 
+
+  
+19th February '99: wxWindows 2.0 beta 5
+  
+ 
+This is the fifth beta release and it contains mostly bug fixes and
+updates for documentation.
+ 
+Applied compile fixes for Solaris (different flavours and compilers).
+ 
+
+  
+12th February '99: wxWindows 2.0 beta 4
+  
+ 
+This is the fourth beta release and it contains mostly bug fixes and
+updates for documentation.
+ 
+Tracked a few more cases, where the bahaviour between wxMSW and wxGTK
+differed. This was the case for closing a dialog or frame as well as
+for clearing a device context or setting its background colour and some
+other minor details.
+ 
+Most standard dialogs have been face-liftet a little.
+ 
+Implememted default buttons for GTK.
+ 
+Fixed many bugs. You guessed it.
+ 
+
+  
+29th January '99: wxWindows 2.0 beta 3
+  
+ 
+This is the third beta release and it contains mostly bug fixes. 
+ 
+There is one field where we haven't been able to fix the API yet, and that
+it Drag'n'Drop. This is mostly due to the fact that DnD in
+GTK 1.0 is hardly usable and much different from GTK 1.2 which means that
+we have to design a common API for Windows, GTK 1.0 and GTK 1.2. Although
+we are trying to prevent that, it is possible that wxWindows 2.0 (being
+based on GTK 1.0) will not have proper DnD support.
+ 
+The major changes are that tool tips have been added, threads have been completely 
+rewritten, the ODBC code has been updated and improved, the socket code works 
+better now.
+ 
+Classes for managing MIME-types under Windows and Unix have been added.
+ 
+There is now a wxGLCanvas class for OpenGl/Mesa for the Windows, GTK and
+Motif ports. Come see the penguins flying...
+ 
+Documentation has received a big face lift - it now covers nearly all the
+classes, at least.
+ 
+The usual amount of bug fixes. Countless.
+ 
+A few member functions of wxString have been renamed.
+ 
+For those who are using the ever-so-popular wxImage class (which
+now available on Motif and Windows as well) in 8-bit mode: wxGTK
+now creates a color cube upon start-up in 8-bit mode and thus the
+generation of bitmaps from images has been speeded up 20 times.
+ 
+It is now possible to develop with wxGTK without having the GTK 1.0 header
+files installed so that having the GTK 1.2 header files installed no longer
+is any problem. We also provide RPMs for RedHat glibc 2 based systems, compiled
+with egcs 1.1.1 on SuSE 6.0. Note that the RPM will   not   work in
+SuSE 6.0 as SuSE decided to ship 6.0 with a broken GTK+ package.
+ 
+
+  
+6th January '99: wxWindows 2.0 beta 2
+  
+ 
+This is the second beta release and contains it mostly build and
+bug fixes. Threads work well now on (up-to-date) glibc 2 systems,
+commercial Unices and Windows.
+ 
+			
+  
+20th December '98: wxWindows 2.0 beta 1
+  
+ 
+This is the first beta release and we have used the time before
+this release to tidy up some parts of the API. All releases from
+now on will be source code compatible but we reserve binary compatibility
+for the final release. Because of this, the actual library name of
+the beta version will not be 2.0 but 1.99, so that we prevent 
+conflicts with the final library later on. After the final release
+we'll only fix bugs so that there will be no reason to link any
+program statically with wxGTK.
+ 
+We changed the name of the shared library to include the version of
+the GTK used so that no conflicts emerge with simultaneous
+versions of wxWindows for GTK 1.0 and for GTK 1.2 and so on.
+ 
+As you can see, we have not moved to GTK 1.1.X as the different
+development versions are too different and buggy to be useful. We'll
+wait for a stable GTK 1.2 release (hardly 1.2.0) and start porting
+then.
+ 
+wxGTK now compiles without problems on anything between gcc 2.7.2 on
+Linux-x86 and egcs 1.1 on Linux-Alpha and egcs 1.0 on Sparc. This isn't
+as easy as it sounds...
+ 
+Available form this site are the Python bindings of wxWindows.
+Thanks to Robin Dunn for this tremendous contribution.
+Tkinter is dead, Java is dead, wxPython rules! That's all there is to say.
+ 
+Although only a few new classes have been added, many have been polished
+up substantially, the most visible are wxListCtrl, wxTreeCtrl and
+all classes related to printing. Also the DialogEd now functions
+much better than before. Drag'n'Drop is fucntional but probably won't 
+be perfect until we use GTK 1.2 and its much improved DnD features.
+ 
+wxClipboard has arrived and works for text. Other formats have not been
+tested carefully yet.
+ 
+wxMiniFrame has been added which might be useful for docking toolbars
+etc. Someone has already done that for the MSW port and we hope to
+include his very nice work later.
+ 
+wxDirDialog has been added (thanks to Harm von der Heijden).
+ 
+The entite "tab traveral" system for moving from item to item in
+a dialog has been rewritten. It now completely overrides the
+not-so-well-done GTK native tab system.
+ 
+Quite much has been done to improve the wxImage class, which is now
+available in the Windows port as well. Very useful for anything related
+to image processing. wxGTK also uses this class internally e.g. to scale
+bitmaps when the scale factor (e.g. zooming) of a drawing context
+has changed.
+  
+Some of the small and handy classes (wxDate, wxTime, wxVariant) have
+received a face-lift. wxList has been rewritten to make it possible
+to write type-safe lists. The collection of utility functions (wxFileFind etc)
+has been revamped and cleaned-up (thanks to Vadim Zeitlin, who has also
+greatly enhanced many basic classes, ranging wxString to the debug and
+log system).
+ 
+We removed some constructors of GDI classes (such as wxPen, wxColour)
+which took a pointer as a parameter. This lead to many errors among users
+resulting in unexpected behaviour so it was decided to remove these
+constructors.
+ 
+As the number of users and the number of test programs and samples
+is steadialy rising the core classes of wxWindows for MSW and GTK 1.0
+can be considered to be very stable if not outright bug-free. I haven't
+seen a crash for weeks now and wxWindows' internal debug features also
+have improved every week, making stepping-through with a debugger almost
+completely unnecessary as the library reports possible errors itself
+(when in debug mode).
+
diff --git a/include/wx/datstrm.h b/include/wx/datstrm.h
index 82e7b8daa9..e3bb7eeb80 100644
--- a/include/wx/datstrm.h
+++ b/include/wx/datstrm.h
@@ -18,6 +18,8 @@
 
 #include <wx/stream.h>
 
+#if wxUSE_STREAMS
+
 class WXDLLEXPORT wxDataInputStream: public wxFilterInputStream {
 public:
   wxDataInputStream(wxInputStream& s);
@@ -44,5 +46,8 @@ class WXDLLEXPORT wxDataOutputStream: public wxFilterOutputStream {
   void WriteString(const wxString& string);
 };
 
+#endif
+  // wxUSE_STREAMS
+
 #endif
     // _WX_DATSTREAM_H_
diff --git a/include/wx/file.h b/include/wx/file.h
index 038b578e33..73deef73cb 100644
--- a/include/wx/file.h
+++ b/include/wx/file.h
@@ -22,6 +22,8 @@
   #include  "wx/filefn.h"
 #endif
 
+#if wxUSE_FILE
+
 // ----------------------------------------------------------------------------
 // constants
 // ----------------------------------------------------------------------------
@@ -178,5 +180,7 @@ private:
   wxFile    m_file;     // the temporary file
 };
 
+#endif
+
 #endif
         // _WX_FILEH__
diff --git a/include/wx/fileconf.h b/include/wx/fileconf.h
index d5e34274d4..f6c4718919 100644
--- a/include/wx/fileconf.h
+++ b/include/wx/fileconf.h
@@ -18,17 +18,11 @@
 #endif
 
 #include "wx/defs.h"
-#include "wx/textfile.h"
-#include "wx/string.h"
 
-// ----------------------------------------------------------------------------
-// compile options
-// ----------------------------------------------------------------------------
+#if wxUSE_CONFIG
 
-// it won't compile without it anyhow
-#ifndef wxUSE_CONFIG
-  #error "Please define wxUSE_CONFIG or remove fileconf.cpp from your makefile"
-#endif // wxUSE_CONFIG
+#include "wx/textfile.h"
+#include "wx/string.h"
 
 // ----------------------------------------------------------------------------
 // wxFileConfig
@@ -349,5 +343,9 @@ public:
   void SetLastGroup(ConfigGroup *pGroup) { m_pLastGroup = pGroup; }
 };
 
-#endif  //_FILECONF_H
+#endif
+  // wxUSE_CONFIG
+
+#endif  
+  //_FILECONF_H
 
diff --git a/include/wx/generic/dcpsg.h b/include/wx/generic/dcpsg.h
index 5be42ac46b..a328f502a5 100644
--- a/include/wx/generic/dcpsg.h
+++ b/include/wx/generic/dcpsg.h
@@ -17,6 +17,8 @@
 
 #include "wx/dc.h"
 
+#if wxUSE_PRINTING_ARCHITECTURE
+
 #if wxUSE_POSTSCRIPT
 
 #include "wx/dialog.h"
@@ -275,6 +277,9 @@ WXDLLEXPORT extern void wxInitializePrintSetupData(bool init = TRUE);
 
 #endif
     // wxUSE_POSTSCRIPT
+    
+#endif
+    // wxUSE_PRINTING_ARCHITECTURE
 
 #endif
         // _WX_DCPSG_H_
diff --git a/include/wx/generic/dirdlgg.h b/include/wx/generic/dirdlgg.h
index 052d8ff6f8..675bf147b1 100644
--- a/include/wx/generic/dirdlgg.h
+++ b/include/wx/generic/dirdlgg.h
@@ -54,8 +54,12 @@
 #pragma interface "dirdlgg.h"
 #endif
 
+#include "wx/defs.h"
+
+#if wxUSE_DIRDLG
+
 #include "wx/dialog.h"
-//#include "wx/checkbox.h"
+#include "wx/checkbox.h"
 #include "wx/treectrl.h"
 
 //-----------------------------------------------------------------------------
@@ -116,6 +120,8 @@ class WXDLLEXPORT wxDirDialog: public wxDialog
     void doSize();
 };
 
+#endif
+
 #endif
     // _WX_DIRDLGG_H_
 
diff --git a/include/wx/generic/printps.h b/include/wx/generic/printps.h
index f02bd11d10..5934eaf40a 100644
--- a/include/wx/generic/printps.h
+++ b/include/wx/generic/printps.h
@@ -19,6 +19,8 @@
 
 #include "wx/prntbase.h"
 
+#if wxUSE_PRINTING_ARCHITECTURE
+
 // ----------------------------------------------------------------------------
 // Represents the printer: manages printing a wxPrintout object
 // ----------------------------------------------------------------------------
@@ -62,5 +64,7 @@ private:
     void Init(wxPrintout *printout, wxPrintout *printoutForPrinting);
 };
 
+#endif
+
 #endif
 // __PRINTPSH__
diff --git a/include/wx/generic/prntdlgg.h b/include/wx/generic/prntdlgg.h
index 258d2afe20..da5f97f15c 100644
--- a/include/wx/generic/prntdlgg.h
+++ b/include/wx/generic/prntdlgg.h
@@ -18,6 +18,9 @@
 #endif
 
 #include "wx/defs.h"
+
+#if wxUSE_PRINTING_ARCHITECTURE
+
 #include "wx/dialog.h"
 #include "wx/dialog.h"
 
@@ -187,5 +190,7 @@ private:
     DECLARE_EVENT_TABLE()
 };
 
+#endif
+
 #endif
 // __PRINTDLGH_G__
diff --git a/include/wx/generic/progdlgg.h b/include/wx/generic/progdlgg.h
index 6958ed035d..8d8c7e544b 100644
--- a/include/wx/generic/progdlgg.h
+++ b/include/wx/generic/progdlgg.h
@@ -17,9 +17,10 @@
 #endif
 
 #include "wx/setup.h"
-#include "wx/frame.h"
 
+#if wxUSE_PROGRESSDLG
 
+#include "wx/frame.h"
 
 /** Progress dialog which shows a moving progress bar.
     Taken from the Mahogany project.*/
@@ -88,5 +89,7 @@ private:
 
    DECLARE_EVENT_TABLE()
 };
+#endif
+
 #endif
     // __PROGDLGH_G__
diff --git a/include/wx/gtk/choice.h b/include/wx/gtk/choice.h
index da0b83c288..796d625f4b 100644
--- a/include/wx/gtk/choice.h
+++ b/include/wx/gtk/choice.h
@@ -15,6 +15,9 @@
 #endif
 
 #include "wx/defs.h"
+
+#if wxUSE_CHOICE
+
 #include "wx/object.h"
 #include "wx/list.h"
 #include "wx/control.h"
@@ -96,4 +99,6 @@ public:
     void ApplyWidgetStyle();
 };
 
+#endif
+
 #endif // __GTKCHOICEH__
diff --git a/include/wx/gtk1/choice.h b/include/wx/gtk1/choice.h
index da0b83c288..796d625f4b 100644
--- a/include/wx/gtk1/choice.h
+++ b/include/wx/gtk1/choice.h
@@ -15,6 +15,9 @@
 #endif
 
 #include "wx/defs.h"
+
+#if wxUSE_CHOICE
+
 #include "wx/object.h"
 #include "wx/list.h"
 #include "wx/control.h"
@@ -96,4 +99,6 @@ public:
     void ApplyWidgetStyle();
 };
 
+#endif
+
 #endif // __GTKCHOICEH__
diff --git a/include/wx/image.h b/include/wx/image.h
index 21d0f14710..2a1c3ad5b0 100644
--- a/include/wx/image.h
+++ b/include/wx/image.h
@@ -95,7 +95,6 @@ public:
   virtual bool LoadFile( wxImage *image, wxInputStream& stream );
   virtual bool SaveFile( wxImage *image, wxOutputStream& stream );
 #endif
-
 };
 #endif
 
@@ -118,8 +117,10 @@ public:
       m_mime = "image/jpeg";
   };
 
+#if wxUSE_STREAMS
   virtual bool LoadFile( wxImage *image, wxInputStream& stream );
   virtual bool SaveFile( wxImage *image, wxOutputStream& stream );
+#endif
 };
 #endif
 
@@ -150,9 +151,25 @@ public:
 // wxGIFHandler
 //-----------------------------------------------------------------------------
 
-/* why an extra headers for GIF, RR */
+class WXDLLEXPORT wxGIFHandler : public wxImageHandler
+{
+  DECLARE_DYNAMIC_CLASS(wxGIFHandler)
+
+public:
+
+  inline wxGIFHandler()
+  {
+      m_name = "GIF file";
+      m_extension = "gif";
+      m_type = wxBITMAP_TYPE_GIF;
+      m_mime = "image/gif";
+  };
 
-#include "wx/imaggif.h"
+#if wxUSE_STREAMS
+  virtual bool LoadFile( wxImage *image, wxInputStream& stream );
+  virtual bool SaveFile( wxImage *image, wxOutputStream& stream );
+#endif
+};
 
 //-----------------------------------------------------------------------------
 // wxImage
diff --git a/include/wx/imaggif.h b/include/wx/imaggif.h
deleted file mode 100644
index 909a69c17a..0000000000
--- a/include/wx/imaggif.h
+++ /dev/null
@@ -1,46 +0,0 @@
-/////////////////////////////////////////////////////////////////////////////
-// Name:        imaggif.h
-// Purpose:     wxImage handler for GIFs (read-only)
-// Author:      Vaclav Slavik (of this header only)
-// Licence:     wxWindows licence
-/////////////////////////////////////////////////////////////////////////////
-
-#ifndef _WX_IMAGGIF_H_
-#define _WX_IMAGGIF_H_
-
-#ifdef __GNUG__
-#pragma interface "imaggif.h"
-#endif
-
-#include <wx/setup.h>
-#include <wx/object.h>
-#include <wx/string.h>
-#include <wx/gdicmn.h>
-#include <wx/stream.h>
-#include <wx/image.h>
-
-//-----------------------------------------------------------------------------
-// wxGIFHandler
-//-----------------------------------------------------------------------------
-
-class WXDLLEXPORT wxGIFHandler : public wxImageHandler
-{
-  DECLARE_DYNAMIC_CLASS(wxGIFHandler)
-
-public:
-
-  inline wxGIFHandler()
-  {
-      m_name = "GIF file";
-      m_extension = "gif";
-      m_type = wxBITMAP_TYPE_GIF;
-      m_mime = "image/gif";
-  };
-
-  virtual bool LoadFile( wxImage *image, wxInputStream& stream );
-  virtual bool SaveFile( wxImage *image, wxOutputStream& stream );
-};
-
-#endif
-    // _WX_IMAGGIF_H_
-
diff --git a/include/wx/mimetype.h b/include/wx/mimetype.h
index d30eb3c70d..4f34fa8dcb 100644
--- a/include/wx/mimetype.h
+++ b/include/wx/mimetype.h
@@ -9,14 +9,18 @@
 // Licence:     wxWindows license (part of wxExtra library)
 /////////////////////////////////////////////////////////////////////////////
 
-#ifndef   _MIMETYPE_H
-#define   _MIMETYPE_H
+#ifndef _MIMETYPE_H
+#define _MIMETYPE_H
 
 // fwd decls
 class wxIcon;
 class wxFileTypeImpl;
 class wxMimeTypesManagerImpl;
 
+#include "wx/defs.h"
+
+#if wxUSE_FILE
+
 // the things we really need
 #include "wx/string.h"
 
@@ -155,6 +159,10 @@ private:
     wxMimeTypesManagerImpl *m_impl;
 };
 
-#endif  //_MIMETYPE_H
+#endif
+  // wxUSE_FILE
+
+#endif  
+  //_MIMETYPE_H
 
 /* vi: set cin tw=80 ts=4 sw=4: */
diff --git a/include/wx/mstream.h b/include/wx/mstream.h
index 3bd53e642d..1c3283e779 100644
--- a/include/wx/mstream.h
+++ b/include/wx/mstream.h
@@ -13,6 +13,8 @@
 
 #include <wx/stream.h>
 
+#if wxUSE_STREAMS
+
 class wxMemoryInputStream: public wxInputStream {
  private:
   size_t m_length;
@@ -32,3 +34,7 @@ class wxMemoryOutputStream:  public wxOutputStream {
 };
 
 #endif
+  // wxUSE_STREAMS
+
+#endif
+  // _WX_WXMMSTREAM_H__
\ No newline at end of file
diff --git a/include/wx/msw/setup0.h b/include/wx/msw/setup0.h
index 173518be10..969e9ca934 100644
--- a/include/wx/msw/setup0.h
+++ b/include/wx/msw/setup0.h
@@ -66,6 +66,9 @@
 #define wxUSE_COMBOBOX      1
                                     // Define 1 to use COMBOXBOX control (Windows)
                                     // or FWW's ComboBox widget (Motif).
+#define wxUSE_CHOICE      1
+                                    // Define 1 to use CHOICE
+
 #define wxUSE_RADIOBUTTON   1
                                     // Define 1 to use radio button control
 
@@ -181,6 +184,8 @@
 #define wxUSE_TEXTDLG 1
 #define wxUSE_TOOLBAR 1
 #define wxUSE_STATUSBAR 1
+#define wxUSE_PROGRESSDLG 1
+#define wxUSE_DIRDLG 1
 
 /*
  * Finer detail
diff --git a/include/wx/objstrm.h b/include/wx/objstrm.h
index 699492671c..f077528e12 100644
--- a/include/wx/objstrm.h
+++ b/include/wx/objstrm.h
@@ -16,6 +16,9 @@
 #endif
 
 #include "wx/defs.h"
+
+#if wxUSE_STREAMS && wxUSE_SERIAL
+
 #include "wx/object.h"
 #include "wx/string.h"
 #include "wx/stream.h"
@@ -81,3 +84,7 @@ class wxObjectInputStream : public wxFilterInputStream {
 };
 
 #endif
+  // wxUSE_STREAMS && wxUSE_SERIAL
+
+#endif
+  // _WX_WXOBJSTRM_H__
\ No newline at end of file
diff --git a/include/wx/sckstrm.h b/include/wx/sckstrm.h
index 57484b17fc..e22c65baf4 100644
--- a/include/wx/sckstrm.h
+++ b/include/wx/sckstrm.h
@@ -16,6 +16,9 @@
 #endif
 
 #include "wx/stream.h"
+
+#if wxUSE_SOCKETS && wxUSE_STREAMS
+
 #include "wx/socket.h"
 
 class WXDLLEXPORT wxSocketOutputStream : public wxOutputStream
@@ -63,3 +66,7 @@ class WXDLLEXPORT wxSocketStream : public wxSocketInputStream,
 };
 
 #endif
+  // wxUSE_SOCKETS && wxUSE_STREAMS
+
+#endif
+  // __SCK_STREAM_H__
\ No newline at end of file
diff --git a/include/wx/socket.h b/include/wx/socket.h
index ef410dbc30..aa5d6ca9b4 100644
--- a/include/wx/socket.h
+++ b/include/wx/socket.h
@@ -16,6 +16,10 @@
 #pragma interface "socket.h"
 #endif
 
+#include "wx/defs.h"
+
+#if wxUSE_SOCKETS
+
 // ---------------------------------------------------------------------------
 // Windows(tm) specific
 // ---------------------------------------------------------------------------
@@ -278,3 +282,7 @@ typedef void (wxEvtHandler::*wxSocketEventFunction)(wxSocketEvent&);
   (wxObject *) NULL  },
 
 #endif
+  // wxUSE_SOCKETS
+
+#endif
+  // _WX_NETWORK_SOCKET_H
diff --git a/include/wx/stream.h b/include/wx/stream.h
index c9d0bb7b84..0872a9ba81 100644
--- a/include/wx/stream.h
+++ b/include/wx/stream.h
@@ -16,6 +16,10 @@
 #pragma interface
 #endif
 
+#include "wx/defs.h"
+
+#if wxUSE_STREAMS
+
 #include <stdio.h>
 #include "wx/object.h"
 #include "wx/string.h"
@@ -259,3 +263,7 @@ class WXDLLEXPORT wxFilterOutputStream: public wxOutputStream {
 };
 
 #endif
+  // wxUSE_STREAMS
+
+#endif
+  // _WX_WXSTREAM_H__
diff --git a/include/wx/textfile.h b/include/wx/textfile.h
index b6132bd178..fafaae9ab1 100644
--- a/include/wx/textfile.h
+++ b/include/wx/textfile.h
@@ -11,14 +11,17 @@
 // Licence:     wxWindows license
 ///////////////////////////////////////////////////////////////////////////////
 
-#ifndef   _TEXTFILE_H
-#define   _TEXTFILE_H
+#ifndef _TEXTFILE_H
+#define _TEXTFILE_H
 
 #ifdef __GNUG__
 #pragma interface "textfile.h"
 #endif
 
 #include "wx/defs.h"
+
+#if wxUSE_TEXTFILE && wxUSE_FILE
+
 #include "wx/string.h"
 #include "wx/file.h"
 #include "wx/dynarray.h"
@@ -137,4 +140,9 @@ private:
   wxString      m_strFile;  // name of the file
 };
 
-#endif  //_TEXTFILE_H
+#endif
+  // wxUSE_TEXTFILE && wxUSE_FILE
+
+#endif  
+  // _TEXTFILE_H
+  
diff --git a/include/wx/valgen.h b/include/wx/valgen.h
index 8fa29d6642..1dbcdb62ec 100644
--- a/include/wx/valgen.h
+++ b/include/wx/valgen.h
@@ -18,6 +18,8 @@
 
 #include "wx/validate.h"
 
+#if wxUSE_VALIDATORS
+
 class WXDLLEXPORT wxGenericValidator: public wxValidator
 {
 public:
@@ -55,4 +57,8 @@ protected:
   wxArrayInt* m_pArrayInt;
 };
 
-#endif    // _WX_VALGENH__
+#endif
+  // wxUSE_VALIDATORS
+
+#endif    
+  // _WX_VALGENH__
diff --git a/include/wx/valtext.h b/include/wx/valtext.h
index 391ed8dfb2..942110e65b 100644
--- a/include/wx/valtext.h
+++ b/include/wx/valtext.h
@@ -16,9 +16,9 @@
 #pragma interface "valtext.h"
 #endif
 
-#if defined(wxUSE_VALIDATORS) && !wxUSE_VALIDATORS
-    #error "wxWindows is compiled without support for wxValidator"
-#endif
+#include "wx/defs.h"
+
+#if wxUSE_VALIDATORS
 
 #include "wx/validate.h"
 
@@ -79,3 +79,7 @@ protected:
 };
 
 #endif
+  // wxUSE_VALIDATORS
+
+#endif
+  // _WX_VALTEXTH__
diff --git a/include/wx/wfstream.h b/include/wx/wfstream.h
index b0f4dbb02a..6a43702ad8 100644
--- a/include/wx/wfstream.h
+++ b/include/wx/wfstream.h
@@ -16,6 +16,10 @@
 #pragma interface "wfstream.h"
 #endif
 
+#include "defs.h"
+
+#if wxUSE_STREAMS && wxUSE_FILE
+
 #include <wx/object.h>
 #include <wx/string.h>
 #include <wx/stream.h>
@@ -79,3 +83,7 @@ class wxFileStream: public wxFileInputStream, public wxFileOutputStream {
 };
 
 #endif
+  // wxUSE_STREAMS && wxUSE_FILE
+
+#endif
+  // _WX_WXFSTREAM_H__
\ No newline at end of file
diff --git a/include/wx/zstream.h b/include/wx/zstream.h
index 9a4f11c6ad..40396a1251 100644
--- a/include/wx/zstream.h
+++ b/include/wx/zstream.h
@@ -17,7 +17,7 @@
 
 #include "wx/defs.h"
 
-#if wxUSE_ZLIB
+#if wxUSE_ZLIB && wxUSE_STREAMS
 
 #include <wx/stream.h>
 
@@ -52,5 +52,7 @@ class WXDLLEXPORT wxZlibOutputStream: public wxFilterOutputStream {
 };
 
 #endif
+  // wxUSE_ZLIB && wxUSE_STREAMS
 
 #endif
+   // _WX_WXZSTREAM_H__
\ No newline at end of file
diff --git a/src/common/config.cpp b/src/common/config.cpp
index 401d25f236..c0b5c85700 100644
--- a/src/common/config.cpp
+++ b/src/common/config.cpp
@@ -19,21 +19,24 @@
 
 #include "wx/wxprec.h"
 
-#ifndef WX_PRECOMP
-    #include  "wx/wx.h"
-#endif
-
-#if wxUSE_CONFIG
-
 #ifdef    __BORLANDC__
   #pragma hdrstop
 #endif  //__BORLANDC__
 
+#ifndef WX_PRECOMP
+  #include "wx/defs.h"
+#endif
+
+#if wxUSE_CONFIG && ((wxUSE_FILE && wxUSE_TEXTFILE) || defined(wxCONFIG_WIN32_NATIVE))
+
 #include "wx/app.h"
 #include "wx/file.h"
 #include "wx/log.h"
 #include "wx/textfile.h"
 #include "wx/utils.h"
+#include "wx/log.h"
+#include "wx/utils.h"
+#include "wx/intl.h"
 
 #include "wx/config.h"
 
diff --git a/src/common/date.cpp b/src/common/date.cpp
index ec7f8d549f..db287ab316 100644
--- a/src/common/date.cpp
+++ b/src/common/date.cpp
@@ -23,10 +23,12 @@
 #include "wx/wxprec.h"
 
 #ifdef __BORLANDC__
-#pragma hdrstop
+  #pragma hdrstop
 #endif
 
-#include "wx/setup.h"
+#ifndef WX_PRECOMP
+  #include "wx/defs.h"
+#endif
 
 #if wxUSE_TIMEDATE
 
diff --git a/src/common/datstrm.cpp b/src/common/datstrm.cpp
index bdf796f7c2..aff9c5355c 100644
--- a/src/common/datstrm.cpp
+++ b/src/common/datstrm.cpp
@@ -17,13 +17,15 @@
 #include "wx/wxprec.h"
 
 #ifdef __BORLANDC__
-#pragma hdrstop
+  #pragma hdrstop
 #endif
 
 #ifndef WX_PRECOMP
-#include "wx/defs.h"
+  #include "wx/defs.h"
 #endif
 
+#if wxUSE_STREAMS
+
 #include "wx/datstrm.h"
 
 // ---------------------------------------------------------------------------
@@ -200,3 +202,7 @@ void wxDataOutputStream::WriteDouble(double d)
 #endif
   Write(buf, 10);
 }
+
+#endif
+  // wxUSE_STREAMS
+  
\ No newline at end of file
diff --git a/src/common/docview.cpp b/src/common/docview.cpp
index ece6ec34a4..a7fd1a2209 100644
--- a/src/common/docview.cpp
+++ b/src/common/docview.cpp
@@ -50,11 +50,14 @@
     #include "wx/mdi.h"
 #endif
 
+#if wxUSE_PRINTING_ARCHITECTURE
+  #include "wx/prntbase.h"
+  #include "wx/printdlg.h"
+#endif
+
 #include "wx/msgdlg.h"
 #include "wx/choicdlg.h"
 #include "wx/docview.h"
-#include "wx/prntbase.h"
-#include "wx/printdlg.h"
 #include "wx/confbase.h"
 
 #include <stdio.h>
@@ -668,9 +671,11 @@ BEGIN_EVENT_TABLE(wxDocManager, wxEvtHandler)
     EVT_MENU(wxID_SAVEAS, wxDocManager::OnFileSaveAs)
     EVT_MENU(wxID_UNDO, wxDocManager::OnUndo)
     EVT_MENU(wxID_REDO, wxDocManager::OnRedo)
+#if wxUSE_PRINTING_ARCHITECTURE
     EVT_MENU(wxID_PRINT, wxDocManager::OnPrint)
     EVT_MENU(wxID_PRINT_SETUP, wxDocManager::OnPrintSetup)
     EVT_MENU(wxID_PREVIEW, wxDocManager::OnPreview)
+#endif
 END_EVENT_TABLE()
 
 wxDocManager::wxDocManager(long flags, bool initialize)
@@ -804,6 +809,7 @@ void wxDocManager::OnPrint(wxCommandEvent& WXUNUSED(event))
 
 void wxDocManager::OnPrintSetup(wxCommandEvent& WXUNUSED(event))
 {
+#if wxUSE_PRINTING_ARCHITECTURE
     wxWindow *parentWin = wxTheApp->GetTopWindow();
     wxView *view = GetCurrentView();
     if (view)
@@ -814,6 +820,7 @@ void wxDocManager::OnPrintSetup(wxCommandEvent& WXUNUSED(event))
     wxPrintDialog printerDialog(parentWin, & data);
     printerDialog.GetPrintDialogData().SetSetupDialog(TRUE);
     printerDialog.ShowModal();
+#endif // wxUSE_PRINTING_ARCHITECTURE
 }
 
 void wxDocManager::OnPreview(wxCommandEvent& WXUNUSED(event))
diff --git a/src/common/event.cpp b/src/common/event.cpp
index 593d1fc131..b7cb5cafaf 100644
--- a/src/common/event.cpp
+++ b/src/common/event.cpp
@@ -591,26 +591,27 @@ void wxEvtHandler::ProcessPendingEvents()
 
 bool wxEvtHandler::ProcessEvent(wxEvent& event)
 {
-    // check that our flag corresponds to reality
+    /* check that our flag corresponds to reality */
     wxASSERT( m_isWindow == IsKindOf(CLASSINFO(wxWindow)) );
 
-    // An event handler can be enabled or disabled
+    /* An event handler can be enabled or disabled */
     if ( GetEvtHandlerEnabled() )
     {
 #if wxUSE_THREADS
-	// Check whether we are in a child thread.
+	/* Check whether we are in a child thread. */
         if (!wxThread::IsMain())
           return ProcessThreadEvent(event);
 #endif
-        // Handle per-instance dynamic event tables first
+        /* Handle per-instance dynamic event tables first */
 
         if ( m_dynamicEvents && SearchDynamicEventTable(event) )
             return TRUE;
 
-        // Then static per-class event tables
+        /* Then static per-class event tables */
 
         const wxEventTable *table = GetEventTable();
 
+#if wxUSE_VALIDATORS
         // Try the associated validator first, if this is a window.
         // Problem: if the event handler of the window has been replaced,
         // this wxEvtHandler may no longer be a window.
@@ -619,7 +620,7 @@ bool wxEvtHandler::ProcessEvent(wxEvent& event)
         // THIS CAN BE CURED if PushEventHandler is used instead of
         // SetEventHandler, and then processing will be passed down the
         // chain of event handlers.
-        if ( m_isWindow )
+        if (m_isWindow)
         {
             wxWindow *win = (wxWindow *)this;
 
@@ -634,9 +635,10 @@ bool wxEvtHandler::ProcessEvent(wxEvent& event)
                 }
             }
         }
+#endif
 
         // Search upwards through the inheritance hierarchy
-        while ( table )
+        while (table)
         {
             if ( SearchEventTable((wxEventTable&)*table, event) )
                 return TRUE;
diff --git a/src/common/file.cpp b/src/common/file.cpp
index 07c0f058fa..6702d2dd83 100644
--- a/src/common/file.cpp
+++ b/src/common/file.cpp
@@ -20,12 +20,17 @@
 
 // For compilers that support precompilation, includes "wx.h".
 #include "wx/wxprec.h"
-#include "wx/defs.h"
 
 #ifdef __BORLANDC__
-    #pragma hdrstop
+  #pragma hdrstop
 #endif
 
+#ifndef WX_PRECOMP
+  #include "wx/defs.h"
+#endif
+
+#if wxUSE_FILE
+
 // standard
 #if defined(__WXMSW__) && !defined(__GNUWIN32__) && !defined(__WXWINE__)
   #include  <io.h>
@@ -573,3 +578,5 @@ void wxTempFile::Discard()
     if ( remove(m_strTemp.fn_str()) != 0 )
         wxLogSysError(_("can't remove temporary file '%s'"), m_strTemp.c_str());
 }
+
+#endif
\ No newline at end of file
diff --git a/src/common/http.cpp b/src/common/http.cpp
index 771f024806..a7e14752b4 100644
--- a/src/common/http.cpp
+++ b/src/common/http.cpp
@@ -17,14 +17,15 @@
 #include "wx/wxprec.h"
 
 #ifdef __BORLANDC__
-#pragma hdrstop
+  #pragma hdrstop
 #endif
 
-#if wxUSE_SOCKETS
-
 #ifndef WX_PRECOMP
+  #include "wx/defs.h"
 #endif
 
+#if wxUSE_SOCKETS
+
 #include <stdio.h>
 #include <stdlib.h>
 #include "wx/string.h"
diff --git a/src/common/image.cpp b/src/common/image.cpp
index 50a037f7e3..91fc0fb9be 100644
--- a/src/common/image.cpp
+++ b/src/common/image.cpp
@@ -577,363 +577,9 @@ bool wxImageHandler::SaveFile( wxImage *WXUNUSED(image), wxOutputStream& WXUNUSE
 #endif // wxUSE_STREAMS
 
 //-----------------------------------------------------------------------------
-// wxBMPHandler
+// MSW conversion routines
 //-----------------------------------------------------------------------------
 
-#if !USE_SHARED_LIBRARIES
-IMPLEMENT_DYNAMIC_CLASS(wxBMPHandler,wxImageHandler)
-#endif
-
-#if wxUSE_STREAMS
-
-#ifndef BI_RGB
-#define BI_RGB       0
-#define BI_RLE8      1
-#define BI_RLE4      2
-#endif
-
-#ifndef BI_BITFIELDS
-#define BI_BITFIELDS 3
-#endif
-
-#define poffset (line * width * 3 + column * 3)
-
-bool wxBMPHandler::LoadFile( wxImage *image, wxInputStream& stream )
-{
-    int             rshift = 0, gshift = 0, bshift = 0;
-    wxUint8         aByte;
-    wxUint16        aWord;
-    wxInt32         dbuf[4], aDword, 
-                    rmask = 0, gmask = 0, bmask = 0;
-    wxInt8          bbuf[4];
-    struct _cmap {
-        unsigned char r, g, b;
-    } *cmap = NULL;
-    
-    off_t start_offset = stream.TellI();
-
-    image->Destroy();
-
-    /*
-     * Read the BMP header
-     */
-
-    stream.Read( &bbuf, 2 );
-    stream.Read( dbuf, 4 * 4 );
-
-    wxInt32 size = wxINT32_SWAP_ON_BE( dbuf[0] );
-    wxInt32 offset = wxINT32_SWAP_ON_BE( dbuf[2] );
-
-    stream.Read(dbuf, 4 * 2);
-    int width = (int)wxINT32_SWAP_ON_BE( dbuf[0] );
-    int height = (int)wxINT32_SWAP_ON_BE( dbuf[1] );
-    if (width > 32767)
-    {
-        wxLogError( _T("Image width > 32767 pixels for file.") );
-        return FALSE;
-    }
-    if (height > 32767)
-    {
-        wxLogError( _T("Image height > 32767 pixels for file.") );
-        return FALSE;
-    }
-    
-    stream.Read( &aWord, 2 );
-/*
-    TODO
-    int planes = (int)wxUINT16_SWAP_ON_BE( aWord );
-*/
-    stream.Read( &aWord, 2 );
-    int bpp = (int)wxUINT16_SWAP_ON_BE( aWord );
-    if (bpp != 1 && bpp != 4 && bpp != 8 && bpp != 16 && bpp != 24 && bpp != 32)
-    {
-        wxLogError( _T("unknown bitdepth in file.") );
-        return FALSE;
-    }
-    
-    stream.Read( dbuf, 4 * 4 );
-    int comp = (int)wxINT32_SWAP_ON_BE( dbuf[0] );
-    if (comp != BI_RGB && comp != BI_RLE4 && comp != BI_RLE8 && comp != BI_BITFIELDS)
-    {
-        wxLogError( _T("unknown encoding in Windows BMP file.") );
-        return FALSE;
-    }
-    
-    stream.Read( dbuf, 4 * 2 );
-    int ncolors = (int)wxINT32_SWAP_ON_BE( dbuf[0] );
-    if (ncolors == 0)
-        ncolors = 1 << bpp;
-    /* some more sanity checks */
-    if (((comp == BI_RLE4) && (bpp != 4)) || 
-        ((comp == BI_RLE8) && (bpp != 8)) || 
-	((comp == BI_BITFIELDS) && (bpp != 16 && bpp != 32)))
-    {
-        wxLogError( _T("encoding of BMP doesn't match bitdepth.") );
-        return FALSE;
-    }
-    if (bpp < 16)
-    {
-        cmap = (struct _cmap *)malloc(sizeof(struct _cmap) * ncolors);
-        if (!cmap)
-        {
-            wxLogError( _T("Cannot allocate RAM for color map in BMP file.") );
-            return FALSE;
-        }
-    }
-    else
-        cmap = NULL;
-
-    image->Create( width, height );
-    unsigned char *ptr = image->GetData();
-    if (!ptr)
-    {
-        wxLogError( _T("Cannot allocate RAM for RGB data in file.") );
-        if (cmap)
-            free(cmap);
-        return FALSE;
-    }
-
-    /*
-     * Reading the palette, if it exists.
-     */
-    if (bpp < 16 && ncolors != 0)
-    {
-        for (int j = 0; j < ncolors; j++)
-        {
-            stream.Read( bbuf, 4 );
-            cmap[j].b = bbuf[0];
-            cmap[j].g = bbuf[1];
-            cmap[j].r = bbuf[2];
-        }
-    }
-    else if (bpp == 16 || bpp == 32)
-    {
-        if (comp == BI_BITFIELDS)
-        {
-            int bit = 0;
-            stream.Read( dbuf, 4 * 3 );
-            bmask = wxINT32_SWAP_ON_BE( dbuf[0] );
-            gmask = wxINT32_SWAP_ON_BE( dbuf[1] );
-            rmask = wxINT32_SWAP_ON_BE( dbuf[2] );
-            /* find shift amount.. ugly, but i can't think of a better way */
-            for (bit = 0; bit < bpp; bit++)
-            {
-                if (bmask & (1 << bit))
-                    bshift = bit;
-                if (gmask & (1 << bit))
-                    gshift = bit;
-                if (rmask & (1 << bit))
-                    rshift = bit;
-            }
-        }
-        else if (bpp == 16)
-        {
-            rmask = 0x7C00;
-            gmask = 0x03E0;
-            bmask = 0x001F;
-            rshift = 10;
-            gshift = 5;
-            bshift = 0;
-        }
-        else if (bpp == 32)
-        {
-            rmask = 0x00FF0000;
-            gmask = 0x0000FF00;
-            bmask = 0x000000FF;
-            rshift = 16;
-            gshift = 8;
-            bshift = 0;
-        }
-    }
-
-    /*
-     * Reading the image data
-     */
-    stream.SeekI( start_offset + offset );
-    unsigned char *data = ptr;
-
-    /* set the whole image to the background color */
-    if (bpp < 16 && (comp == BI_RLE4 || comp == BI_RLE8))
-    {
-        for (int i = 0; i < width * height; i++)
-        {
-            *ptr++ = cmap[0].r;
-            *ptr++ = cmap[0].g;
-            *ptr++ = cmap[0].b;
-        }
-        ptr = data;
-    }
-    
-    int line = 0;
-    int column = 0;
-    int linesize = ((width * bpp + 31) / 32) * 4;
-
-    /* BMPs are stored upside down */
-    for (line = (height - 1); line >= 0; line--) 
-    {
-        int linepos = 0;
-        for (column = 0; column < width;)
-        {
-            if (bpp < 16)
-            {
-                int index = 0;
-                linepos++;
-                aByte = stream.GetC();
-                if (bpp == 1)
-                {
-                    int bit = 0;
-                    for (bit = 0; bit < 8; bit++)
-                    {
-                        index = ((aByte & (0x80 >> bit)) ? 1 : 0);
-                        ptr[poffset] = cmap[index].r;
-                        ptr[poffset + 1] = cmap[index].g;
-                        ptr[poffset + 2] = cmap[index].b;
-                        column++;
-                    }
-                }
-                else if (bpp == 4)
-                {
-                    if (comp == BI_RLE4)
-                    {
-                        wxLogError( _T("Can't deal with 4bit encoded yet.") );
-                        image->Destroy();
-                        free(cmap);
-                        return FALSE;
-                    }
-                    else
-                    {
-                        int nibble = 0;
-                        for (nibble = 0; nibble < 2; nibble++)
-                        {
-                            index = ((aByte & (0xF0 >> nibble * 4)) >> (!nibble * 4));
-                            if (index >= 16)
-                                index = 15;
-                            ptr[poffset] = cmap[index].r;
-                            ptr[poffset + 1] = cmap[index].g;
-                            ptr[poffset + 2] = cmap[index].b;
-                            column++;
-                        }
-                    }
-                }
-                else if (bpp == 8)
-                {
-                    if (comp == BI_RLE8)
-                    {
-                        unsigned char first;
-                        first = aByte;
-                        aByte = stream.GetC();
-                        if (first == 0)
-                        {
-                            if (aByte == 0)
-                            {
-                                /* column = width; */
-                            }
-                            else if (aByte == 1)
-                            {
-                                column = width;
-                                line = -1;
-                            }
-                            else if (aByte == 2)
-                            {
-                                aByte = stream.GetC();
-                                column += aByte;
-                                linepos = column * bpp / 8;
-                                aByte = stream.GetC();
-                                line += aByte;
-                            }
-                            else
-                            {
-                                int absolute = aByte;
-                                for (int k = 0; k < absolute; k++)
-                                {
-                                    linepos++;
-                                    aByte = stream.GetC();
-                                    ptr[poffset    ] = cmap[aByte].r;
-                                    ptr[poffset + 1] = cmap[aByte].g;
-                                    ptr[poffset + 2] = cmap[aByte].b;
-                                    column++;
-                                }
-                                if (absolute & 0x01)
-                                    aByte = stream.GetC();
-                            }
-                        }
-                        else
-                        {
-                            for (int l = 0; l < first; l++)
-                            {
-                                ptr[poffset    ] = cmap[aByte].r;
-                                ptr[poffset + 1] = cmap[aByte].g;
-                                ptr[poffset + 2] = cmap[aByte].b;
-                                column++;
-                                linepos++;
-                            }
-                        }
-                    }
-                    else
-                    {
-                        ptr[poffset    ] = cmap[aByte].r;
-                        ptr[poffset + 1] = cmap[aByte].g;
-                        ptr[poffset + 2] = cmap[aByte].b;
-                        column++;
-                        linepos += size;
-                    }
-                }
-               }
-               else if (bpp == 24)
-               {
-                   stream.Read( &bbuf, 3 );
-                   linepos += 3;
-                   ptr[poffset    ] = (unsigned char)bbuf[2];
-                   ptr[poffset + 1] = (unsigned char)bbuf[1];
-                   ptr[poffset + 2] = (unsigned char)bbuf[0];
-                   column++;
-               }
-               else if (bpp == 16)
-               {
-                   unsigned char temp;
-                   stream.Read( &aWord, 2 );
-		   aWord = wxUINT16_SWAP_ON_BE( aWord );
-                   linepos += 2;
-                   temp = (aWord & rmask) >> rshift;
-                   ptr[poffset] = temp;
-                   temp = (aWord & gmask) >> gshift;
-                   ptr[poffset + 1] = temp;
-                   temp = (aWord & bmask) >> gshift;
-                   ptr[poffset + 2] = temp;
-                   column++;
-               }
-               else
-               {
-                   unsigned char temp;
-                   stream.Read( &aDword, 4 );
-		   aDword = wxINT32_SWAP_ON_BE( aDword );
-                   linepos += 4;
-                   temp = (aDword & rmask) >> rshift;
-                   ptr[poffset] = temp;
-                   temp = (aDword & gmask) >> gshift;
-                   ptr[poffset + 1] = temp;
-                   temp = (aDword & bmask) >> bshift;
-                   ptr[poffset + 2] = temp;
-                   column++;
-               }
-          }
-          while ((linepos < linesize) && (comp != 1) && (comp != 2))
-          {
-              stream.Read( &aByte, 1 );
-              linepos += 1;
-              if (stream.LastError() != wxStream_NOERROR)
-                  break;
-          }
-     }
-     if (cmap) 
-       free(cmap);
-
-     image->SetMask( FALSE );
-
-     return TRUE;
-}
-#endif // wxUSE_STREAMS
-
 #ifdef __WXMSW__
 
 wxBitmap wxImage::ConvertToBitmap() const
@@ -1269,6 +915,10 @@ wxImage::wxImage( const wxBitmap &bitmap )
 
 #endif
 
+//-----------------------------------------------------------------------------
+// GTK conversion routines
+//-----------------------------------------------------------------------------
+
 #ifdef __WXGTK__
 
 #include "gtk/gtk.h"
@@ -1575,6 +1225,10 @@ wxImage::wxImage( const wxBitmap &bitmap )
 
 #endif
 
+//-----------------------------------------------------------------------------
+// Motif conversion routines
+//-----------------------------------------------------------------------------
+
 #ifdef __WXMOTIF__
 
 #include <Xm/Xm.h>
diff --git a/src/common/imaggif.cpp b/src/common/imaggif.cpp
index 596c9932d5..4977856f2a 100644
--- a/src/common/imaggif.cpp
+++ b/src/common/imaggif.cpp
@@ -6,24 +6,30 @@
 // Licence:     wxWindows licence
 /////////////////////////////////////////////////////////////////////////////
 
-#ifdef __GNUG__
-#pragma implementation "imaggif.h"
-#endif
+/*
+   We don't put pragma implement in this file because it is already present in
+   src/common/image.cpp
+*/
 
 // For compilers that support precompilation, includes "wx.h".
 #include <wx/wxprec.h>
 
 #ifdef __BORLANDC__
-#pragma hdrstop
+  #pragma hdrstop
 #endif
 
-#include <wx/wx.h>
+#ifndef WX_PRECOMP
+  #include "wx/defs.h"
+#endif
 
-#include <wx/image.h>
-#include <wx/wfstream.h>
-#include <wx/module.h>
+#include "wx/image.h"
+#include "wx/wfstream.h"
+#include "wx/module.h"
+#include "wx/log.h"
 
-#include <wx/imaggif.h>
+IMPLEMENT_DYNAMIC_CLASS(wxGIFHandler,wxImageHandler)
+
+#if wxUSE_STREAMS
 
 /*
 
@@ -361,8 +367,6 @@ FOLLOWING CODE IS BY V.S. :
 // wxGIFHandler
 //-----------------------------------------------------------------------------
 
-IMPLEMENT_DYNAMIC_CLASS(wxGIFHandler,wxImageHandler)
-
 bool wxGIFHandler::LoadFile( wxImage *image, wxInputStream& stream )
 {
     unsigned char *ptr, *src, *pal;
@@ -420,8 +424,4 @@ bool wxGIFHandler::SaveFile( wxImage * WXUNUSED(image),
     return FALSE;
 }
 
-
-
-
-
-
+#endif
diff --git a/src/common/imagjpeg.cpp b/src/common/imagjpeg.cpp
index 07bc8934cb..9a82b1029a 100644
--- a/src/common/imagjpeg.cpp
+++ b/src/common/imagjpeg.cpp
@@ -10,10 +10,6 @@
 /*
    We don't put pragma implement in this file because it is already present in
    src/common/image.cpp
-
-#ifdef __GNUG__
-#pragma implementation "image.h"
-#endif
 */
 
 // For compilers that support precompilation, includes "wx.h".
@@ -23,16 +19,18 @@
 #pragma hdrstop
 #endif
 
+#include "wx/defs.h"
+
+#if wxUSE_LIBJPEG
+
 #include "wx/image.h"
 #include "wx/bitmap.h"
 #include "wx/debug.h"
 #include "wx/log.h"
 #include "wx/app.h"
-#if wxUSE_LIBJPEG
-extern "C" {
-#include "../jpeg/jpeglib.h"
+extern "C" { 
+#include "jpeglib.h"
 }
-#endif
 #include "wx/filefn.h"
 #include "wx/wfstream.h"
 #include "wx/intl.h"
@@ -57,15 +55,12 @@ extern "C" {
 // wxJPEGHandler
 //-----------------------------------------------------------------------------
 
-#if wxUSE_LIBJPEG
-
 #if !USE_SHARED_LIBRARIES
 IMPLEMENT_DYNAMIC_CLASS(wxJPEGHandler,wxImageHandler)
 #endif
 
 #if wxUSE_STREAMS
 
-
 //------------- JPEG Data Source Manager
 
 typedef struct {
@@ -310,12 +305,12 @@ bool wxJPEGHandler::SaveFile( wxImage *image, wxOutputStream& stream )
     
     return TRUE;
 }
-#endif // wxUSE_STREAMS
-
-#endif
 
-// wxUSE_LIBJPEG
+#endif 
+  // wxUSE_STREAMS
 
+#endif 
+  // wxUSE_LIBJPEG
 
 
 
diff --git a/src/common/imagpng.cpp b/src/common/imagpng.cpp
index 11655cf352..b3b7482131 100644
--- a/src/common/imagpng.cpp
+++ b/src/common/imagpng.cpp
@@ -10,27 +10,27 @@
 /*
    We don't put pragma implement in this file because it is already present in
    src/common/image.cpp
-
-#ifdef __GNUG__
-#pragma implementation "image.h"
-#endif
 */
 
 // For compilers that support precompilation, includes "wx.h".
 #include "wx/wxprec.h"
 
 #ifdef __BORLANDC__
-#pragma hdrstop
+  #pragma hdrstop
+#endif
+
+#ifndef WX_PRECOMP
+  #include "wx/defs.h"
 #endif
 
+#if wxUSE_LIBPNG
+
 #include "wx/image.h"
 #include "wx/bitmap.h"
 #include "wx/debug.h"
 #include "wx/log.h"
 #include "wx/app.h"
-#if wxUSE_LIBPNG
-#include "../png/png.h"
-#endif
+#include "png.h"
 #include "wx/filefn.h"
 #include "wx/wfstream.h"
 #include "wx/intl.h"
@@ -53,14 +53,12 @@
 // wxPNGHandler
 //-----------------------------------------------------------------------------
 
-#if wxUSE_LIBPNG
-
 #if !USE_SHARED_LIBRARIES
 IMPLEMENT_DYNAMIC_CLASS(wxPNGHandler,wxImageHandler)
 #endif
 
-
 #if wxUSE_STREAMS
+
 static void _PNG_stream_reader( png_structp png_ptr, png_bytep data, png_size_t length )
 {
     ((wxInputStream*) png_get_io_ptr( png_ptr )) -> Read(data, length);
@@ -315,9 +313,10 @@ bool wxPNGHandler::SaveFile( wxImage *image, wxOutputStream& stream )
     }
     return TRUE;
 }
-#endif // wxUSE_STREAMS
 
-#endif
+#endif 
+  // wxUSE_STREAMS
 
-// wxUSE_LIBPNG
+#endif 
+  // wxUSE_LIBPNG
 
diff --git a/src/common/layout.cpp b/src/common/layout.cpp
index 3718e78c12..e11c18f3f2 100644
--- a/src/common/layout.cpp
+++ b/src/common/layout.cpp
@@ -25,19 +25,21 @@
 #include "wx/wxprec.h"
 
 #ifdef __BORLANDC__
-    #pragma hdrstop
+  #pragma hdrstop
 #endif
 
-#include "wx/defs.h"
+#ifndef WX_PRECOMP
+  #include "wx/defs.h"
+#endif
 
 #if wxUSE_CONSTRAINTS
 
 #ifndef WX_PRECOMP
-    #include "wx/window.h"
-    #include "wx/utils.h"
-    #include "wx/dialog.h"
-    #include "wx/msgdlg.h"
-    #include "wx/intl.h"
+  #include "wx/window.h"
+  #include "wx/utils.h"
+  #include "wx/dialog.h"
+  #include "wx/msgdlg.h"
+  #include "wx/intl.h"
 #endif
 
 #include "wx/layout.h"
diff --git a/src/common/mimetype.cpp b/src/common/mimetype.cpp
index 99e0a628b1..2ff0df4d34 100644
--- a/src/common/mimetype.cpp
+++ b/src/common/mimetype.cpp
@@ -10,34 +10,32 @@
 /////////////////////////////////////////////////////////////////////////////
 
 #ifdef    __GNUG__
-    #pragma implementation "mimetype.h"
+#pragma implementation "mimetype.h"
 #endif
 
-// ============================================================================
-// declarations
-// ============================================================================
-
-// ----------------------------------------------------------------------------
-// headers
-// ----------------------------------------------------------------------------
-
 // for compilers that support precompilation, includes "wx.h".
 #include "wx/wxprec.h"
 
 #ifdef __BORLANDC__
-    #pragma hdrstop
+  #pragma hdrstop
 #endif
 
-// wxWindows
 #ifndef WX_PRECOMP
-    #include  "wx/string.h"
-    #include  "wx/icon.h"
+  #include "wx/defs.h"
+#endif
+
+#if (wxUSE_FILE && wxUSE_TEXTFILE) || defined(__WXMSW__)
+
+#ifndef WX_PRECOMP
+  #include "wx/string.h"
+  #include "wx/icon.h"
 #endif //WX_PRECOMP
 
 // Doesn't compile in WIN16 mode
 #ifndef __WIN16__
 
 #include "wx/log.h"
+#include "wx/file.h"
 #include "wx/intl.h"
 #include "wx/dynarray.h"
 #include "wx/confbase.h"
@@ -1341,7 +1339,11 @@ bool wxMimeTypesManagerImpl::ReadMailcap(const wxString& strFileName,
     return TRUE;
 }
 
-#endif // OS type
+#endif 
+  // OS type
+
+#endif  
+  // wxUSE_FILE && wxUSE_TEXTFILE
 
 #endif
   // __WIN16__
diff --git a/src/common/mstream.cpp b/src/common/mstream.cpp
index 560c0fd1ae..c9f2370466 100644
--- a/src/common/mstream.cpp
+++ b/src/common/mstream.cpp
@@ -15,14 +15,21 @@
 
 // For compilers that support precompilation, includes "wx.h".
 #include "wx/wxprec.h"
-#include <stdlib.h>
-#include <wx/stream.h>
-#include <wx/mstream.h>
 
 #ifdef __BORLANDC__
-#pragma hdrstop
+  #pragma hdrstop
 #endif
 
+#ifndef WX_PRECOMP
+  #include "wx/defs.h"
+#endif
+
+#if wxUSE_STREAMS
+
+#include <stdlib.h>
+#include <wx/stream.h>
+#include <wx/mstream.h>
+
 // ----------------------------------------------------------------------------
 // wxMemoryInputStream
 // ----------------------------------------------------------------------------
@@ -60,3 +67,5 @@ wxMemoryOutputStream::wxMemoryOutputStream(char *data, size_t len)
 wxMemoryOutputStream::~wxMemoryOutputStream()
 {
 }
+
+#endif
diff --git a/src/common/objstrm.cpp b/src/common/objstrm.cpp
index 6f6c6e607f..4de828ae72 100644
--- a/src/common/objstrm.cpp
+++ b/src/common/objstrm.cpp
@@ -16,15 +16,14 @@
 #include "wx/wxprec.h"
 
 #ifdef __BORLANDC__
-#pragma hdrstop
+  #pragma hdrstop
 #endif
 
 #ifndef WX_PRECOMP
-#include "wx/defs.h"
-#include "wx/setup.h"
+  #include "wx/defs.h"
 #endif
 
-#if wxUSE_SERIAL
+#if wxUSE_SERIAL && wxUSE_STREAMS
 
 #include "wx/object.h"
 #include "wx/objstrm.h"
diff --git a/src/common/sckfile.cpp b/src/common/sckfile.cpp
index a4487f8df0..6c472fe224 100644
--- a/src/common/sckfile.cpp
+++ b/src/common/sckfile.cpp
@@ -16,14 +16,15 @@
 #include "wx/wxprec.h"
 
 #ifdef __BORLANDC__
-#pragma hdrstop
+  #pragma hdrstop
 #endif
 
-#if wxUSE_SOCKETS
-
 #ifndef WX_PRECOMP
+  #include "wx/defs.h"
 #endif
 
+#if wxUSE_SOCKETS
+
 #include <stdio.h>
 #include <wx/wfstream.h>
 #include <wx/protocol/file.h>
diff --git a/src/common/sckstrm.cpp b/src/common/sckstrm.cpp
index c0b5332b04..f7796cea3b 100644
--- a/src/common/sckstrm.cpp
+++ b/src/common/sckstrm.cpp
@@ -16,14 +16,15 @@
 #include "wx/wxprec.h"
 
 #ifdef __BORLANDC__
-#pragma hdrstop
+  #pragma hdrstop
 #endif
 
-#if wxUSE_SOCKETS
-
 #ifndef WX_PRECOMP
+  #include "wx/defs.h"
 #endif
 
+#if wxUSE_SOCKETS && wxUSE_STREAMS
+
 #include "wx/stream.h"
 #include "wx/socket.h"
 #include "wx/sckstrm.h"
@@ -90,3 +91,4 @@ wxSocketStream::~wxSocketStream()
 }
 
 #endif
+  // wxUSE_STREAMS && wxUSE_SOCKETS
diff --git a/src/common/stream.cpp b/src/common/stream.cpp
index d5954d71d8..cc38a5022b 100644
--- a/src/common/stream.cpp
+++ b/src/common/stream.cpp
@@ -15,15 +15,22 @@
 
 // For compilers that support precompilation, includes "wx.h".
 #include "wx/wxprec.h"
+
+#ifdef __BORLANDC__
+  #pragma hdrstop
+#endif
+
+#ifndef WX_PRECOMP
+  #include "wx/defs.h"
+#endif
+
+#if wxUSE_STREAMS
+
 #include <ctype.h>
 #include <wx/stream.h>
 #include <wx/datstrm.h>
 #include <wx/objstrm.h>
 
-#ifdef __BORLANDC__
-#pragma hdrstop
-#endif
-
 #define BUF_TEMP_SIZE 10000
 
 // ----------------------------------------------------------------------------
@@ -855,3 +862,6 @@ wxOutputStream& wxEndL(wxOutputStream& stream)
   return stream.Write("\n", 1);
 #endif
 }
+
+#endif
+  // wxUSE_STREAMS
diff --git a/src/common/textfile.cpp b/src/common/textfile.cpp
index c70d51d278..d45a4cc498 100644
--- a/src/common/textfile.cpp
+++ b/src/common/textfile.cpp
@@ -23,6 +23,12 @@
   #pragma hdrstop
 #endif  //__BORLANDC__
 
+#ifndef WX_PRECOMP
+#include "wx/defs.h"
+#endif
+
+#if wxUSE_TEXTFILE && wxUSE_FILE
+
 #include  <wx/string.h>
 #include  <wx/intl.h>
 #include  <wx/file.h>
@@ -250,7 +256,7 @@ bool wxTextFile::Write(wxTextFileType typeNew)
 }
 
 const wxChar *wxTextFile::GetEOL(wxTextFileType type)
-  {
+{
     switch ( type ) {
       case wxTextFileType_None: return _T("");
       case wxTextFileType_Unix: return _T("\n");
@@ -261,5 +267,6 @@ const wxChar *wxTextFile::GetEOL(wxTextFileType type)
         wxFAIL_MSG(_T("bad file type in wxTextFile::GetEOL."));
         return (const wxChar *) NULL;
     }
-  }
+}
 
+#endif
diff --git a/src/common/valgen.cpp b/src/common/valgen.cpp
index 7d64b2165c..41c659fe64 100644
--- a/src/common/valgen.cpp
+++ b/src/common/valgen.cpp
@@ -17,50 +17,66 @@
 #include "wx/wxprec.h"
 
 #ifdef __BORLANDC__
-#pragma hdrstop
+  #pragma hdrstop
 #endif
 
 #ifndef WX_PRECOMP
-#include "wx/utils.h"
-#include "wx/intl.h"
-#include "wx/wx.h"
-#include "wx/dynarray.h"
+  #include "wx/defs.h"
+#endif
+
+#if wxUSE_VALIDATORS
+
+#ifndef WX_PRECOMP
+  #include "wx/utils.h"
+  #include "wx/intl.h"
+  #include "wx/dynarray.h"
+  #include "wx/choice.h"
+  #include "wx/combobox.h"
+  #include "wx/radiobox.h"
+  #include "wx/radiobut.h"
+  #include "wx/checkbox.h"
+  #include "wx/scrolbar.h"
+  #include "wx/gauge.h"
+  #include "wx/stattext.h"
+  #include "wx/textctrl.h"
+  #include "wx/button.h"
+  #include "wx/listbox.h"
 #endif
 
 #ifndef __WIN16__
-#include "wx/spinbutt.h"
-#include "wx/checklst.h"
+  #include "wx/spinbutt.h"
+  #include "wx/checklst.h"
 #endif
 
 #include "wx/valgen.h"
 
 wxGenericValidator::wxGenericValidator(bool *val)
 {
-  Initialize();
-  m_pBool = val;
+    Initialize();
+    m_pBool = val;
 }
 
 wxGenericValidator::wxGenericValidator(int *val)
 {
-  Initialize();
-  m_pInt = val;
+    Initialize();
+    m_pInt = val;
 }
 
 wxGenericValidator::wxGenericValidator(wxString *val)
 {
-  Initialize();
-  m_pString = val;
+    Initialize();
+    m_pString = val;
 }
 
 wxGenericValidator::wxGenericValidator(wxArrayInt *val)
 {
-  Initialize();
-  m_pArrayInt = val;
+    Initialize();
+    m_pArrayInt = val;
 }
 
 wxGenericValidator::wxGenericValidator(const wxGenericValidator& val)
 {
-  Copy(val);
+    Copy(val);
 }
 
 bool wxGenericValidator::Copy(const wxGenericValidator& val)
@@ -176,9 +192,10 @@ bool wxGenericValidator::TransferToWindow(void)
       pControl->SetValue(*m_pString) ;
       return TRUE;
     }
-  }
+  } else
 #endif
-  else if (m_validatorWindow->IsKindOf(CLASSINFO(wxChoice)) )
+#if wxUSE_CHOICE
+  if (m_validatorWindow->IsKindOf(CLASSINFO(wxChoice)) )
   {
     wxChoice* pControl = (wxChoice*) m_validatorWindow;
 	if (m_pInt)
@@ -187,6 +204,7 @@ bool wxGenericValidator::TransferToWindow(void)
       return TRUE;
     }
   }
+#endif
   else if (m_validatorWindow->IsKindOf(CLASSINFO(wxStaticText)) )
   {
     wxStaticText* pControl = (wxStaticText*) m_validatorWindow;
@@ -352,6 +370,7 @@ bool wxGenericValidator::TransferFromWindow(void)
     }
   } else 
 #endif
+#if wxUSE_CHOICE
  if (m_validatorWindow->IsKindOf(CLASSINFO(wxChoice)) )
   {
     wxChoice* pControl = (wxChoice*) m_validatorWindow;
@@ -361,6 +380,7 @@ bool wxGenericValidator::TransferFromWindow(void)
       return TRUE;
     }
   } else 
+#endif
   if (m_validatorWindow->IsKindOf(CLASSINFO(wxStaticText)) )
   {
     wxStaticText* pControl = (wxStaticText*) m_validatorWindow;
@@ -431,9 +451,12 @@ bool wxGenericValidator::TransferFromWindow(void)
 */
 void wxGenericValidator::Initialize()
 {
-  m_pBool = 0;
-  m_pInt = 0;
-  m_pString = 0;
-  m_pArrayInt = 0;
+    m_pBool = 0;
+    m_pInt = 0;
+    m_pString = 0;
+    m_pArrayInt = 0;
 }
 
+#endif
+  // wxUSE_VALIDATORS
+  
\ No newline at end of file
diff --git a/src/common/validate.cpp b/src/common/validate.cpp
index 6932875a5c..44e0caeece 100644
--- a/src/common/validate.cpp
+++ b/src/common/validate.cpp
@@ -10,18 +10,24 @@
 /////////////////////////////////////////////////////////////////////////////
 
 #ifdef __GNUG__
-    #pragma implementation "validate.h"
+#pragma implementation "validate.h"
 #endif
 
 // For compilers that support precompilation, includes "wx.h".
 #include "wx/wxprec.h"
 
 #ifdef __BORLANDC__
-    #pragma hdrstop
+  #pragma hdrstop
 #endif
 
 #ifndef WX_PRECOMP
-    #include "wx/wx.h"
+  #include "wx/defs.h"
+#endif
+
+#if wxUSE_VALIDATORS
+
+#ifndef WX_PRECOMP
+  #include "wx/window.h"
 #endif
 
 #include "wx/validate.h"
@@ -45,4 +51,5 @@ wxValidator::~wxValidator()
 {
 }
 
-
+#endif
+  // wxUSE_VALIDATORS
diff --git a/src/common/valtext.cpp b/src/common/valtext.cpp
index bb83543bb1..a3b027ea0a 100644
--- a/src/common/valtext.cpp
+++ b/src/common/valtext.cpp
@@ -10,22 +10,28 @@
 /////////////////////////////////////////////////////////////////////////////
 
 #ifdef __GNUG__
-    #pragma implementation "valtext.h"
+#pragma implementation "valtext.h"
 #endif
 
 // For compilers that support precompilation, includes "wx.h".
 #include "wx/wxprec.h"
 
 #ifdef __BORLANDC__
-    #pragma hdrstop
+  #pragma hdrstop
 #endif
 
 #ifndef WX_PRECOMP
-    #include <stdio.h>
-    #include "wx/textctrl.h"
-    #include "wx/utils.h"
-    #include "wx/msgdlg.h"
-    #include "wx/intl.h"
+  #include "wx/defs.h"
+#endif
+
+#if wxUSE_VALIDATORS
+
+#ifndef WX_PRECOMP
+  #include <stdio.h>
+  #include "wx/textctrl.h"
+  #include "wx/utils.h"
+  #include "wx/msgdlg.h"
+  #include "wx/intl.h"
 #endif
 
 #include "wx/valtext.h"
@@ -306,3 +312,6 @@ static bool wxIsNumeric(const wxString& val)
     return TRUE;
 }
 
+#endif
+  // wxUSE_VALIDATORS
+  
\ No newline at end of file
diff --git a/src/common/wfstream.cpp b/src/common/wfstream.cpp
index 885bab4cf9..e4da5d94df 100644
--- a/src/common/wfstream.cpp
+++ b/src/common/wfstream.cpp
@@ -15,14 +15,21 @@
 
 // For compilers that support precompilation, includes "wx.h".
 #include "wx/wxprec.h"
-#include <stdio.h>
-#include <wx/stream.h>
-#include <wx/wfstream.h>
 
 #ifdef __BORLANDC__
-#pragma hdrstop
+  #pragma hdrstop
 #endif
 
+#ifndef WX_PRECOMP
+  #include "wx/defs.h"
+#endif
+
+#if wxUSE_STREAMS && wxUSE_FILE
+
+#include <stdio.h>
+#include <wx/stream.h>
+#include <wx/wfstream.h>
+
 // ----------------------------------------------------------------------------
 // wxFileInputStream
 // ----------------------------------------------------------------------------
@@ -163,3 +170,6 @@ wxFileStream::wxFileStream(const wxString& fileName)
  : wxFileInputStream(fileName), wxFileOutputStream(*wxFileInputStream::m_file)
 {
 }
+
+#endif
+  // wxUSE_STREAMS && wxUSE_FILE
diff --git a/src/common/zstream.cpp b/src/common/zstream.cpp
index 90d3338161..09953c87d1 100644
--- a/src/common/zstream.cpp
+++ b/src/common/zstream.cpp
@@ -8,6 +8,7 @@
 // Copyright:   (c) Guilhem Lavaux
 // Licence:     wxWindows licence
 /////////////////////////////////////////////////////////////////////////////
+
 #ifdef __GNUG__
 #pragma implementation "zstream.h"
 #endif
@@ -15,18 +16,21 @@
 // For compilers that support precompilation, includes "wx.h".
 #include "wx/wxprec.h"
 
-#include "wx/zstream.h"
+#ifdef __BORLANDC__
+  #pragma hdrstop
+#endif
+
+#ifndef WX_PRECOMP
+  #include "wx/defs.h"
+#endif
 
-#if wxUSE_ZLIB
+#if wxUSE_ZLIB && wxUSE_STREAMS
 
+#include "wx/zstream.h"
 #include "wx/utils.h"
 #include "wx/intl.h"
 #include "wx/log.h"
-#include "../zlib/zlib.h"   // don't change this, Robert
-
-#ifdef __BORLANDC__
-#pragma hdrstop
-#endif
+#include "zlib.h"
 
 #define ZSTREAM_BUFFER_SIZE 1024
 
@@ -186,6 +190,5 @@ size_t wxZlibOutputStream::OnSysWrite(const void *buffer, size_t size)
 }
 
 #endif
-
-  // wxUSE_ZLIB
+  // wxUSE_ZLIB && wxUSE_STREAMS
   
diff --git a/src/generic/dcpsg.cpp b/src/generic/dcpsg.cpp
index 291946a96e..880a6a10aa 100644
--- a/src/generic/dcpsg.cpp
+++ b/src/generic/dcpsg.cpp
@@ -25,6 +25,8 @@
     #include "wx/defs.h"
 #endif // WX_PRECOMP
 
+#if wxUSE_PRINTING_ARCHITECTURE
+
 #if wxUSE_POSTSCRIPT
 
 #include "wx/dcmemory.h"
@@ -2267,3 +2269,6 @@ void wxPostScriptModule::OnExit()
 
 #endif
   // wxUSE_POSTSCRIPT
+
+#endif 
+  // wxUSE_PRINTING_ARCHITECTURE
\ No newline at end of file
diff --git a/src/generic/dirdlgg.cpp b/src/generic/dirdlgg.cpp
index ef802459fa..fa4ca908b1 100644
--- a/src/generic/dirdlgg.cpp
+++ b/src/generic/dirdlgg.cpp
@@ -20,6 +20,9 @@
 #endif
 
 #include "wx/defs.h"
+
+#if wxUSE_DIRDLG
+
 #include "wx/utils.h"
 #include "wx/dialog.h"
 #include "wx/button.h"
@@ -501,3 +504,5 @@ void wxDirDialog::OnCheck( wxCommandEvent& WXUNUSED(event) )
   printf("Checkbox clicked: %s\n", ( m_check->GetValue() ? "on" : "off" ) );
 }
 */
+
+#endif
diff --git a/src/generic/helphtml.cpp b/src/generic/helphtml.cpp
index 6065eeef12..b7885919ca 100644
--- a/src/generic/helphtml.cpp
+++ b/src/generic/helphtml.cpp
@@ -104,6 +104,7 @@ wxHTMLHelpControllerBase::LoadFile(const wxString& ifile)
       else
          file = ifile;
 
+#if wxUSE_INTL
       // If a locale is set, look in file/localename, i.e.
       // If passed "/usr/local/myapp/help" and the current wxLocale is
       // set to be "de", then look in "/usr/local/myapp/help/de/"
@@ -125,6 +126,7 @@ wxHTMLHelpControllerBase::LoadFile(const wxString& ifile)
                file = newfile;
          }
       }
+#endif
 
       if(! wxDirExists(file))
          return FALSE;
diff --git a/src/generic/listctrl.cpp b/src/generic/listctrl.cpp
index 25364ef23f..02741c4278 100644
--- a/src/generic/listctrl.cpp
+++ b/src/generic/listctrl.cpp
@@ -2390,7 +2390,9 @@ bool wxListCtrl::Create( wxWindow *parent, wxWindowID id,
 
     bool ret = wxControl::Create( parent, id, pos, size, s, name );
 
+#if wxUSE_VALIDATORS
     SetValidator( validator );
+#endif
   
     if (s & wxSUNKEN_BORDER) s -= wxSUNKEN_BORDER;
 
diff --git a/src/generic/printps.cpp b/src/generic/printps.cpp
index e9b819b6fc..5cb8272a26 100644
--- a/src/generic/printps.cpp
+++ b/src/generic/printps.cpp
@@ -30,6 +30,8 @@
 
 #include "wx/defs.h"
 
+#if wxUSE_PRINTING_ARCHITECTURE
+
 #ifndef WX_PRECOMP
     #include "wx/utils.h"
     #include "wx/dc.h"
@@ -345,3 +347,4 @@ void wxPostScriptPrintPreview::DetermineScaling()
     }
 }
 
+#endif
diff --git a/src/generic/prntdlgg.cpp b/src/generic/prntdlgg.cpp
index e420201628..665c7ce812 100644
--- a/src/generic/prntdlgg.cpp
+++ b/src/generic/prntdlgg.cpp
@@ -30,6 +30,8 @@
 
 #include "wx/defs.h"
 
+#if wxUSE_PRINTING_ARCHITECTURE
+
 #ifndef WX_PRECOMP
     #include "wx/utils.h"
     #include "wx/dc.h"
@@ -770,3 +772,4 @@ wxChoice *wxGenericPageSetupDialog::CreatePaperTypeChoice(int *x, int *y)
     return choice;
 }
 
+#endif
diff --git a/src/generic/progdlgg.cpp b/src/generic/progdlgg.cpp
index 137a4be73c..b3b74cc634 100644
--- a/src/generic/progdlgg.cpp
+++ b/src/generic/progdlgg.cpp
@@ -31,6 +31,8 @@
 #include "wx/intl.h"
 #endif
 
+#if wxUSE_PROGRESSDLG
+
 #include "wx/generic/progdlgg.h"
 
 #define LAYOUT_X_MARGIN 8
@@ -172,3 +174,5 @@ wxProgressDialog::~wxProgressDialog()
    else
       wxEnableTopLevelWindows(TRUE);
 }
+
+#endif
diff --git a/src/generic/treectrl.cpp b/src/generic/treectrl.cpp
index 67fe811ede..944c984855 100644
--- a/src/generic/treectrl.cpp
+++ b/src/generic/treectrl.cpp
@@ -403,7 +403,9 @@ bool wxTreeCtrl::Create(wxWindow *parent, wxWindowID id,
 
   wxScrolledWindow::Create( parent, id, pos, size, style|wxHSCROLL|wxVSCROLL, name );
 
+#if wxUSE_VALIDATORS
   SetValidator( validator );
+#endif
 
   SetBackgroundColour( *wxWHITE );
   m_dottedPen = wxPen( *wxBLACK, 0, 0 );
diff --git a/src/gtk/Makefile.am b/src/gtk/Makefile.am
index 4af3fb61fb..85dc87380b 100644
--- a/src/gtk/Makefile.am
+++ b/src/gtk/Makefile.am
@@ -57,6 +57,7 @@ libwx_gtk_la_SOURCES = \
  helpbase.cpp \
  http.cpp \
  image.cpp \
+ imagbmp.cpp \
  imaggif.cpp \
  imagjpeg.cpp \
  imagpng.cpp \
diff --git a/src/gtk/bmpbuttn.cpp b/src/gtk/bmpbuttn.cpp
index 71e20e97f2..6661b99efd 100644
--- a/src/gtk/bmpbuttn.cpp
+++ b/src/gtk/bmpbuttn.cpp
@@ -122,7 +122,9 @@ bool wxBitmapButton::Create( wxWindow *parent, wxWindowID id, const wxBitmap &bi
 
     PreCreation( parent, id, pos, newSize, style, name );
   
+#if wxUSE_VALIDATORS
     SetValidator( validator );
+#endif
 
     m_bitmap   = bitmap;
     m_disabled = bitmap;
diff --git a/src/gtk/checkbox.cpp b/src/gtk/checkbox.cpp
index f7d4fa4840..946a09a413 100644
--- a/src/gtk/checkbox.cpp
+++ b/src/gtk/checkbox.cpp
@@ -82,7 +82,10 @@ bool wxCheckBox::Create(wxWindow *parent,
 
     m_blockFirstEvent = FALSE;
 
+#if wxUSE_VALIDATORS
     SetValidator( validator );
+#endif
+
     wxControl::SetLabel( label );
 
     if ( style & wxALIGN_RIGHT )
diff --git a/src/gtk/choice.cpp b/src/gtk/choice.cpp
index 9b9be9c0b0..bd63c5e3f8 100644
--- a/src/gtk/choice.cpp
+++ b/src/gtk/choice.cpp
@@ -14,6 +14,8 @@
 
 #include "wx/choice.h"
 
+#if wxUSE_CHOICE
+
 #include "gdk/gdk.h"
 #include "gtk/gtk.h"
 
@@ -71,7 +73,9 @@ bool wxChoice::Create( wxWindow *parent, wxWindowID id,
 
     PreCreation( parent, id, pos, size, style, name );
 
+#if wxUSE_VALIDATORS
     SetValidator( validator );
+#endif
 
     m_widget = gtk_option_menu_new();
 
@@ -388,3 +392,4 @@ void wxChoice::ApplyWidgetStyle()
     }
 }
 
+#endif
diff --git a/src/gtk/combobox.cpp b/src/gtk/combobox.cpp
index 3a8ee3af6a..efbe51763d 100644
--- a/src/gtk/combobox.cpp
+++ b/src/gtk/combobox.cpp
@@ -104,7 +104,9 @@ bool wxComboBox::Create( wxWindow *parent, wxWindowID id, const wxString& value,
 
     PreCreation( parent, id, pos, size, style, name );
 
+#if wxUSE_VALIDATORS
     SetValidator( validator );
+#endif
 
     m_widget = gtk_combo_new();
 
diff --git a/src/gtk/gauge.cpp b/src/gtk/gauge.cpp
index 3c64b9d500..e176cbe194 100644
--- a/src/gtk/gauge.cpp
+++ b/src/gtk/gauge.cpp
@@ -32,7 +32,9 @@ bool wxGauge::Create( wxWindow *parent, wxWindowID id,  int range,
   
   PreCreation( parent, id, pos, size, style, name );
   
-  SetValidator( validator );
+#if wxUSE_VALIDATORS
+    SetValidator( validator );
+#endif
 
   m_rangeMax = range;
   m_gaugePos = 0;
diff --git a/src/gtk/listbox.cpp b/src/gtk/listbox.cpp
index 8639e859fb..4c496c67a0 100644
--- a/src/gtk/listbox.cpp
+++ b/src/gtk/listbox.cpp
@@ -246,7 +246,9 @@ bool wxListBox::Create( wxWindow *parent, wxWindowID id,
 
     PreCreation( parent, id, pos, size, style, name );
 
+#if wxUSE_VALIDATORS
     SetValidator( validator );
+#endif
 
     m_widget = gtk_scrolled_window_new( (GtkAdjustment*) NULL, (GtkAdjustment*) NULL );
     if (style & wxLB_ALWAYS_SB)
diff --git a/src/gtk/radiobox.cpp b/src/gtk/radiobox.cpp
index e677deb968..7d2f23a120 100644
--- a/src/gtk/radiobox.cpp
+++ b/src/gtk/radiobox.cpp
@@ -87,7 +87,9 @@ bool wxRadioBox::Create( wxWindow *parent, wxWindowID id, const wxString& title,
 
     PreCreation( parent, id, pos, size, style, name );
 
+#if wxUSE_VALIDATORS
     SetValidator( validator );
+#endif
 
     m_widget = gtk_frame_new( title.mbc_str() );
 
diff --git a/src/gtk/radiobut.cpp b/src/gtk/radiobut.cpp
index 5957092695..6b6cd98694 100644
--- a/src/gtk/radiobut.cpp
+++ b/src/gtk/radiobut.cpp
@@ -74,7 +74,9 @@ bool wxRadioButton::Create( wxWindow *parent, wxWindowID id, const wxString& lab
 
     PreCreation( parent, id, pos, newSize, style, name );
   
+#if wxUSE_VALIDATORS
     SetValidator( validator );
+#endif
 
     m_widget = gtk_radio_button_new_with_label( (GSList *) NULL, label.mbc_str() );
       
diff --git a/src/gtk/scrolbar.cpp b/src/gtk/scrolbar.cpp
index 038d908e20..a2f96c9a33 100644
--- a/src/gtk/scrolbar.cpp
+++ b/src/gtk/scrolbar.cpp
@@ -139,7 +139,9 @@ bool wxScrollBar::Create(wxWindow *parent, wxWindowID id,
   
     PreCreation( parent, id, pos, size, style, name );
   
+#if wxUSE_VALIDATORS
     SetValidator( validator );
+#endif
 
     m_oldPos = 0.0;
 
diff --git a/src/gtk/slider.cpp b/src/gtk/slider.cpp
index 504b1cfb5a..b2f0bccefc 100644
--- a/src/gtk/slider.cpp
+++ b/src/gtk/slider.cpp
@@ -100,7 +100,9 @@ bool wxSlider::Create(wxWindow *parent, wxWindowID id,
   
     PreCreation( parent, id, pos, size, style, name );
   
+#if wxUSE_VALIDATORS
     SetValidator( validator );
+#endif
 
     m_oldPos = 0.0;
 
diff --git a/src/gtk1/Makefile.am b/src/gtk1/Makefile.am
index 4af3fb61fb..85dc87380b 100644
--- a/src/gtk1/Makefile.am
+++ b/src/gtk1/Makefile.am
@@ -57,6 +57,7 @@ libwx_gtk_la_SOURCES = \
  helpbase.cpp \
  http.cpp \
  image.cpp \
+ imagbmp.cpp \
  imaggif.cpp \
  imagjpeg.cpp \
  imagpng.cpp \
diff --git a/src/gtk1/bmpbuttn.cpp b/src/gtk1/bmpbuttn.cpp
index 71e20e97f2..6661b99efd 100644
--- a/src/gtk1/bmpbuttn.cpp
+++ b/src/gtk1/bmpbuttn.cpp
@@ -122,7 +122,9 @@ bool wxBitmapButton::Create( wxWindow *parent, wxWindowID id, const wxBitmap &bi
 
     PreCreation( parent, id, pos, newSize, style, name );
   
+#if wxUSE_VALIDATORS
     SetValidator( validator );
+#endif
 
     m_bitmap   = bitmap;
     m_disabled = bitmap;
diff --git a/src/gtk1/checkbox.cpp b/src/gtk1/checkbox.cpp
index f7d4fa4840..946a09a413 100644
--- a/src/gtk1/checkbox.cpp
+++ b/src/gtk1/checkbox.cpp
@@ -82,7 +82,10 @@ bool wxCheckBox::Create(wxWindow *parent,
 
     m_blockFirstEvent = FALSE;
 
+#if wxUSE_VALIDATORS
     SetValidator( validator );
+#endif
+
     wxControl::SetLabel( label );
 
     if ( style & wxALIGN_RIGHT )
diff --git a/src/gtk1/choice.cpp b/src/gtk1/choice.cpp
index 9b9be9c0b0..bd63c5e3f8 100644
--- a/src/gtk1/choice.cpp
+++ b/src/gtk1/choice.cpp
@@ -14,6 +14,8 @@
 
 #include "wx/choice.h"
 
+#if wxUSE_CHOICE
+
 #include "gdk/gdk.h"
 #include "gtk/gtk.h"
 
@@ -71,7 +73,9 @@ bool wxChoice::Create( wxWindow *parent, wxWindowID id,
 
     PreCreation( parent, id, pos, size, style, name );
 
+#if wxUSE_VALIDATORS
     SetValidator( validator );
+#endif
 
     m_widget = gtk_option_menu_new();
 
@@ -388,3 +392,4 @@ void wxChoice::ApplyWidgetStyle()
     }
 }
 
+#endif
diff --git a/src/gtk1/combobox.cpp b/src/gtk1/combobox.cpp
index 3a8ee3af6a..efbe51763d 100644
--- a/src/gtk1/combobox.cpp
+++ b/src/gtk1/combobox.cpp
@@ -104,7 +104,9 @@ bool wxComboBox::Create( wxWindow *parent, wxWindowID id, const wxString& value,
 
     PreCreation( parent, id, pos, size, style, name );
 
+#if wxUSE_VALIDATORS
     SetValidator( validator );
+#endif
 
     m_widget = gtk_combo_new();
 
diff --git a/src/gtk1/gauge.cpp b/src/gtk1/gauge.cpp
index 3c64b9d500..e176cbe194 100644
--- a/src/gtk1/gauge.cpp
+++ b/src/gtk1/gauge.cpp
@@ -32,7 +32,9 @@ bool wxGauge::Create( wxWindow *parent, wxWindowID id,  int range,
   
   PreCreation( parent, id, pos, size, style, name );
   
-  SetValidator( validator );
+#if wxUSE_VALIDATORS
+    SetValidator( validator );
+#endif
 
   m_rangeMax = range;
   m_gaugePos = 0;
diff --git a/src/gtk1/listbox.cpp b/src/gtk1/listbox.cpp
index 8639e859fb..4c496c67a0 100644
--- a/src/gtk1/listbox.cpp
+++ b/src/gtk1/listbox.cpp
@@ -246,7 +246,9 @@ bool wxListBox::Create( wxWindow *parent, wxWindowID id,
 
     PreCreation( parent, id, pos, size, style, name );
 
+#if wxUSE_VALIDATORS
     SetValidator( validator );
+#endif
 
     m_widget = gtk_scrolled_window_new( (GtkAdjustment*) NULL, (GtkAdjustment*) NULL );
     if (style & wxLB_ALWAYS_SB)
diff --git a/src/gtk1/radiobox.cpp b/src/gtk1/radiobox.cpp
index e677deb968..7d2f23a120 100644
--- a/src/gtk1/radiobox.cpp
+++ b/src/gtk1/radiobox.cpp
@@ -87,7 +87,9 @@ bool wxRadioBox::Create( wxWindow *parent, wxWindowID id, const wxString& title,
 
     PreCreation( parent, id, pos, size, style, name );
 
+#if wxUSE_VALIDATORS
     SetValidator( validator );
+#endif
 
     m_widget = gtk_frame_new( title.mbc_str() );
 
diff --git a/src/gtk1/radiobut.cpp b/src/gtk1/radiobut.cpp
index 5957092695..6b6cd98694 100644
--- a/src/gtk1/radiobut.cpp
+++ b/src/gtk1/radiobut.cpp
@@ -74,7 +74,9 @@ bool wxRadioButton::Create( wxWindow *parent, wxWindowID id, const wxString& lab
 
     PreCreation( parent, id, pos, newSize, style, name );
   
+#if wxUSE_VALIDATORS
     SetValidator( validator );
+#endif
 
     m_widget = gtk_radio_button_new_with_label( (GSList *) NULL, label.mbc_str() );
       
diff --git a/src/gtk1/scrolbar.cpp b/src/gtk1/scrolbar.cpp
index 038d908e20..a2f96c9a33 100644
--- a/src/gtk1/scrolbar.cpp
+++ b/src/gtk1/scrolbar.cpp
@@ -139,7 +139,9 @@ bool wxScrollBar::Create(wxWindow *parent, wxWindowID id,
   
     PreCreation( parent, id, pos, size, style, name );
   
+#if wxUSE_VALIDATORS
     SetValidator( validator );
+#endif
 
     m_oldPos = 0.0;
 
diff --git a/src/gtk1/slider.cpp b/src/gtk1/slider.cpp
index 504b1cfb5a..b2f0bccefc 100644
--- a/src/gtk1/slider.cpp
+++ b/src/gtk1/slider.cpp
@@ -100,7 +100,9 @@ bool wxSlider::Create(wxWindow *parent, wxWindowID id,
   
     PreCreation( parent, id, pos, size, style, name );
   
+#if wxUSE_VALIDATORS
     SetValidator( validator );
+#endif
 
     m_oldPos = 0.0;
 
diff --git a/src/motif/Makefile.am b/src/motif/Makefile.am
index b9ea7d1782..faa471ef06 100644
--- a/src/motif/Makefile.am
+++ b/src/motif/Makefile.am
@@ -56,6 +56,7 @@ libwx_motif_la_SOURCES = \
  helpbase.cpp \
  http.cpp \
  image.cpp \
+ imagbmp.cpp \
  imaggif.cpp \
  imagjpeg.cpp \
  imagpng.cpp \
diff --git a/src/msw/Makefile.am b/src/msw/Makefile.am
index 45128e4bbf..0267832744 100644
--- a/src/msw/Makefile.am
+++ b/src/msw/Makefile.am
@@ -54,6 +54,7 @@ libwx_msw_la_SOURCES = \
  helpbase.cpp \
  http.cpp \
  image.cpp \
+ imagbmp.cpp \
  imaggif.cpp \
  imagjpeg.cpp \
  imagpng.cpp \
diff --git a/src/msw/makefile.b32 b/src/msw/makefile.b32
index fad700852b..6e357ccafc 100644
--- a/src/msw/makefile.b32
+++ b/src/msw/makefile.b32
@@ -113,6 +113,7 @@ COMMONOBJS = \
   $(MSWDIR)\gdicmn.obj \
   $(MSWDIR)\helpbase.obj \
   $(MSWDIR)\image.obj \
+  $(MSWDIR)\imagbmp.obj \
   $(MSWDIR)\imagpng.obj \
   $(MSWDIR)\imagjpeg.obj \
   $(MSWDIR)\imaggif.obj \
@@ -517,6 +518,8 @@ $(MSWDIR)\gdicmn.obj:     $(COMMDIR)\gdicmn.$(SRCSUFF)
 
 $(MSWDIR)\image.obj:     $(COMMDIR)\image.$(SRCSUFF)
 
+$(MSWDIR)\imagbmp.obj:     $(COMMDIR)\imagbmp.$(SRCSUFF)
+
 $(MSWDIR)\imagpng.obj:     $(COMMDIR)\imagpng.$(SRCSUFF)
 
 $(MSWDIR)\imagjpeg.obj:     $(COMMDIR)\imagjpeg.$(SRCSUFF)
diff --git a/src/msw/makefile.g95 b/src/msw/makefile.g95
index 3b55706fbe..bb84243c76 100644
--- a/src/msw/makefile.g95
+++ b/src/msw/makefile.g95
@@ -91,6 +91,7 @@ COMMONOBJS = \
   $(COMMDIR)/gdicmn.$(OBJSUFF) \
   $(COMMDIR)/helpbase.$(OBJSUFF) \
   $(COMMDIR)/image.$(OBJSUFF) \
+  $(COMMDIR)/imagebmp.$(OBJSUFF) \
   $(COMMDIR)/imagpng.$(OBJSUFF) \
   $(COMMDIR)/imagjpeg.$(OBJSUFF) \
   $(COMMDIR)/intl.$(OBJSUFF) \
diff --git a/src/msw/makefile.twn b/src/msw/makefile.twn
index 3a70a7d5f6..1153904bf5 100644
--- a/src/msw/makefile.twn
+++ b/src/msw/makefile.twn
@@ -93,6 +93,7 @@ COMMONOBJS = \
   $(COMMDIR)/gdicmn.$(OBJSUFF) \
   $(COMMDIR)/helpbase.$(OBJSUFF) \
   $(COMMDIR)/image.$(OBJSUFF) \
+  $(COMMDIR)/imagbmp.$(OBJSUFF) \
   $(COMMDIR)/imagpng.$(OBJSUFF) \
   $(COMMDIR)/imagjpeg.$(OBJSUFF) \
   $(COMMDIR)/intl.$(OBJSUFF) \
diff --git a/src/msw/makefile.vc b/src/msw/makefile.vc
index 7b8e046e4b..6ebf727c68 100644
--- a/src/msw/makefile.vc
+++ b/src/msw/makefile.vc
@@ -114,6 +114,7 @@ COMMONOBJS = \
   ..\common\$D\ftp.obj \
   ..\common\$D\gdicmn.obj \
   ..\common\$D\image.obj \
+  ..\common\$D\imagbmp.obj \
   ..\common\$D\imagjpeg.obj \
   ..\common\$D\imagpng.obj \
   ..\common\$D\imaggif.obj \
diff --git a/src/msw/makefile.wat b/src/msw/makefile.wat
index 5ded030671..fe278f986c 100644
--- a/src/msw/makefile.wat
+++ b/src/msw/makefile.wat
@@ -64,6 +64,7 @@ COMMONOBJS = cmndata.obj &
   framecmn.obj &
   gdicmn.obj &
   image.obj &
+  imagbmp.obj &
   imagpng.obj &
   intl.obj &
   ipcbase.obj &
@@ -569,6 +570,9 @@ gdicmn.obj:     $(COMMDIR)\gdicmn.cpp
 image.obj:     $(COMMDIR)\image.cpp
   *$(CCC) $(CPPFLAGS) $(IFLAGS) $<
 
+imagbmp.obj:     $(COMMDIR)\imagbmp.cpp
+  *$(CCC) $(CPPFLAGS) -i=..\png -i=..\zlib $(IFLAGS) $<
+
 imagpng.obj:     $(COMMDIR)\imagpng.cpp
   *$(CCC) $(CPPFLAGS) -i=..\png -i=..\zlib $(IFLAGS) $<
 
-- 
2.45.2