gimp r25195 - in trunk: . app/core app/widgets
- From: neo svn gnome org
- To: svn-commits-list gnome org
- Subject: gimp r25195 - in trunk: . app/core app/widgets
- Date: Mon, 24 Mar 2008 16:41:42 +0000 (GMT)
Author: neo
Date: Mon Mar 24 16:41:42 2008
New Revision: 25195
URL: http://svn.gnome.org/viewvc/gimp?rev=25195&view=rev
Log:
2008-03-24 Sven Neumann <sven gimp org>
* libgimpthumb/gimpthumbnail.c: don't reset the mime-type info
when we can't load a thumbnail.
* app/core/gimpimagefile.c (gimp_imagefile_get_new_pixbuf):
don't
set a stock-id depending on the state.
* app/widgets/gimpviewrendererimagefile.[ch]: removed commented
out hack that used to access semi-private API from
GtkFilesystem.
Instead lifted some code from GtkRecentManager that looks up
icons
by mime-type.
Modified:
trunk/ChangeLog
trunk/app/core/gimpimagefile.c
trunk/app/widgets/gimpviewrendererimagefile.c
trunk/app/widgets/gimpviewrendererimagefile.h
Modified: trunk/app/core/gimpimagefile.c
==============================================================================
--- trunk/app/core/gimpimagefile.c (original)
+++ trunk/app/core/gimpimagefile.c Mon Mar 24 16:41:42 2008
@@ -417,8 +417,6 @@
if (GIMP_OBJECT_CLASS (parent_class)->name_changed)
GIMP_OBJECT_CLASS (parent_class)->name_changed (object);
- gimp_viewable_set_stock_id (GIMP_VIEWABLE (imagefile), NULL);
-
gimp_thumbnail_set_uri (imagefile->thumbnail, gimp_object_get_name (object));
}
@@ -454,39 +452,11 @@
gint height)
{
GimpImagefile *imagefile = GIMP_IMAGEFILE (viewable);
- GdkPixbuf *pixbuf;
- const gchar *stock_id = NULL;
- if (! GIMP_OBJECT (imagefile)->name)
+ if (! gimp_object_get_name (GIMP_OBJECT (imagefile)))
return NULL;
- pixbuf = gimp_imagefile_load_thumb (imagefile, width, height);
-
- switch (imagefile->thumbnail->image_state)
- {
- case GIMP_THUMB_STATE_REMOTE:
- stock_id = "gtk-network";
- break;
-
- case GIMP_THUMB_STATE_FOLDER:
- stock_id = "gtk-directory";
- break;
-
- case GIMP_THUMB_STATE_SPECIAL:
- stock_id = "gtk-harddisk";
- break;
-
- case GIMP_THUMB_STATE_NOT_FOUND:
- stock_id = "gtk-dialog-question";
- break;
-
- default:
- break;
- }
-
- gimp_viewable_set_stock_id (GIMP_VIEWABLE (imagefile), stock_id);
-
- return pixbuf;
+ return gimp_imagefile_load_thumb (imagefile, width, height);
}
static gchar *
Modified: trunk/app/widgets/gimpviewrendererimagefile.c
==============================================================================
--- trunk/app/widgets/gimpviewrendererimagefile.c (original)
+++ trunk/app/widgets/gimpviewrendererimagefile.c Mon Mar 24 16:41:42 2008
@@ -35,14 +35,12 @@
#include "gimpviewrendererimagefile.h"
#include "gimpviewrenderer-frame.h"
-#ifdef ENABLE_FILE_SYSTEM_ICONS
-#define GTK_FILE_SYSTEM_ENABLE_UNSUPPORTED
-#include <gtk/gtkfilesystem.h>
-#endif
+static void gimp_view_renderer_imagefile_render (GimpViewRenderer *renderer,
+ GtkWidget *widget);
-static void gimp_view_renderer_imagefile_render (GimpViewRenderer *renderer,
- GtkWidget *widget);
+static GdkPixbuf * gimp_view_renderer_imagefile_get_icon (GimpImagefile *imagefile,
+ gint size);
G_DEFINE_TYPE (GimpViewRendererImagefile, gimp_view_renderer_imagefile,
@@ -62,9 +60,6 @@
static void
gimp_view_renderer_imagefile_init (GimpViewRendererImagefile *renderer)
{
-#ifdef ENABLE_FILE_SYSTEM_ICONS
- renderer->file_system = NULL;
-#endif
}
static void
@@ -75,30 +70,14 @@
renderer->width,
renderer->height);
-#ifdef ENABLE_FILE_SYSTEM_ICONS
- if (! pixbuf &&
- GIMP_VIEW_RENDERER_IMAGEFILE (renderer)->file_system)
+ if (! pixbuf)
{
- const gchar *uri;
+ GimpImagefile *imagefile = GIMP_IMAGEFILE (renderer->viewable);
- uri = gimp_object_get_name (GIMP_OBJECT (renderer->viewable));
- if (uri)
- {
- GtkFileSystem *file_system;
- GtkFilePath *path;
-
- file_system = GIMP_VIEW_RENDERER_IMAGEFILE (renderer)->file_system;
-
- path = gtk_file_system_uri_to_path (file_system, uri);
-
- pixbuf = gtk_file_system_render_icon (file_system, path, widget,
- MIN (renderer->width,
- renderer->height),
- NULL);
- gtk_file_path_free (path);
- }
+ pixbuf = gimp_view_renderer_imagefile_get_icon (imagefile,
+ MIN (renderer->width,
+ renderer->height));
}
-#endif /* ENABLE_FILE_SYSTEM_ICONS */
if (pixbuf)
{
@@ -112,3 +91,102 @@
gimp_view_renderer_default_render_stock (renderer, widget, stock_id);
}
}
+
+
+/* The code to get an icon for a mime-type is lifted from GtkRecentManager. */
+
+static GdkPixbuf *
+get_icon_for_mime_type (const char *mime_type,
+ gint pixel_size)
+{
+ GtkIconTheme *icon_theme;
+ const gchar *separator;
+ GString *icon_name;
+ GdkPixbuf *pixbuf;
+
+ separator = strchr (mime_type, '/');
+ if (! separator)
+ return NULL;
+
+ icon_theme = gtk_icon_theme_get_default ();
+
+ /* try with the three icon name variants for MIME types */
+
+ /* canonicalize MIME type: foo/x-bar -> foo-x-bar */
+ icon_name = g_string_new (NULL);
+ g_string_append_len (icon_name, mime_type, separator - mime_type);
+ g_string_append_c (icon_name, '-');
+ g_string_append (icon_name, separator + 1);
+ pixbuf = gtk_icon_theme_load_icon (icon_theme, icon_name->str,
+ pixel_size,
+ 0,
+ NULL);
+ g_string_free (icon_name, TRUE);
+ if (pixbuf)
+ return pixbuf;
+
+ /* canonicalize MIME type, and prepend "gnome-mime-" */
+ icon_name = g_string_new ("gnome-mime-");
+ g_string_append_len (icon_name, mime_type, separator - mime_type);
+ g_string_append_c (icon_name, '-');
+ g_string_append (icon_name, separator + 1);
+ pixbuf = gtk_icon_theme_load_icon (icon_theme, icon_name->str,
+ pixel_size,
+ 0,
+ NULL);
+ g_string_free (icon_name, TRUE);
+ if (pixbuf)
+ return pixbuf;
+
+ /* try the MIME family icon */
+ icon_name = g_string_new ("gnome-mime-");
+ g_string_append_len (icon_name, mime_type, separator - mime_type);
+ pixbuf = gtk_icon_theme_load_icon (icon_theme, icon_name->str,
+ pixel_size,
+ 0,
+ NULL);
+ g_string_free (icon_name, TRUE);
+
+ return pixbuf;
+}
+
+static GdkPixbuf *
+get_icon_fallback (const gchar *icon_name,
+ gint size)
+{
+ return gtk_icon_theme_load_icon (gtk_icon_theme_get_default (), icon_name,
+ size,
+ GTK_ICON_LOOKUP_USE_BUILTIN,
+ NULL);
+}
+
+static GdkPixbuf *
+gimp_view_renderer_imagefile_get_icon (GimpImagefile *imagefile,
+ gint size)
+{
+ GdkPixbuf *retval = NULL;
+
+ if (! gimp_object_get_name (GIMP_OBJECT (imagefile)))
+ return NULL;
+
+ if (imagefile->thumbnail->image_mimetype)
+ {
+ retval = get_icon_for_mime_type (imagefile->thumbnail->image_mimetype,
+ size);
+ }
+
+ if (! retval)
+ {
+ const gchar *icon_name = GTK_STOCK_FILE;
+
+ if (imagefile->thumbnail->image_state == GIMP_THUMB_STATE_FOLDER)
+ icon_name = GTK_STOCK_DIRECTORY;
+
+ retval = gtk_icon_theme_load_icon (gtk_icon_theme_get_default (),
+ icon_name, size,
+ GTK_ICON_LOOKUP_USE_BUILTIN,
+ NULL);
+ }
+
+ return retval;
+}
Modified: trunk/app/widgets/gimpviewrendererimagefile.h
==============================================================================
--- trunk/app/widgets/gimpviewrendererimagefile.h (original)
+++ trunk/app/widgets/gimpviewrendererimagefile.h Mon Mar 24 16:41:42 2008
@@ -25,8 +25,6 @@
#include "gimpviewrenderer.h"
-/* #define ENABLE_FILE_SYSTEM_ICONS 1 */
-
#define GIMP_TYPE_VIEW_RENDERER_IMAGEFILE (gimp_view_renderer_imagefile_get_type ())
#define GIMP_VIEW_RENDERER_IMAGEFILE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GIMP_TYPE_VIEW_RENDERER_IMAGEFILE, GimpViewRendererImagefile))
@@ -41,10 +39,6 @@
struct _GimpViewRendererImagefile
{
GimpViewRenderer parent_instance;
-
-#ifdef ENABLE_FILE_SYSTEM_ICONS
- gpointer file_system;
-#endif
};
struct _GimpViewRendererImagefileClass
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]