/////////////////////////////////////////////////////////////////////////////
-// Name: artstd.cpp
+// Name: src/gtk/artstd.cpp
// Purpose: stock wxArtProvider instance with native GTK+ stock icons
// Author: Vaclav Slavik
// Modified by:
#pragma hdrstop
#endif
-#if defined(__WXGTK20__) && !defined(__WXUNIVERSAL__)
+#if !defined(__WXUNIVERSAL__)
#include "wx/artprov.h"
-#include "wx/module.h"
-#include "wx/gtk/private.h"
+#ifndef WX_PRECOMP
+ #include "wx/module.h"
+#endif
+
+#include <gtk/gtkversion.h>
+#if GTK_CHECK_VERSION(2, 9, 0)
+ // gtk_object_sink
+ #undef GTK_DISABLE_DEPRECATED
+#endif
#include <gtk/gtk.h>
// compatibility with older GTK+ versions:
/*static*/ void wxArtProvider::InitNativeProvider()
{
- wxArtProvider::PushProvider(new wxGTK2ArtProvider);
+ Push(new wxGTK2ArtProvider);
}
// ----------------------------------------------------------------------------
if (size.x > s_sizes[i].x || size.y > s_sizes[i].y)
continue;
- unsigned dist = (size.x - s_sizes[i].x) * (size.x - s_sizes[i].x) +
+ unsigned dist = (size.x - s_sizes[i].x) * (size.x - s_sizes[i].x) +
(size.y - s_sizes[i].y) * (size.y - s_sizes[i].y);
if (dist == 0)
return s_sizes[i].icon;
gs_gtkStyle = gtk_rc_get_style(widget);
wxASSERT( gs_gtkStyle != NULL );
g_object_ref(gs_gtkStyle);
- gtk_widget_destroy(widget);
+ gtk_object_sink((GtkObject*)widget);
}
GtkIconSet *iconset = gtk_style_lookup_icon_set(gs_gtkStyle, stockid);
GdkPixbuf *pixbuf = CreateStockIcon(stockid, stocksize);
#ifdef __WXGTK24__
- if (!gtk_check_version(2,4,0))
+ if (!pixbuf && !gtk_check_version(2,4,0))
{
- if (!pixbuf)
- pixbuf = CreateThemeIcon(stockid, stocksize, size);
+ pixbuf = CreateThemeIcon(stockid, stocksize, size);
}
#endif
}
}
- if (!pixbuf)
- return wxNullBitmap;
-
wxBitmap bmp;
- bmp.SetWidth(gdk_pixbuf_get_width(pixbuf));
- bmp.SetHeight(gdk_pixbuf_get_height(pixbuf));
- bmp.SetPixbuf(pixbuf);
+ if (pixbuf != NULL)
+ bmp.SetPixbuf(pixbuf);
return bmp;
}
IMPLEMENT_DYNAMIC_CLASS(wxArtGtkModule, wxModule)
-#endif // defined(__WXGTK20__) && !defined(__WXUNIVERSAL__)
+#endif // !defined(__WXUNIVERSAL__)