X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/e766c8a9ad51ecf73e8f1641992f1007ee9e5e0a..c3aee5c154ce130ab9858453c9ae28f944565695:/include/wx/univ/theme.h?ds=sidebyside diff --git a/include/wx/univ/theme.h b/include/wx/univ/theme.h index a22293cfa1..62c0d53df5 100644 --- a/include/wx/univ/theme.h +++ b/include/wx/univ/theme.h @@ -8,13 +8,13 @@ // Created: 06.08.00 // RCS-ID: $Id$ // Copyright: (c) 2000 SciTech Software, Inc. (www.scitechsoft.com) -// Licence: wxWindows license +// Licence: wxWindows licence /////////////////////////////////////////////////////////////////////////////// #ifndef _WX_UNIV_THEME_H_ #define _WX_UNIV_THEME_H_ -#ifdef __GNUG__ +#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) #pragma interface "theme.h" #endif @@ -25,6 +25,7 @@ class WXDLLEXPORT wxRenderer; class WXDLLEXPORT wxColourScheme; class WXDLLEXPORT wxInputHandler; +class WXDLLEXPORT wxArtProvider; struct WXDLLEXPORT wxThemeInfo; class WXDLLEXPORT wxTheme @@ -51,6 +52,9 @@ public: // get the renderer implementing all the control-drawing operations in // this theme virtual wxRenderer *GetRenderer() = 0; + + // get the art provider to be used together with this theme + virtual wxArtProvider *GetArtProvider() = 0; // get the input handler of the given type virtual wxInputHandler *GetInputHandler(const wxString& handlerType) = 0; @@ -69,11 +73,7 @@ private: // the current theme static wxTheme *ms_theme; -#ifdef __MWERKS__ - friend class wxThemeInfo; -#else - friend wxThemeInfo; -#endif + friend struct WXDLLEXPORT wxThemeInfo; }; // ---------------------------------------------------------------------------- @@ -105,10 +105,10 @@ struct WXDLLEXPORT wxThemeInfo // without it, an over optimizing linker may discard the object module // containing the theme implementation entirely #define WX_USE_THEME(themename) \ - extern bool wxThemeUse##themename; \ + WXDLLEXPORT_DATA(extern bool) wxThemeUse##themename; \ static struct wxThemeUserFor##themename \ { \ - wxThemeUserFor##themename() { wxThemeUse##themename = TRUE; } \ + wxThemeUserFor##themename() { wxThemeUse##themename = true; } \ } wxThemeDoUse##themename // to declare a new theme, this macro must be used in the class declaration @@ -121,10 +121,10 @@ struct WXDLLEXPORT wxThemeInfo // and this one must be inserted in the source file #define WX_IMPLEMENT_THEME(classname, themename, themedesc) \ - bool wxThemeUse##themename = TRUE; \ + WXDLLEXPORT_DATA(bool) wxThemeUse##themename = true; \ wxTheme *wxCtorFor##themename() { return new classname; } \ wxThemeInfo classname::ms_info##themename(wxCtorFor##themename, \ - #themename, themedesc) + wxT( #themename ), themedesc) #endif // _WX_UNIV_THEME_H_