X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/80fdcdb90ef779185492dab676d461fc34933312..7d6a4d96961eac84d05db8bb24c64d39003f6e54:/src/gtk/artgtk.cpp diff --git a/src/gtk/artgtk.cpp b/src/gtk/artgtk.cpp index 99142b5f15..17cc916e18 100644 --- a/src/gtk/artgtk.cpp +++ b/src/gtk/artgtk.cpp @@ -21,6 +21,8 @@ #endif #include "wx/artprov.h" + +#include #include "wx/gtk/private.h" // compatibility with older GTK+ versions: @@ -47,7 +49,7 @@ protected: /*static*/ void wxArtProvider::InitNativeProvider() { - Push(new wxGTK2ArtProvider); + PushBack(new wxGTK2ArtProvider); } // ---------------------------------------------------------------------------- @@ -203,7 +205,7 @@ GdkPixbuf *CreateStockIcon(const char *stockid, GtkIconSize size) // with "stock-id" representation (in addition to pixmap and pixbuf // ones) and would convert it to pixbuf when rendered. - GtkStyle* style = wxGTKPrivate::GetButtonWidget()->style; + GtkStyle* style = gtk_widget_get_style(wxGTKPrivate::GetButtonWidget()); GtkIconSet* iconset = gtk_style_lookup_icon_set(style, stockid); if (!iconset) @@ -259,7 +261,7 @@ wxIconBundle DoCreateIconBundle(const char *stockid, continue; wxIcon icon; - icon.SetPixbuf(pixbuf); + icon.CopyFromBitmap(wxBitmap(pixbuf)); bundle.AddIcon(icon); } @@ -296,28 +298,25 @@ wxBitmap wxGTK2ArtProvider::CreateBitmap(const wxArtID& id, } } - wxBitmap bmp; - if (pixbuf != NULL) - bmp.SetPixbuf(pixbuf); - - return bmp; + return wxBitmap(pixbuf); } wxIconBundle wxGTK2ArtProvider::CreateIconBundle(const wxArtID& id, const wxArtClient& WXUNUSED(client)) { + wxIconBundle bundle; const wxString stockid = wxArtIDToStock(id); // try to load the bundle as stock icon first - GtkStyle* style = wxGTKPrivate::GetButtonWidget()->style; + GtkStyle* style = gtk_widget_get_style(wxGTKPrivate::GetButtonWidget()); GtkIconSet* iconset = gtk_style_lookup_icon_set(style, stockid.utf8_str()); if ( iconset ) { GtkIconSize *sizes; gint n_sizes; gtk_icon_set_get_sizes(iconset, &sizes, &n_sizes); - wxIconBundle bundle = DoCreateIconBundle + bundle = DoCreateIconBundle ( stockid.utf8_str(), sizes, sizes + n_sizes, @@ -329,7 +328,9 @@ wxGTK2ArtProvider::CreateIconBundle(const wxArtID& id, // otherwise try icon themes #ifdef __WXGTK26__ +#ifndef __WXGTK3__ if ( !gtk_check_version(2,6,0) ) +#endif { gint *sizes = gtk_icon_theme_get_icon_sizes ( @@ -337,24 +338,23 @@ wxGTK2ArtProvider::CreateIconBundle(const wxArtID& id, stockid.utf8_str() ); if ( !sizes ) - return wxNullIconBundle; + return bundle; gint *last = sizes; while ( *last ) last++; - wxIconBundle bundle = DoCreateIconBundle + bundle = DoCreateIconBundle ( stockid.utf8_str(), sizes, last, &CreateThemeIcon ); g_free(sizes); - return bundle; } #endif // __WXGTK26__ - return wxNullIconBundle; + return bundle; } // ----------------------------------------------------------------------------