471 lines
8.7 KiB
C
471 lines
8.7 KiB
C
/*
|
|
* This file is part of libslab.
|
|
*
|
|
* Copyright (c) 2006 Novell, Inc.
|
|
*
|
|
* Libslab is free software; you can redistribute it and/or modify it under the
|
|
* terms of the GNU Lesser General Public License as published by the Free
|
|
* Software Foundation; either version 2 of the License, or (at your option)
|
|
* any later version.
|
|
*
|
|
* Libslab is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
* FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for
|
|
* more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with libslab; if not, write to the Free Software Foundation, Inc., 51
|
|
* Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
|
|
#include "slab-gnome-util.h"
|
|
#include "libslab-utils.h"
|
|
|
|
#include <gconf/gconf-client.h>
|
|
#include <gio/gio.h>
|
|
#include <string.h>
|
|
|
|
gboolean
|
|
get_slab_gconf_bool (const gchar * key)
|
|
{
|
|
GConfClient *gconf_client;
|
|
GError *error;
|
|
|
|
gboolean value;
|
|
|
|
gconf_client = gconf_client_get_default ();
|
|
error = NULL;
|
|
|
|
value = gconf_client_get_bool (gconf_client, key, &error);
|
|
|
|
g_object_unref (gconf_client);
|
|
|
|
if (error)
|
|
{
|
|
g_warning ("error accessing %s [%s]\n", key, error->message);
|
|
g_error_free (error);
|
|
}
|
|
|
|
return value;
|
|
}
|
|
|
|
gint
|
|
get_slab_gconf_int (const gchar * key)
|
|
{
|
|
GConfClient *gconf_client;
|
|
GError *error;
|
|
|
|
gint value;
|
|
|
|
gconf_client = gconf_client_get_default ();
|
|
error = NULL;
|
|
|
|
value = gconf_client_get_int (gconf_client, key, &error);
|
|
|
|
g_object_unref (gconf_client);
|
|
if (error)
|
|
{
|
|
g_warning ("error accessing %s [%s]\n", key, error->message);
|
|
g_error_free (error);
|
|
}
|
|
|
|
return value;
|
|
}
|
|
|
|
gchar *
|
|
get_slab_gconf_string (const gchar * key)
|
|
{
|
|
GConfClient *gconf_client;
|
|
GError *error;
|
|
|
|
gchar *value;
|
|
|
|
gconf_client = gconf_client_get_default ();
|
|
error = NULL;
|
|
|
|
value = gconf_client_get_string (gconf_client, key, &error);
|
|
|
|
g_object_unref (gconf_client);
|
|
if (error)
|
|
{
|
|
g_warning ("error accessing %s [%s]\n", key, error->message);
|
|
g_error_free (error);
|
|
}
|
|
|
|
return value;
|
|
}
|
|
|
|
void
|
|
free_list_of_strings (GList * string_list)
|
|
{
|
|
g_assert (string_list != NULL);
|
|
g_list_foreach (string_list, (GFunc) g_free, NULL);
|
|
g_list_free (string_list);
|
|
}
|
|
|
|
void
|
|
free_slab_gconf_slist_of_strings (GSList * string_list)
|
|
{
|
|
g_assert (string_list != NULL);
|
|
g_slist_foreach (string_list, (GFunc) g_free, NULL);
|
|
g_slist_free (string_list);
|
|
}
|
|
|
|
GSList *
|
|
get_slab_gconf_slist (const gchar * key)
|
|
{
|
|
GConfClient *gconf_client;
|
|
GError *error;
|
|
|
|
GSList *value;
|
|
|
|
gconf_client = gconf_client_get_default ();
|
|
error = NULL;
|
|
|
|
value = gconf_client_get_list (gconf_client, key, GCONF_VALUE_STRING, &error);
|
|
|
|
g_object_unref (gconf_client);
|
|
if (error)
|
|
{
|
|
g_warning ("error accessing %s [%s]\n", key, error->message);
|
|
|
|
g_error_free (error);
|
|
}
|
|
|
|
return value;
|
|
}
|
|
|
|
GnomeDesktopItem *
|
|
load_desktop_item_from_gconf_key (const gchar * key)
|
|
{
|
|
GnomeDesktopItem *item;
|
|
gchar *id = get_slab_gconf_string (key);
|
|
|
|
if (!id)
|
|
return NULL;
|
|
|
|
item = load_desktop_item_from_unknown (id);
|
|
g_free (id);
|
|
return item;
|
|
}
|
|
|
|
GnomeDesktopItem *
|
|
load_desktop_item_from_unknown (const gchar *id)
|
|
{
|
|
GnomeDesktopItem *item;
|
|
gchar *basename;
|
|
|
|
GError *error = NULL;
|
|
|
|
|
|
item = gnome_desktop_item_new_from_uri (id, 0, &error);
|
|
|
|
if (! error)
|
|
return item;
|
|
else {
|
|
g_error_free (error);
|
|
error = NULL;
|
|
}
|
|
|
|
item = gnome_desktop_item_new_from_file (id, 0, &error);
|
|
|
|
if (! error)
|
|
return item;
|
|
else {
|
|
g_error_free (error);
|
|
error = NULL;
|
|
}
|
|
|
|
item = gnome_desktop_item_new_from_basename (id, 0, &error);
|
|
|
|
if (! error)
|
|
return item;
|
|
else {
|
|
g_error_free (error);
|
|
error = NULL;
|
|
}
|
|
|
|
basename = g_strrstr (id, "/");
|
|
|
|
if (basename) {
|
|
basename++;
|
|
|
|
item = gnome_desktop_item_new_from_basename (basename, 0, &error);
|
|
|
|
if (! error)
|
|
return item;
|
|
else {
|
|
g_error_free (error);
|
|
error = NULL;
|
|
}
|
|
}
|
|
|
|
return NULL;
|
|
}
|
|
|
|
gchar *
|
|
get_package_name_from_desktop_item (GnomeDesktopItem * desktop_item)
|
|
{
|
|
gchar *argv[6];
|
|
gchar *package_name;
|
|
gint retval;
|
|
GError *error;
|
|
|
|
argv[0] = "rpm";
|
|
argv[1] = "-qf";
|
|
argv[2] = "--qf";
|
|
argv[3] = "%{NAME}";
|
|
argv[4] = g_filename_from_uri (gnome_desktop_item_get_location (desktop_item), NULL, NULL);
|
|
argv[5] = NULL;
|
|
|
|
error = NULL;
|
|
|
|
if (!g_spawn_sync (NULL, argv, NULL, G_SPAWN_SEARCH_PATH, NULL, NULL, &package_name, NULL,
|
|
&retval, &error))
|
|
{
|
|
g_warning ("error: [%s]\n", error->message);
|
|
g_error_free (error);
|
|
retval = -1;
|
|
}
|
|
|
|
g_free (argv[4]);
|
|
|
|
if (!retval)
|
|
return package_name;
|
|
else
|
|
return NULL;
|
|
}
|
|
|
|
gboolean
|
|
open_desktop_item_exec (GnomeDesktopItem * desktop_item)
|
|
{
|
|
GError *error = NULL;
|
|
|
|
if (!desktop_item)
|
|
return FALSE;
|
|
|
|
gnome_desktop_item_launch (desktop_item, NULL, GNOME_DESKTOP_ITEM_LAUNCH_ONLY_ONE, &error);
|
|
|
|
if (error)
|
|
{
|
|
g_warning ("error launching %s [%s]\n",
|
|
gnome_desktop_item_get_location (desktop_item), error->message);
|
|
|
|
g_error_free (error);
|
|
return FALSE;
|
|
}
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
gboolean
|
|
open_desktop_item_help (GnomeDesktopItem * desktop_item)
|
|
{
|
|
const gchar *doc_path;
|
|
gchar *help_uri;
|
|
|
|
GError *error;
|
|
|
|
if (!desktop_item)
|
|
return FALSE;
|
|
|
|
doc_path = gnome_desktop_item_get_string (desktop_item, "DocPath");
|
|
|
|
if (doc_path)
|
|
{
|
|
help_uri = g_strdup_printf ("ghelp:%s", doc_path);
|
|
|
|
error = NULL;
|
|
if (!gtk_show_uri (libslab_get_current_screen (), help_uri, gtk_get_current_event_time (), &error))
|
|
{
|
|
g_warning ("error opening %s [%s]\n", help_uri, error->message);
|
|
|
|
g_free (help_uri);
|
|
g_error_free (error);
|
|
return FALSE;
|
|
}
|
|
|
|
g_free (help_uri);
|
|
}
|
|
else
|
|
return FALSE;
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
gboolean
|
|
desktop_item_is_in_main_menu (GnomeDesktopItem * desktop_item)
|
|
{
|
|
return desktop_uri_is_in_main_menu (gnome_desktop_item_get_location (desktop_item));
|
|
}
|
|
|
|
gboolean
|
|
desktop_uri_is_in_main_menu (const gchar * uri)
|
|
{
|
|
GSList *app_list;
|
|
|
|
GSList *node;
|
|
gint offset;
|
|
gint uri_len;
|
|
gboolean found = FALSE;
|
|
|
|
app_list = get_slab_gconf_slist (SLAB_USER_SPECIFIED_APPS_KEY);
|
|
|
|
if (!app_list)
|
|
return FALSE;
|
|
|
|
uri_len = strlen (uri);
|
|
|
|
for (node = app_list; node; node = node->next)
|
|
{
|
|
offset = uri_len - strlen ((gchar *) node->data);
|
|
|
|
if (offset < 0)
|
|
offset = 0;
|
|
|
|
if (!strcmp (&uri[offset], (gchar *) node->data))
|
|
{
|
|
found = TRUE;
|
|
break;
|
|
}
|
|
}
|
|
|
|
free_slab_gconf_slist_of_strings (app_list);
|
|
return found;
|
|
}
|
|
|
|
gint
|
|
desktop_item_location_compare (gconstpointer a_obj, gconstpointer b_obj)
|
|
{
|
|
const gchar *a;
|
|
const gchar *b;
|
|
|
|
gint offset;
|
|
|
|
a = (const gchar *) a_obj;
|
|
b = (const gchar *) b_obj;
|
|
|
|
offset = strlen (a) - strlen (b);
|
|
|
|
if (offset > 0)
|
|
return strcmp (&a[offset], b);
|
|
else if (offset < 0)
|
|
return strcmp (a, &b[-offset]);
|
|
else
|
|
return strcmp (a, b);
|
|
}
|
|
|
|
gboolean
|
|
slab_load_image (GtkImage * image, GtkIconSize size, const gchar * image_id)
|
|
{
|
|
GdkPixbuf *pixbuf;
|
|
gint width;
|
|
gint height;
|
|
|
|
gchar *id;
|
|
|
|
if (!image_id)
|
|
return FALSE;
|
|
|
|
id = g_strdup (image_id);
|
|
|
|
gtk_icon_size_lookup (size, &width, &height);
|
|
|
|
if (g_path_is_absolute (id))
|
|
pixbuf = gdk_pixbuf_new_from_file_at_size (id, width, height, NULL);
|
|
else
|
|
{
|
|
if ( /* file extensions are not copesetic with loading by "name" */
|
|
g_str_has_suffix (id, ".png") ||
|
|
g_str_has_suffix (id, ".svg") ||
|
|
g_str_has_suffix (id, ".xpm")
|
|
)
|
|
|
|
id[strlen (id) - 4] = '\0';
|
|
|
|
pixbuf = gtk_icon_theme_load_icon (gtk_icon_theme_get_default (), id, width, 0,
|
|
NULL);
|
|
}
|
|
|
|
if (pixbuf)
|
|
{
|
|
gtk_image_set_from_pixbuf (image, pixbuf);
|
|
|
|
g_object_unref (pixbuf);
|
|
|
|
g_free (id);
|
|
|
|
return TRUE;
|
|
}
|
|
else
|
|
{ /* This will make it show the "broken image" icon */
|
|
gtk_image_set_from_file (image, id);
|
|
|
|
g_free (id);
|
|
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
gchar *
|
|
string_replace_once (const gchar * str_template, const gchar * key, const gchar * value)
|
|
{
|
|
GString *str_built;
|
|
gint pivot;
|
|
|
|
pivot = strstr (str_template, key) - str_template;
|
|
|
|
str_built = g_string_new_len (str_template, pivot);
|
|
g_string_append (str_built, value);
|
|
g_string_append (str_built, &str_template[pivot + strlen (key)]);
|
|
|
|
return g_string_free (str_built, FALSE);
|
|
}
|
|
|
|
void
|
|
spawn_process (const gchar *command)
|
|
{
|
|
gchar **argv;
|
|
GError *error = NULL;
|
|
|
|
if (!command || strlen (command) < 1)
|
|
return;
|
|
|
|
argv = g_strsplit (command, " ", -1);
|
|
|
|
g_spawn_async (NULL, argv, NULL, G_SPAWN_SEARCH_PATH, NULL, NULL, NULL, &error);
|
|
|
|
if (error)
|
|
{
|
|
g_warning ("error spawning [%s]: [%s]\n", command, error->message);
|
|
|
|
g_error_free (error);
|
|
}
|
|
|
|
g_strfreev (argv);
|
|
}
|
|
|
|
void
|
|
copy_file (const gchar * src_uri, const gchar * dst_uri)
|
|
{
|
|
GFile *src;
|
|
GFile *dst;
|
|
GError *error = NULL;
|
|
gboolean res;
|
|
|
|
src = g_file_new_for_uri (src_uri);
|
|
dst = g_file_new_for_uri (dst_uri);
|
|
|
|
res = g_file_copy (src, dst,
|
|
G_FILE_COPY_NONE,
|
|
NULL, NULL, NULL, &error);
|
|
|
|
if (!res)
|
|
{
|
|
g_warning ("error copying [%s] to [%s]: %s.", src_uri, dst_uri, error->message);
|
|
g_error_free (error);
|
|
}
|
|
|
|
g_object_unref (src);
|
|
g_object_unref (dst);
|
|
}
|