]> www.fi.muni.cz Git - evince.git/blobdiff - cut-n-paste/recent-files/egg-recent-util.c
Icons for a new sizes.
[evince.git] / cut-n-paste / recent-files / egg-recent-util.c
index 6780cd1ee02dcfd1deeacd16baa4720fd2f7c714..4597f03c2d7aa280910143036289e6841f73c190 100644 (file)
@@ -2,16 +2,19 @@
 #include <stdio.h>
 #include <string.h>
 #include <gtk/gtk.h>
-#include <time.h>
-#include <unistd.h>
-#include <sys/types.h>
 #ifndef USE_STABLE_LIBGNOMEUI
-#include <libgnomeui/gnome-icon-theme.h>
 #include <libgnomeui/gnome-icon-lookup.h>
 #endif
+#include <time.h>
+#include <unistd.h>
+#include <sys/types.h>
 #include <math.h>
 #include "egg-recent-util.h"
 
+#ifdef G_OS_WIN32
+#include <windows.h>
+#endif
+
 #define EGG_RECENT_UTIL_HOSTNAME_SIZE 512
 
 /* ripped out of gedit2 */
@@ -53,72 +56,26 @@ egg_recent_util_escape_underlines (const gchar* text)
        return g_string_free (str, FALSE);
 }
 
-#ifndef USE_STABLE_LIBGNOMEUI
-static GdkPixbuf *
-load_icon_file (char          *filename,
-               guint          nominal_size)
-{
-       GdkPixbuf *pixbuf, *scaled_pixbuf;
-       guint width, height;
-
-       pixbuf = gdk_pixbuf_new_from_file_at_size (filename, nominal_size, nominal_size, NULL);
-
-       if (pixbuf == NULL) {
-               return NULL;
-       }
-       
-       width = gdk_pixbuf_get_width (pixbuf); 
-       height = gdk_pixbuf_get_height (pixbuf);
-       /* if the icon is larger than the nominal size, scale down */
-       if (MAX (width, height) > nominal_size) {
-               if (width > height) {
-                       height = height * nominal_size / width;
-                       width = nominal_size;
-               } else {
-                       width = width * nominal_size / height;
-                       height = nominal_size;
-               }
-               scaled_pixbuf = gdk_pixbuf_scale_simple
-                       (pixbuf, width, height, GDK_INTERP_BILINEAR);
-               g_object_unref (pixbuf);
-               pixbuf = scaled_pixbuf;
-       }
-
-       return pixbuf;
-}
-
 GdkPixbuf *
-egg_recent_util_get_icon (GnomeIconTheme *theme, const gchar *uri,
+egg_recent_util_get_icon (GtkIconTheme *theme, const gchar *uri,
                          const gchar *mime_type, int size)
 {
+#ifndef USE_STABLE_LIBGNOMEUI
        gchar *icon;
-       gchar *filename;
-       const GnomeIconData *icon_data;
        GdkPixbuf *pixbuf;
        
        icon = gnome_icon_lookup (theme, NULL, uri, NULL, NULL,
                                  mime_type, 0, NULL);
-       
 
        g_return_val_if_fail (icon != NULL, NULL);
 
-       filename = gnome_icon_theme_lookup_icon (theme, icon,
-                                                size,
-                                                &icon_data,
-                                                NULL);
+       pixbuf = gtk_icon_theme_load_icon (theme, icon, size, 0, NULL);
        g_free (icon);
 
-       if (filename == NULL) {
-               return NULL;
-       }
-
-       pixbuf = load_icon_file (filename, size);
-       g_free (filename);
-       
-       
        return pixbuf;
+#endif
+       return NULL;
 }
-#endif /* !USE_STABLE_LIBGNOMEUI */
 
 gchar *
 egg_recent_util_get_unique_id (void)
@@ -128,7 +85,14 @@ egg_recent_util_get_unique_id (void)
        guint32 rand;
        int pid;
        
+#ifndef G_OS_WIN32
        gethostname (hostname, EGG_RECENT_UTIL_HOSTNAME_SIZE);
+#else
+       {
+               DWORD size = EGG_RECENT_UTIL_HOSTNAME_SIZE;
+               GetComputerName (hostname, &size);
+       }
+#endif
        
        time (&the_time);
        rand = g_random_int ();