From 0d65f37b8fbcac9c0f181aa12bc4176f22a1dc09 Mon Sep 17 00:00:00 2001 From: Matt Wilson Date: Tue, 2 Oct 2001 16:50:04 +0000 Subject: (pyg_object_new): rewrote function to use g_object_newv and instantiate 2001-10-02 Matt Wilson (pyg_object_new): rewrote function to use g_object_newv and instantiate the object after we check to make sure the class handles all the properties passed. This solves the problem of trying to destroy a GtkObject after creating it, which can be a little tricky. --- gobject/gobjectmodule.c | 63 ++++++++++++++++++++++++++++--------------------- 1 file changed, 36 insertions(+), 27 deletions(-) (limited to 'gobject/gobjectmodule.c') diff --git a/gobject/gobjectmodule.c b/gobject/gobjectmodule.c index 4c67c59..1b9dd8d 100644 --- a/gobject/gobjectmodule.c +++ b/gobject/gobjectmodule.c @@ -2098,32 +2098,31 @@ pyg_object_new (PyGObject *self, PyObject *args, PyObject *kwargs) { PyObject *pytype; GType type; - GObject *obj; + GObject *obj = NULL; GObjectClass *class; PyObject *value; PyObject *key; - int pos=0; - + int pos=0, num_params=0, i; + GParameter *params; + if (!PyArg_ParseTuple (args, "O:gobject.new", &pytype)) { return NULL; } - type = pyg_type_from_object (pytype); - obj = g_object_new(type, NULL); - if (!obj) { - PyErr_SetString (PyExc_RuntimeError, - "could not create object"); + if ((type = pyg_type_from_object (pytype)) == 0) + return NULL; + + if ((class = g_type_class_ref (type)) == NULL) { + PyErr_SetString(PyExc_TypeError, + "could not get a reference to type class"); return NULL; } - class = G_OBJECT_GET_CLASS(obj); - g_object_freeze_notify (G_OBJECT(obj)); - + params = g_new0(GParameter, PyDict_Size(kwargs)); + while (kwargs && PyDict_Next (kwargs, &pos, &key, &value)) { - gchar *key_str = PyString_AsString (key); GParamSpec *pspec; - GValue gvalue ={ 0, }; - + gchar *key_str = g_strdup(PyString_AsString (key)); pspec = g_object_class_find_property (class, key_str); if (!pspec) { gchar buf[512]; @@ -2132,27 +2131,37 @@ pyg_object_new (PyGObject *self, PyObject *args, PyObject *kwargs) "gobject `%s' doesn't support property `%s'", g_type_name(type), key_str); PyErr_SetString(PyExc_TypeError, buf); - g_object_unref(G_OBJECT(obj)); - return NULL; + goto cleanup; } - - g_value_init(&gvalue, G_PARAM_SPEC_VALUE_TYPE(pspec)); - if (pyg_value_from_pyobject(&gvalue, value)) { + g_value_init(¶ms[num_params].value, + G_PARAM_SPEC_VALUE_TYPE(pspec)); + if (pyg_value_from_pyobject(¶ms[num_params].value, value)) { gchar buf[512]; g_snprintf(buf, sizeof(buf), "could not convert value for property `%s'", key_str); PyErr_SetString(PyExc_TypeError, buf); - g_object_unref(G_OBJECT(obj)); - return NULL; + goto cleanup; } - g_object_set_property(G_OBJECT(obj), key_str, &gvalue); - g_value_unset(&gvalue); + params[num_params].name = key_str; + num_params++; } - g_object_thaw_notify (G_OBJECT(obj)); - - return pygobject_new ((GObject *)obj); + obj = g_object_newv(type, num_params, params); + if (!obj) + PyErr_SetString (PyExc_RuntimeError, "could not create object"); + + cleanup: + for (i = 0; i < num_params; i++) { + g_free((gchar *) params[i].name); + g_value_unset(¶ms[i].value); + } + g_free(params); + g_type_class_unref(class); + + if (obj) + return pygobject_new ((GObject *)obj); + return NULL; } static PyMethodDef pygobject_functions[] = { @@ -2166,7 +2175,7 @@ static PyMethodDef pygobject_functions[] = { { "signal_new", pyg_signal_new, METH_VARARGS }, { "signal_list_names", pyg_signal_list_names, METH_VARARGS }, { "list_properties", pyg_object_class_list_properties, METH_VARARGS }, - { "new", pyg_object_new, METH_VARARGS|METH_KEYWORDS }, + { "new", (PyCFunction)pyg_object_new, METH_VARARGS|METH_KEYWORDS }, { NULL, NULL, 0 } }; -- cgit