// Modified by:
// Created: 19.06.2003
// RCS-ID: $Id$
-// Copyright: (c) 2003 Vadim Zeitlin <vadim@wxwindows.org>
+// Copyright: (c) 2003 Vadim Zeitlin <vadim@wxwidgets.org>
// Licence: wxWindows licence
///////////////////////////////////////////////////////////////////////////////
class WXDLLEXPORT wxRendererNative;
class WXDLLIMPEXP_BASE wxString;
-extern "C" struct GSocketGUIFunctionsTable;
+class GSocketGUIFunctionsTable;
// ----------------------------------------------------------------------------
// toolkit information
// wxAppTraits: this class defines various configurable aspects of wxApp
// ----------------------------------------------------------------------------
+class WXDLLIMPEXP_BASE wxStandardPathsBase;
+
class WXDLLIMPEXP_BASE wxAppTraitsBase
{
public:
// NB: returned pointer will be deleted by the caller
virtual wxRendererNative *CreateRenderer() = 0;
+ // wxStandardPaths object is normally the same for wxBase and wxGUI
+ // except in the case of wxMac and wxCocoa
+#ifndef __WXPALMOS__
+ virtual wxStandardPathsBase& GetStandardPaths();
+#endif
// functions abstracting differences between GUI and console modes
// ------------------------------------------------------------------------
virtual void RemoveFromPendingDelete(wxObject *object) = 0;
#if wxUSE_SOCKETS
- // return table of GUI callbacks for GSocket code or NULL in wxBase
+ // return table of GUI callbacks for GSocket code or NULL in wxBase. This
+ // is needed because networking classes are in their own library and so
+ // they can't directly call GUI functions (the same net library can be
+ // used in both GUI and base apps). To complicate it further, GUI library
+ // ("wxCore") doesn't depend on networking library and so only a functions
+ // table can be passed around
virtual GSocketGUIFunctionsTable* GetSocketGUIFunctionsTable() = 0;
#endif
// NB: test for __UNIX__ before __WXMAC__ as under Darwin we want to use the
// Unix code (and otherwise __UNIX__ wouldn't be defined)
-#if defined(__WXMSW__)
+#if defined(__WXPALMOS__)
+ #include "wx/palmos/apptbase.h"
+#elif defined(__WXMSW__)
#include "wx/msw/apptbase.h"
-#elif defined(__UNIX__)
+#elif defined(__UNIX__) && !defined(__EMX__)
#include "wx/unix/apptbase.h"
#elif defined(__WXMAC__)
#include "wx/mac/apptbase.h"
+#elif defined(__OS2__)
+ #include "wx/os2/apptbase.h"
#else // no platform-specific methods to add to wxAppTraits
// wxAppTraits must be a class because it was forward declared as class
class WXDLLIMPEXP_BASE wxAppTraits : public wxAppTraitsBase
// include the platform-specific version of the classes above
// ----------------------------------------------------------------------------
-#if defined(__WXMSW__)
+#if defined(__WXPALMOS__)
+ #include "wx/palmos/apptrait.h"
+#elif defined(__WXMSW__)
#include "wx/msw/apptrait.h"
-#elif defined(__UNIX__)
+#elif defined(__UNIX__) && !defined(__EMX__)
#include "wx/unix/apptrait.h"
#elif defined(__WXMAC__)
#include "wx/mac/apptrait.h"
-#else // no platform-specific methods to add to wxAppTraits
+#elif defined(__WXPM__)
+ #include "wx/os2/apptrait.h"
+#else
+ // at least, we need an implementation of GetToolkitInfo !
#if wxUSE_GUI
- typedef wxGUIAppTraitsBase wxGUIAppTraits;
+ class wxGUIAppTraits : public wxGUIAppTraitsBase
+ {
+ virtual wxToolkitInfo& GetToolkitInfo();
+ };
#endif // wxUSE_GUI
- typedef wxConsoleAppTraitsBase wxConsoleAppTraits;
+ class wxConsoleAppTraits: public wxConsoleAppTraitsBase
+ {
+ virtual wxToolkitInfo& GetToolkitInfo();
+ };
#endif // platform
#endif // _WX_APPTRAIT_H_