summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlexander Larsson <alexl@redhat.com>2008-01-29 15:51:58 +0000
committerAlexander Larsson <alexl@src.gnome.org>2008-01-29 15:51:58 +0000
commitd46c3ff4910c1d6518d1f44931e708cca3a29709 (patch)
treeb891bd015035619369aa8b888bd469ef3346150f
parent6fb59fee83e2233d6b22fa7c586b6a6ebb8551e2 (diff)
downloadgvfs-d46c3ff4910c1d6518d1f44931e708cca3a29709.tar.gz
Added. Added. Added. Add gconf based implementation of
2008-01-29 Alexander Larsson <alexl@redhat.com> * Makefile.am: * configure.ac: * gconf/Makefile.am: Added. * gconf/gapplookupgconf.[ch]: Added. * gconf/gconf-module.c: Added. Add gconf based implementation of g_app_info_get_default_for_uri_scheme () svn path=/trunk/; revision=1206
-rw-r--r--ChangeLog10
-rw-r--r--Makefile.am5
-rw-r--r--configure.ac24
-rw-r--r--gconf/Makefile.am33
-rw-r--r--gconf/gapplookupgconf.c192
-rw-r--r--gconf/gapplookupgconf.h53
-rw-r--r--gconf/gconf-module.c40
7 files changed, 354 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index b6829d04..d2b16d2a 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,15 @@
2008-01-29 Alexander Larsson <alexl@redhat.com>
+ * Makefile.am:
+ * configure.ac:
+ * gconf/Makefile.am: Added.
+ * gconf/gapplookupgconf.[ch]: Added.
+ * gconf/gconf-module.c: Added.
+ Add gconf based implementation of
+ g_app_info_get_default_for_uri_scheme ()
+
+2008-01-29 Alexander Larsson <alexl@redhat.com>
+
* hal/ghalvolumemonitor.c (g_hal_volume_monitor_class_init):
Remove setting prio/name
diff --git a/Makefile.am b/Makefile.am
index 42c5cfc4..ecdbf809 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -4,15 +4,14 @@ SUBDIRS = \
common \
client \
daemon \
+ gconf \
po \
programs \
test \
$(NULL)
if USE_HAL
-
SUBDIRS += hal
-
endif
DISTCHECK_CONFIGURE_FLAGS = --enable-gtk-doc
@@ -28,4 +27,4 @@ DISTCLEANFILES = \
intltool-extract \
intltool-merge \
intltool-update \
- $(NULL) \ No newline at end of file
+ $(NULL)
diff --git a/configure.ac b/configure.ac
index efa4d774..a9b01258 100644
--- a/configure.ac
+++ b/configure.ac
@@ -174,6 +174,28 @@ AC_SUBST(FUSE_CFLAGS)
AM_CONDITIONAL(USE_FUSE, [test "$msg_fuse" = "yes"])
dnl **********************
+dnl *** Check for GConf ***
+dnl **********************
+AC_ARG_ENABLE(gconf, [ --disable-gconf build without GConf support])
+msg_gconf=no
+GCONF_LIBS=
+GCONF_CFLAGS=
+
+if test "x$enable_gconf" != "xno"; then
+ PKG_CHECK_EXISTS(gconf-2.0, msg_gconf=yes)
+
+ if test "x$msg_gconf" == "xyes"; then
+ PKG_CHECK_MODULES(GCONF, gconf-2.0)
+ AC_DEFINE(HAVE_GCONF, 1, [Define to 1 if GConf is available])
+ fi
+fi
+
+AC_SUBST(GCONF_LIBS)
+AC_SUBST(GCONF_CFLAGS)
+
+AM_CONDITIONAL(USE_GCONF, [test "$msg_gconf" = "yes"])
+
+dnl **********************
dnl *** Check for HAL ***
dnl **********************
AC_ARG_ENABLE(hal, [ --disable-hal build without HAL support])
@@ -329,6 +351,7 @@ common/Makefile
client/Makefile
daemon/Makefile
hal/Makefile
+gconf/Makefile
programs/Makefile
test/Makefile
po/Makefile.in
@@ -341,5 +364,6 @@ echo "
Samba support: $msg_samba
FUSE support: $msg_fuse
CDDA support: $msg_cdda
+ GConf support: $msg_gconf
Use HAL for volume monitor: $msg_hal (with fast init path: $have_hal_fast_init)
"
diff --git a/gconf/Makefile.am b/gconf/Makefile.am
new file mode 100644
index 00000000..218767ad
--- /dev/null
+++ b/gconf/Makefile.am
@@ -0,0 +1,33 @@
+
+NULL =
+
+module_flags = -export_dynamic -avoid-version -module -no-undefined -export-symbols-regex '^g_io_module_(load|unload)'
+
+if USE_GCONF
+giomodules_LTLIBRARIES = libgiogconf.la
+endif
+
+giomodulesdir = $(libdir)/gio/modules
+
+libgiogconf_la_SOURCES = \
+ gapplookupgconf.c gapplookupgconf.h \
+ gconf-module.c \
+ $(NULL)
+
+libgiogconf_la_CFLAGS = \
+ -DG_LOG_DOMAIN=\"GVFS-GConf\" \
+ -I$(top_srcdir)/common \
+ $(GLIB_CFLAGS) \
+ $(GCONF_CFLAGS) \
+ -DGIO_MODULE_DIR=\"$(GIO_MODULE_DIR)\" \
+ -DG_DISABLE_DEPRECATED \
+ $(NULL)
+
+libgiogconf_la_LDFLAGS = \
+ $(module_flags) \
+ $(NULL)
+
+libgiogconf_la_LIBADD = \
+ $(GLIB_LIBS) \
+ $(GCONF_LIBS) \
+ $(NULL)
diff --git a/gconf/gapplookupgconf.c b/gconf/gapplookupgconf.c
new file mode 100644
index 00000000..30b2d636
--- /dev/null
+++ b/gconf/gapplookupgconf.c
@@ -0,0 +1,192 @@
+/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
+
+/* GIO - GLib Input, Output and Streaming Library
+ *
+ * Copyright (C) 2006-2007 Red Hat, Inc.
+ *
+ * This library 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.
+ *
+ * This library 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 this library; if not, write to the
+ * Free Software Foundation, Inc., 59 Temple Place, Suite 330,
+ * Boston, MA 02111-1307, USA.
+ *
+ * Author: Alexader Larsson <alexl@redhat.com>
+ */
+
+#include <config.h>
+
+#include <string.h>
+
+#include <glib.h>
+#include <glib/gi18n-lib.h>
+#include <gio/gio.h>
+#include <gconf/gconf-client.h>
+
+#include "gapplookupgconf.h"
+
+
+struct _GAppLookupGConf {
+ GObject parent;
+
+};
+
+static void lookup_iface_init (GDesktopAppInfoLookupIface *iface);
+static void g_app_lookup_gconf_finalize (GObject *object);
+
+#define _G_IMPLEMENT_INTERFACE_DYNAMIC(TYPE_IFACE, iface_init) { \
+ const GInterfaceInfo g_implement_interface_info = { \
+ (GInterfaceInitFunc) iface_init, NULL, NULL \
+ }; \
+ g_type_module_add_interface (type_module, g_define_type_id, TYPE_IFACE, &g_implement_interface_info); \
+}
+
+G_DEFINE_DYNAMIC_TYPE_EXTENDED (GAppLookupGConf, g_app_lookup_gconf, G_TYPE_OBJECT, 0,
+ _G_IMPLEMENT_INTERFACE_DYNAMIC (G_TYPE_DESKTOP_APP_INFO_LOOKUP,
+ lookup_iface_init))
+
+static void
+g_app_lookup_gconf_finalize (GObject *object)
+{
+ GAppLookupGConf *lookup;
+
+ lookup = G_APP_LOOKUP_GCONF (object);
+
+ if (G_OBJECT_CLASS (g_app_lookup_gconf_parent_class)->finalize)
+ (*G_OBJECT_CLASS (g_app_lookup_gconf_parent_class)->finalize) (object);
+}
+
+static GObject *
+g_app_lookup_gconf_constructor (GType type,
+ guint n_construct_properties,
+ GObjectConstructParam *construct_properties)
+{
+ GObject *object;
+ GAppLookupGConf *lookup;
+ GAppLookupGConfClass *klass;
+ GObjectClass *parent_class;
+
+ object = NULL;
+
+ /* Invoke parent constructor. */
+ klass = G_APP_LOOKUP_GCONF_CLASS (g_type_class_peek (G_TYPE_APP_LOOKUP_GCONF));
+ parent_class = G_OBJECT_CLASS (g_type_class_peek_parent (klass));
+ object = parent_class->constructor (type,
+ n_construct_properties,
+ construct_properties);
+
+ lookup = G_APP_LOOKUP_GCONF (object);
+
+ return object;
+}
+
+static void
+g_app_lookup_gconf_init (GAppLookupGConf *lookup)
+{
+}
+
+static void
+g_app_lookup_gconf_class_finalize (GAppLookupGConfClass *klass)
+{
+}
+
+
+static void
+g_app_lookup_gconf_class_init (GAppLookupGConfClass *klass)
+{
+ GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
+
+ gobject_class->constructor = g_app_lookup_gconf_constructor;
+ gobject_class->finalize = g_app_lookup_gconf_finalize;
+}
+
+#define GCONF_PATH_PREFIX "/desktop/gnome/url-handlers/"
+
+static GAppInfo *
+get_default_for_uri_scheme (GDesktopAppInfoLookup *lookup,
+ const char *uri_scheme)
+{
+ GAppInfo *appinfo;
+ GConfClient *client;
+ char *command_key, *enabled_key, *terminal_key, *command;
+ gboolean enabled, needs_terminal;
+ GAppInfoCreateFlags flags;
+
+ appinfo = NULL;
+
+ client = gconf_client_get_default ();
+
+ command_key = g_strconcat (GCONF_PATH_PREFIX,
+ uri_scheme,
+ "/command",
+ NULL);
+ command = gconf_client_get_string (client,
+ command_key,
+ NULL);
+ g_free (command_key);
+ if (command)
+ {
+ enabled_key = g_strconcat (GCONF_PATH_PREFIX,
+ uri_scheme,
+ "/enabled",
+ NULL);
+ enabled = gconf_client_get_bool (client,
+ enabled_key,
+ NULL);
+ g_free (enabled_key);
+
+ terminal_key = g_strconcat (GCONF_PATH_PREFIX,
+ uri_scheme,
+ "/needs_terminal",
+ NULL);
+ needs_terminal = gconf_client_get_bool (client,
+ terminal_key,
+ NULL);
+ g_free (terminal_key);
+
+ if (enabled)
+ {
+ if (g_str_has_suffix (command, "\"\%s\"") ||
+ g_str_has_suffix (command, "\'\%s\'"))
+ command[strlen (command) - 4] = 0;
+ else if (g_str_has_suffix (command, "\%s"))
+ command[strlen (command) - 2] = 0;
+
+ flags = G_APP_INFO_CREATE_SUPPORTS_URIS;
+ if (needs_terminal)
+ flags |= G_APP_INFO_CREATE_NEEDS_TERMINAL;
+ appinfo = g_app_info_create_from_commandline (command,
+ NULL,
+ flags,
+ NULL);
+ }
+ }
+
+ g_object_unref (client);
+
+ return appinfo;
+}
+
+static void
+lookup_iface_init (GDesktopAppInfoLookupIface *iface)
+{
+ iface->get_default_for_uri_scheme = get_default_for_uri_scheme;
+}
+
+void
+g_app_lookup_gconf_register (GIOModule *module)
+{
+ g_app_lookup_gconf_register_type (G_TYPE_MODULE (module));
+ g_io_extension_point_implement (G_DESKTOP_APP_INFO_LOOKUP_EXTENSION_POINT_NAME,
+ G_TYPE_APP_LOOKUP_GCONF,
+ "gconf",
+ 10);
+}
diff --git a/gconf/gapplookupgconf.h b/gconf/gapplookupgconf.h
new file mode 100644
index 00000000..dd04380c
--- /dev/null
+++ b/gconf/gapplookupgconf.h
@@ -0,0 +1,53 @@
+/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
+
+/* GIO - GLib Input, Output and Streaming Library
+ *
+ * Copyright (C) 2006-2007 Red Hat, Inc.
+ *
+ * This library 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.
+ *
+ * This library 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 this library; if not, write to the
+ * Free Software Foundation, Inc., 59 Temple Place, Suite 330,
+ * Boston, MA 02111-1307, USA.
+ *
+ * Author: Alexander Larsson <alexl@redhat.com>
+ */
+
+#ifndef __G_APP_LOOKUP_GCONF_H__
+#define __G_APP_LOOKUP_GCONF_H__
+
+#include <glib-object.h>
+#include <gio/gio.h>
+#include <gio/gdesktopappinfo.h>
+
+
+G_BEGIN_DECLS
+
+#define G_TYPE_APP_LOOKUP_GCONF (g_app_lookup_gconf_get_type ())
+#define G_APP_LOOKUP_GCONF(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), G_TYPE_APP_LOOKUP_GCONF, GAppLookupGConf))
+#define G_APP_LOOKUP_GCONF_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), G_TYPE_APP_LOOKUP_GCONF, GAppLookupGConfClass))
+#define G_IS_APP_LOOKUP_GCONF(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), G_TYPE_APP_LOOKUP_GCONF))
+#define G_IS_APP_LOOKUP_GCONF_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), G_TYPE_APP_LOOKUP_GCONF))
+
+typedef struct _GAppLookupGConf GAppLookupGConf;
+typedef struct _GAppLookupGConfClass GAppLookupGConfClass;
+
+struct _GAppLookupGConfClass {
+ GObjectClass parent_class;
+};
+
+GType g_app_lookup_gconf_get_type (void) G_GNUC_CONST;
+void g_app_lookup_gconf_register (GIOModule *module);
+
+G_END_DECLS
+
+#endif /* __G_APP_LOOKUP_GCONF_H__ */
diff --git a/gconf/gconf-module.c b/gconf/gconf-module.c
new file mode 100644
index 00000000..f60484b7
--- /dev/null
+++ b/gconf/gconf-module.c
@@ -0,0 +1,40 @@
+/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
+
+/* GIO - GLib Input, Output and Streaming Library
+ *
+ * Copyright (C) 2006-2007 Red Hat, Inc.
+ *
+ * This library 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.
+ *
+ * This library 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 this library; if not, write to the
+ * Free Software Foundation, Inc., 59 Temple Place, Suite 330,
+ * Boston, MA 02111-1307, USA.
+ *
+ * Author: David Zeuthen <davidz@redhat.com>
+ */
+
+#include <glib.h>
+#include <gmodule.h>
+#include <gio/gio.h>
+
+#include "gapplookupgconf.h"
+
+void
+g_io_module_load (GIOModule *module)
+{
+ g_app_lookup_gconf_register (module);
+}
+
+void
+g_io_module_unload (GIOModule *module)
+{
+}