[gnome-menus/wip/gobject-review: 8/38] Convert to GObject, drop static Python bindings
- From: Vincent Untz <vuntz src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-menus/wip/gobject-review: 8/38] Convert to GObject, drop static Python bindings
- Date: Sun, 12 Jun 2011 09:59:55 +0000 (UTC)
commit 37a08aea4b0a788904d9360d0bec93ad2ca21b58
Author: Colin Walters <walters verbum org>
Date: Sun Apr 17 07:50:19 2011 -0400
Convert to GObject, drop static Python bindings
GMenuTree is now a GObject. Drop the static Python bindings, since
introspection gives us coverage of most of the API now.
https://bugzilla.gnome.org/show_bug.cgi?id=647968
Makefile.am | 6 +-
configure.ac | 37 +-
libmenu/gmenu-tree.c | 152 +++--
libmenu/gmenu-tree.h | 26 +-
libmenu/menu-monitor.c | 9 -
python/Makefile.am | 20 -
python/gmenu.c | 1883 ------------------------------------------------
util/gnome-menus-ls.py | 2 +-
util/test-menu-spec.c | 4 +-
9 files changed, 122 insertions(+), 2017 deletions(-)
---
diff --git a/Makefile.am b/Makefile.am
index 565ab87..b1a66e6 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -1,12 +1,10 @@
SUBDIRS = libmenu desktop-directories layout util po
-if HAVE_PYTHON
-SUBDIRS += python simple-editor
-endif
+SUBDIRS += simple-editor
ACLOCAL_AMFLAGS = -I m4 ${ACLOCAL_FLAGS}
-DISTCHECK_CONFIGURE_FLAGS = --enable-introspection --enable-python
+DISTCHECK_CONFIGURE_FLAGS = --enable-introspection
EXTRA_DIST = \
HACKING \
diff --git a/configure.ac b/configure.ac
index e9361aa..65bdccb 100644
--- a/configure.ac
+++ b/configure.ac
@@ -72,39 +72,8 @@ else
fi
AC_SUBST(DEBUG_CFLAGS)
-AC_ARG_ENABLE(python,
- [AC_HELP_STRING([--enable-python],
- [build python bindings @<:@default=auto@:>@])],
- [enable_deprecations=$enableval],
- [enable_deprecations=auto])
-
-# Detect if we can build Python bindings (need python and python headers)
-if test "x$enable_python" = "xno" ; then
- have_python=no
-else
- AC_MSG_NOTICE([Checking to see if we can build Python bindings])
- have_python=no
- AM_PATH_PYTHON(2.3)
-
- if test "x$PYTHON" = "x" ; then
- AC_MSG_WARN([Python not found])
- else
- AM_CHECK_PYTHON_HEADERS(have_python_headers=yes, have_python_headers=no)
- if test "x$have_python_headers" = "xyes" ; then
- have_python=yes
- fi
- fi
-
- if test "x$have_python" = "xno" ; then
- if test "x$enable_python" = "xyes" ; then
- AC_MSG_ERROR([Building python explicitly requested, but can't build python bindings])
- else
- AC_MSG_WARN([Couldn't find the Python headers, not building Python bindings])
- fi
- fi
-fi
-
-AM_CONDITIONAL(HAVE_PYTHON, test x$have_python = xyes)
+AM_PATH_PYTHON(2.3)
+AM_CONDITIONAL(HAVE_PYTHON, test x$PYTHON != xyes)
# Because of the way Python implements polymorphism, we get the following warning:
# "warning: dereferencing type-punned pointer will break strict-aliasing rules"
@@ -136,7 +105,6 @@ libmenu/libgnome-menu-uninstalled.pc
layout/Makefile
desktop-directories/Makefile
util/Makefile
-python/Makefile
simple-editor/Makefile
simple-editor/GMenuSimpleEditor/Makefile
po/Makefile.in
@@ -165,7 +133,6 @@ echo "
Use *_DISABLE_DEPRECATED: ${enable_deprecation_flags}
Turn on debugging: ${enable_debug}
- Build python bindings: ${have_python}
Build introspection support: ${found_introspection}
"
diff --git a/libmenu/gmenu-tree.c b/libmenu/gmenu-tree.c
index 7d709f9..f8e01ea 100644
--- a/libmenu/gmenu-tree.c
+++ b/libmenu/gmenu-tree.c
@@ -29,9 +29,24 @@
#include "menu-util.h"
#include "canonicalize.h"
-struct GMenuTree
+enum {
+ PROP_0,
+
+ PROP_NAME,
+ PROP_FLAGS
+};
+
+/* Signals */
+enum
+{
+ LAST_SIGNAL
+};
+
+static guint gmenu_tree_signals [LAST_SIGNAL] = { 0 };
+
+struct _GMenuTree
{
- guint refcount;
+ GObject parent_instance;
char *basename;
char *canonical_path;
@@ -43,14 +58,11 @@ struct GMenuTree
MenuLayoutNode *layout;
GMenuTreeDirectory *root;
- GSList *monitors;
-
- gpointer user_data;
- GDestroyNotify dnotify;
-
guint canonical : 1;
};
+G_DEFINE_TYPE (GMenuTree, gmenu_tree, G_TYPE_OBJECT)
+
typedef struct
{
GMenuTreeChangedFunc callback;
@@ -419,45 +431,61 @@ gmenu_tree_force_recanonicalize (GMenuTree *tree)
* Returns: (transfer full): A new #GMenuTree instance
*/
GMenuTree *
-gmenu_tree_new (const char *menu_file,
+gmenu_tree_new (const char *name,
GMenuTreeFlags flags)
{
- GMenuTree *tree;
+ g_return_val_if_fail (name != NULL, NULL);
- g_return_val_if_fail (menu_file != NULL, NULL);
-
- tree = g_new0 (GMenuTree, 1);
- tree->flags = flags;
- tree->refcount = 1;
- tree->basename = g_strdup (menu_file);
-
- return tree;
+ return g_object_new (GMENU_TYPE_TREE, "name", name, "flags", flags, NULL);
}
-GMenuTree *
-gmenu_tree_ref (GMenuTree *tree)
+static void
+gmenu_tree_set_property(GObject *object,
+ guint prop_id,
+ const GValue *value,
+ GParamSpec *pspec)
{
- g_return_val_if_fail (tree != NULL, NULL);
- g_return_val_if_fail (tree->refcount > 0, NULL);
+ GMenuTree *self = GMENU_TREE (object);
- tree->refcount++;
+ switch (prop_id)
+ {
+ case PROP_NAME:
+ self->basename = g_value_dup_string (value);
+ break;
- return tree;
+ case PROP_FLAGS:
+ self->flags = g_value_get_flags (value);
+ break;
+
+ default:
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
+ break;
+ }
}
-void
-gmenu_tree_unref (GMenuTree *tree)
+static void
+gmenu_tree_get_property(GObject *object,
+ guint prop_id,
+ GValue *value,
+ GParamSpec *pspec)
{
- g_return_if_fail (tree != NULL);
- g_return_if_fail (tree->refcount >= 1);
+ GMenuTree *self = GMENU_TREE (object);
- if (--tree->refcount > 0)
- return;
+ switch (prop_id)
+ {
+ case PROP_NAME:
+ g_value_set_string (value, self->basename);
+ break;
+ default:
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
+ break;
+ }
+}
- if (tree->dnotify)
- tree->dnotify (tree->user_data);
- tree->user_data = NULL;
- tree->dnotify = NULL;
+static void
+gmenu_tree_finalize (GObject *object)
+{
+ GMenuTree *tree = GMENU_TREE (object);
gmenu_tree_force_recanonicalize (tree);
@@ -469,35 +497,49 @@ gmenu_tree_unref (GMenuTree *tree)
g_free (tree->canonical_path);
tree->canonical_path = NULL;
- g_slist_foreach (tree->monitors, (GFunc) g_free, NULL);
- g_slist_free (tree->monitors);
- tree->monitors = NULL;
-
- g_free (tree);
+ G_OBJECT_CLASS (gmenu_tree_parent_class)->finalize (object);
}
-void
-gmenu_tree_set_user_data (GMenuTree *tree,
- gpointer user_data,
- GDestroyNotify dnotify)
+static void
+gmenu_tree_init (GMenuTree *self)
{
- g_return_if_fail (tree != NULL);
-
- if (tree->dnotify != NULL)
- tree->dnotify (tree->user_data);
-
- tree->dnotify = dnotify;
- tree->user_data = user_data;
}
-gpointer
-gmenu_tree_get_user_data (GMenuTree *tree)
+static void
+gmenu_tree_class_init (GMenuTreeClass *klass)
{
- g_return_val_if_fail (tree != NULL, NULL);
+ GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
+
+ gobject_class->get_property = gmenu_tree_get_property;
+ gobject_class->set_property = gmenu_tree_set_property;
+ gobject_class->finalize = gmenu_tree_finalize;
+
+ /**
+ * GMenuTree:name
+ *
+ * The name of the menu file; must be a relative path. See
+ * the Desktop Menu specification.
+ */
+ g_object_class_install_property (gobject_class,
+ PROP_NAME,
+ g_param_spec_string ("name", "", "",
+ NULL,
+ G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY));
+ /**
+ * GMenuTree:flags
+ *
+ * Flags controlling the content of the menu.
+ */
+ g_object_class_install_property (gobject_class,
+ PROP_FLAGS,
+ g_param_spec_flags ("flags", "", "",
+ GMENU_TYPE_TREE_FLAGS,
+ GMENU_TREE_FLAGS_NONE,
+ G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY));
- return tree->user_data;
}
+
const char *
gmenu_tree_get_menu_file (GMenuTree *tree)
{
@@ -825,7 +867,7 @@ gmenu_tree_directory_get_tree (GMenuTreeDirectory *directory)
root = (GMenuTreeDirectoryRoot *) directory;
if (root->tree)
- gmenu_tree_ref (root->tree);
+ g_object_ref (root->tree);
return root->tree;
}
diff --git a/libmenu/gmenu-tree.h b/libmenu/gmenu-tree.h
index 755fc6f..825b025 100644
--- a/libmenu/gmenu-tree.h
+++ b/libmenu/gmenu-tree.h
@@ -28,7 +28,23 @@
G_BEGIN_DECLS
-typedef struct GMenuTree GMenuTree;
+#define GMENU_TYPE_TREE (gmenu_tree_get_type ())
+#define GMENU_TREE(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), GMENU_TYPE_TREE, GMenuTree))
+#define GMENU_TREE_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), GMENU_TYPE_TREE, GMenuTreeClass))
+#define GMENU_IS_TREE(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), GMENU_TYPE_TREE))
+#define GMENU_IS_TREE_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), GMENU_TYPE_TREE))
+#define GMENU_TREE_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), G_TYPE_DESKTOP_APP_INFO, GMenuTreeClass))
+
+typedef struct _GMenuTree GMenuTree;
+typedef struct _GMenuTreeClass GMenuTreeClass;
+
+struct _GMenuTreeClass
+{
+ GObjectClass parent_class;
+};
+
+GType gmenu_tree_get_type (void) G_GNUC_CONST;
+
typedef struct GMenuTreeItem GMenuTreeItem;
typedef struct GMenuTreeDirectory GMenuTreeDirectory;
typedef struct GMenuTreeEntry GMenuTreeEntry;
@@ -71,14 +87,6 @@ GType gmenu_tree_flags_get_type (void);
GMenuTree *gmenu_tree_new (const char *menu_file,
GMenuTreeFlags flags);
-GMenuTree *gmenu_tree_ref (GMenuTree *tree);
-void gmenu_tree_unref (GMenuTree *tree);
-
-void gmenu_tree_set_user_data (GMenuTree *tree,
- gpointer user_data,
- GDestroyNotify dnotify);
-gpointer gmenu_tree_get_user_data (GMenuTree *tree);
-
const char *gmenu_tree_get_menu_file (GMenuTree *tree);
GMenuTreeDirectory *gmenu_tree_get_root_directory (GMenuTree *tree);
GMenuTreeDirectory *gmenu_tree_get_directory_from_path (GMenuTree *tree,
diff --git a/libmenu/menu-monitor.c b/libmenu/menu-monitor.c
index 09d416d..8895b49 100644
--- a/libmenu/menu-monitor.c
+++ b/libmenu/menu-monitor.c
@@ -203,18 +203,9 @@ static MenuMonitor *
register_monitor (const char *path,
gboolean is_directory)
{
- static gboolean initted = FALSE;
MenuMonitor *retval;
GFile *file;
- if (!initted)
- {
- /* This is the only place where we're using GObject and the app can't
- * know we're using it, so we need to init the type system ourselves. */
- g_type_init ();
- initted = TRUE;
- }
-
retval = g_new0 (MenuMonitor, 1);
retval->path = g_strdup (path);
diff --git a/util/gnome-menus-ls.py b/util/gnome-menus-ls.py
index d752552..83660e0 100644
--- a/util/gnome-menus-ls.py
+++ b/util/gnome-menus-ls.py
@@ -23,7 +23,7 @@
import optparse
import sys
-import gmenu
+import gi.GMenu
def print_entry(entry, path):
if entry.get_is_excluded():
diff --git a/util/test-menu-spec.c b/util/test-menu-spec.c
index c26754d..2be39c7 100644
--- a/util/test-menu-spec.c
+++ b/util/test-menu-spec.c
@@ -188,6 +188,8 @@ main (int argc, char **argv)
GMenuTreeDirectory *root;
GMenuTreeFlags flags;
+ g_type_init ();
+
#if 0
/* See comment when defining _() at the top of this file. */
bindtextdomain (GETTEXT_PACKAGE, GNOMELOCALEDIR);
@@ -238,7 +240,7 @@ main (int argc, char **argv)
}
- gmenu_tree_unref (tree);
+ g_object_unref (tree);
return 0;
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]