X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/62e68ee3c686986f7adc39cbd5b238a1ec7386e0..ce5abbf9f5dc0208d9fbc91ad48101f7777299ea:/src/gtk/artgtk.cpp diff --git a/src/gtk/artgtk.cpp b/src/gtk/artgtk.cpp index 33718756ea..d31eb8cd5f 100644 --- a/src/gtk/artgtk.cpp +++ b/src/gtk/artgtk.cpp @@ -57,10 +57,10 @@ protected: namespace { -const wxScopedCharBuffer wxArtIDToStock(const wxArtID& id) +wxString wxArtIDToStock(const wxArtID& id) { #define ART(wxid, gtkid) \ - if (id == wxid) return wxScopedCharBuffer::CreateNonOwned(gtkid); + if (id == wxid) return gtkid; ART(wxART_ERROR, GTK_STOCK_DIALOG_ERROR) ART(wxART_INFORMATION, GTK_STOCK_DIALOG_INFO) @@ -113,6 +113,7 @@ const wxScopedCharBuffer wxArtIDToStock(const wxArtID& id) ART(wxART_UNDO, GTK_STOCK_UNDO) ART(wxART_REDO, GTK_STOCK_REDO) + ART(wxART_CLOSE, GTK_STOCK_CLOSE) ART(wxART_QUIT, GTK_STOCK_QUIT) ART(wxART_FIND, GTK_STOCK_FIND) @@ -123,7 +124,7 @@ const wxScopedCharBuffer wxArtIDToStock(const wxArtID& id) // allow passing GTK+ stock IDs to wxArtProvider -- if a recognized wx // ID wasn't found, pass it to GTK+ in the hope it is a GTK+ or theme // icon name: - return id.mb_str(); + return id; } GtkIconSize ArtClientToIconSize(const wxArtClient& client) @@ -266,7 +267,7 @@ wxBitmap wxGTK2ArtProvider::CreateBitmap(const wxArtID& id, const wxArtClient& client, const wxSize& size) { - const wxScopedCharBuffer stockid = wxArtIDToStock(id); + const wxString stockid = wxArtIDToStock(id); GtkIconSize stocksize = (size == wxDefaultSize) ? ArtClientToIconSize(client) : @@ -275,7 +276,7 @@ wxBitmap wxGTK2ArtProvider::CreateBitmap(const wxArtID& id, if (stocksize == GTK_ICON_SIZE_INVALID) stocksize = GTK_ICON_SIZE_BUTTON; - GdkPixbuf *pixbuf = CreateGtkIcon(stockid, stocksize, size); + GdkPixbuf *pixbuf = CreateGtkIcon(stockid.utf8_str(), stocksize, size); if (pixbuf && size != wxDefaultSize && (size.x != gdk_pixbuf_get_width(pixbuf) || @@ -301,11 +302,11 @@ wxIconBundle wxGTK2ArtProvider::CreateIconBundle(const wxArtID& id, const wxArtClient& WXUNUSED(client)) { - const wxScopedCharBuffer stockid = wxArtIDToStock(id); + const wxString stockid = wxArtIDToStock(id); // try to load the bundle as stock icon first GtkStyle* style = wxGTKPrivate::GetButtonWidget()->style; - GtkIconSet* iconset = gtk_style_lookup_icon_set(style, stockid); + GtkIconSet* iconset = gtk_style_lookup_icon_set(style, stockid.utf8_str()); if ( iconset ) { GtkIconSize *sizes; @@ -313,7 +314,7 @@ wxGTK2ArtProvider::CreateIconBundle(const wxArtID& id, gtk_icon_set_get_sizes(iconset, &sizes, &n_sizes); wxIconBundle bundle = DoCreateIconBundle ( - stockid, + stockid.utf8_str(), sizes, sizes + n_sizes, &CreateStockIcon ); @@ -328,7 +329,7 @@ wxGTK2ArtProvider::CreateIconBundle(const wxArtID& id, gint *sizes = gtk_icon_theme_get_icon_sizes ( gtk_icon_theme_get_default(), - stockid + stockid.utf8_str() ); if ( !sizes ) return wxNullIconBundle; @@ -339,7 +340,7 @@ wxGTK2ArtProvider::CreateIconBundle(const wxArtID& id, wxIconBundle bundle = DoCreateIconBundle ( - stockid, + stockid.utf8_str(), sizes, last, &CreateThemeIcon );