python-gobject2
This commit is contained in:
parent
376ab1db72
commit
3c73b023a1
|
@ -1,13 +0,0 @@
|
||||||
diff -p -up pygobject-2.16.1/pygtk.py.fixdetection pygobject-2.16.1/pygtk.py
|
|
||||||
--- pygobject-2.16.1/pygtk.py.fixdetection 2009-02-20 22:27:14.000000000 +0100
|
|
||||||
+++ pygobject-2.16.1/pygtk.py 2009-02-23 09:44:55.000000000 +0100
|
|
||||||
@@ -57,6 +57,9 @@ def _get_available_versions():
|
|
||||||
# skip empty directories
|
|
||||||
if not os.listdir(pathname):
|
|
||||||
continue
|
|
||||||
+ # only accept directories containing gtk.py or gobject.so
|
|
||||||
+ if not glob.glob(os.path.join(pathname, "gtk.py")) and not glob.glob(os.path.join(pathname,"gobject.so")):
|
|
||||||
+ continue
|
|
||||||
|
|
||||||
if not versions.has_key(filename[-3:]):
|
|
||||||
versions[filename[-3:]] = pathname
|
|
|
@ -1,720 +0,0 @@
|
||||||
Submitted By: Andrew Benton <andy at benton dot eu dot com> (gobject-introspection) and Armin K. <krejzi at email dot com>, after thomas kaedin (git)
|
|
||||||
Date: 2012-03-29 (gobject-introspection) and 2014-03-04 (git)
|
|
||||||
Initial Package Version: 2.28.6
|
|
||||||
Upstream Status: not submitted (gobject-introspection) and committed (git)
|
|
||||||
Origin: Andrew Benton (gobject-introspection) and upstream (git)
|
|
||||||
Tanım: Fixes compiling with recent versions of gobject-introspection; and upstream fixes
|
|
||||||
|
|
||||||
diff -Naur pygobject-2.28.6.orig/configure.ac pygobject-2.28.6/configure.ac
|
|
||||||
--- pygobject-2.28.6.orig/configure.ac 2011-06-13 13:33:56.000000000 -0300
|
|
||||||
+++ pygobject-2.28.6/configure.ac 2014-03-04 18:36:07.947079909 -0300
|
|
||||||
@@ -85,7 +85,7 @@
|
|
||||||
AM_PROG_CC_STDC
|
|
||||||
AM_PROG_CC_C_O
|
|
||||||
|
|
||||||
-# check that we have the minimum version of python necisary to build
|
|
||||||
+# check that we have the minimum version of python necessary to build
|
|
||||||
JD_PATH_PYTHON(python_min_ver)
|
|
||||||
|
|
||||||
# check if we are building for python 3
|
|
||||||
@@ -236,7 +236,7 @@
|
|
||||||
AC_ARG_ENABLE(introspection,
|
|
||||||
AC_HELP_STRING([--enable-introspection], [Use introspection information]),
|
|
||||||
enable_introspection=$enableval,
|
|
||||||
- enable_introspection=yes)
|
|
||||||
+ enable_introspection=no)
|
|
||||||
if test "$enable_introspection" != no; then
|
|
||||||
AC_DEFINE(ENABLE_INTROSPECTION,1,Use introspection information)
|
|
||||||
PKG_CHECK_MODULES(GI,
|
|
||||||
@@ -262,6 +262,9 @@
|
|
||||||
AC_SUBST(INTROSPECTION_SCANNER)
|
|
||||||
AC_SUBST(INTROSPECTION_COMPILER)
|
|
||||||
|
|
||||||
+dnl Do not install codegen for Python 3.
|
|
||||||
+AM_CONDITIONAL(ENABLE_CODEGEN, test $build_py3k = false)
|
|
||||||
+
|
|
||||||
dnl add required cflags ...
|
|
||||||
if test "x$GCC" = "xyes"; then
|
|
||||||
JH_ADD_CFLAG([-Wall])
|
|
||||||
@@ -281,8 +284,6 @@
|
|
||||||
Makefile
|
|
||||||
pygobject-2.0.pc
|
|
||||||
pygobject-2.0-uninstalled.pc
|
|
||||||
- codegen/Makefile
|
|
||||||
- codegen/pygobject-codegen-2.0
|
|
||||||
docs/Makefile
|
|
||||||
docs/reference/entities.docbook
|
|
||||||
docs/xsl/fixxref.py
|
|
||||||
@@ -295,6 +296,13 @@
|
|
||||||
examples/Makefile
|
|
||||||
tests/Makefile
|
|
||||||
PKG-INFO)
|
|
||||||
+
|
|
||||||
+if test $build_py3k = false; then
|
|
||||||
+ AC_CONFIG_FILES(
|
|
||||||
+ codegen/Makefile
|
|
||||||
+ codegen/pygobject-codegen-2.0)
|
|
||||||
+fi
|
|
||||||
+
|
|
||||||
AC_OUTPUT
|
|
||||||
|
|
||||||
echo
|
|
||||||
diff -Naur pygobject-2.28.6.orig/gi/module.py pygobject-2.28.6/gi/module.py
|
|
||||||
--- pygobject-2.28.6.orig/gi/module.py 2011-06-13 13:30:25.000000000 -0300
|
|
||||||
+++ pygobject-2.28.6/gi/module.py 2014-03-04 18:36:07.947079909 -0300
|
|
||||||
@@ -24,7 +24,11 @@
|
|
||||||
|
|
||||||
import os
|
|
||||||
import gobject
|
|
||||||
-import string
|
|
||||||
+try:
|
|
||||||
+ maketrans = ''.maketrans
|
|
||||||
+except AttributeError:
|
|
||||||
+ # fallback for Python 2
|
|
||||||
+ from string import maketrans
|
|
||||||
|
|
||||||
import gi
|
|
||||||
from .overrides import registry
|
|
||||||
@@ -124,7 +128,7 @@
|
|
||||||
# Don't use upper() here to avoid locale specific
|
|
||||||
# identifier conversion (e. g. in Turkish 'i'.upper() == 'i')
|
|
||||||
# see https://bugzilla.gnome.org/show_bug.cgi?id=649165
|
|
||||||
- ascii_upper_trans = string.maketrans(
|
|
||||||
+ ascii_upper_trans = maketrans(
|
|
||||||
'abcdefgjhijklmnopqrstuvwxyz',
|
|
||||||
'ABCDEFGJHIJKLMNOPQRSTUVWXYZ')
|
|
||||||
for value_info in info.get_values():
|
|
||||||
diff -Naur pygobject-2.28.6.orig/gi/overrides/Gtk.py pygobject-2.28.6/gi/overrides/Gtk.py
|
|
||||||
--- pygobject-2.28.6.orig/gi/overrides/Gtk.py 2011-06-13 13:33:49.000000000 -0300
|
|
||||||
+++ pygobject-2.28.6/gi/overrides/Gtk.py 2014-03-04 18:36:07.949079863 -0300
|
|
||||||
@@ -35,6 +35,18 @@
|
|
||||||
Gtk = modules['Gtk']._introspection_module
|
|
||||||
__all__ = []
|
|
||||||
|
|
||||||
+if Gtk._version == '2.0':
|
|
||||||
+ import warnings
|
|
||||||
+ warn_msg = "You have imported the Gtk 2.0 module. Because Gtk 2.0 \
|
|
||||||
+was not designed for use with introspection some of the \
|
|
||||||
+interfaces and API will fail. As such this is not supported \
|
|
||||||
+by the pygobject development team and we encourage you to \
|
|
||||||
+port your app to Gtk 3 or greater. PyGTK is the recomended \
|
|
||||||
+python module to use with Gtk 2.0"
|
|
||||||
+
|
|
||||||
+ warnings.warn(warn_msg, RuntimeWarning)
|
|
||||||
+
|
|
||||||
+
|
|
||||||
class Widget(Gtk.Widget):
|
|
||||||
|
|
||||||
def translate_coordinates(self, dest_widget, src_x, src_y):
|
|
||||||
@@ -401,16 +413,22 @@
|
|
||||||
def __init__(self,
|
|
||||||
parent=None,
|
|
||||||
flags=0,
|
|
||||||
- type=Gtk.MessageType.INFO,
|
|
||||||
+ message_type=Gtk.MessageType.INFO,
|
|
||||||
buttons=Gtk.ButtonsType.NONE,
|
|
||||||
message_format=None,
|
|
||||||
**kwds):
|
|
||||||
|
|
||||||
if message_format != None:
|
|
||||||
kwds['text'] = message_format
|
|
||||||
+
|
|
||||||
+ if 'type' in kwds:
|
|
||||||
+ import warnings
|
|
||||||
+ warnings.warn("The use of the keyword type as a parameter of the Gtk.MessageDialog constructor has been depricated. Please use message_type instead.", DeprecationWarning)
|
|
||||||
+ message_type = kwds['type']
|
|
||||||
+
|
|
||||||
Gtk.MessageDialog.__init__(self,
|
|
||||||
_buttons_property=buttons,
|
|
||||||
- message_type=type,
|
|
||||||
+ message_type=message_type,
|
|
||||||
**kwds)
|
|
||||||
Dialog.__init__(self, parent=parent, flags=flags)
|
|
||||||
|
|
||||||
@@ -619,12 +637,18 @@
|
|
||||||
def forward_search(self, string, flags, limit):
|
|
||||||
success, match_start, match_end = super(TextIter, self).forward_search(string,
|
|
||||||
flags, limit)
|
|
||||||
- return (match_start, match_end,)
|
|
||||||
+ if success:
|
|
||||||
+ return (match_start, match_end)
|
|
||||||
+ else:
|
|
||||||
+ return None
|
|
||||||
|
|
||||||
def backward_search(self, string, flags, limit):
|
|
||||||
success, match_start, match_end = super(TextIter, self).backward_search(string,
|
|
||||||
flags, limit)
|
|
||||||
- return (match_start, match_end,)
|
|
||||||
+ if success:
|
|
||||||
+ return (match_start, match_end)
|
|
||||||
+ else:
|
|
||||||
+ return None
|
|
||||||
|
|
||||||
def begins_tag(self, tag=None):
|
|
||||||
return super(TextIter, self).begins_tag(tag)
|
|
||||||
diff -Naur pygobject-2.28.6.orig/gi/pygi-foreign-cairo.c pygobject-2.28.6/gi/pygi-foreign-cairo.c
|
|
||||||
--- pygobject-2.28.6.orig/gi/pygi-foreign-cairo.c 2011-06-13 13:33:49.000000000 -0300
|
|
||||||
+++ pygobject-2.28.6/gi/pygi-foreign-cairo.c 2014-03-04 18:36:07.949079863 -0300
|
|
||||||
@@ -30,7 +30,7 @@
|
|
||||||
#include <pycairo/py3cairo.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
-Pycairo_CAPI_t *Pycairo_CAPI;
|
|
||||||
+static Pycairo_CAPI_t *Pycairo_CAPI;
|
|
||||||
|
|
||||||
#include "pygi-foreign.h"
|
|
||||||
|
|
||||||
@@ -114,10 +114,15 @@
|
|
||||||
Py_RETURN_NONE;
|
|
||||||
}
|
|
||||||
|
|
||||||
-static PyMethodDef _gi_cairo_functions[] = {};
|
|
||||||
+static PyMethodDef _gi_cairo_functions[] = {0,};
|
|
||||||
PYGLIB_MODULE_START(_gi_cairo, "_gi_cairo")
|
|
||||||
{
|
|
||||||
+#if PY_VERSION_HEX < 0x03000000
|
|
||||||
Pycairo_IMPORT;
|
|
||||||
+#else
|
|
||||||
+ Pycairo_CAPI = (Pycairo_CAPI_t*) PyCObject_Import("cairo", "CAPI");
|
|
||||||
+#endif
|
|
||||||
+
|
|
||||||
if (Pycairo_CAPI == NULL)
|
|
||||||
return PYGLIB_MODULE_ERROR_RETURN;
|
|
||||||
|
|
||||||
diff -Naur pygobject-2.28.6.orig/gi/pygi-info.c pygobject-2.28.6/gi/pygi-info.c
|
|
||||||
--- pygobject-2.28.6.orig/gi/pygi-info.c 2011-06-13 13:30:25.000000000 -0300
|
|
||||||
+++ pygobject-2.28.6/gi/pygi-info.c 2014-03-04 18:35:32.473899924 -0300
|
|
||||||
@@ -162,9 +162,6 @@
|
|
||||||
case GI_INFO_TYPE_CONSTANT:
|
|
||||||
type = &PyGIConstantInfo_Type;
|
|
||||||
break;
|
|
||||||
- case GI_INFO_TYPE_ERROR_DOMAIN:
|
|
||||||
- type = &PyGIErrorDomainInfo_Type;
|
|
||||||
- break;
|
|
||||||
case GI_INFO_TYPE_UNION:
|
|
||||||
type = &PyGIUnionInfo_Type;
|
|
||||||
break;
|
|
||||||
@@ -481,7 +478,6 @@
|
|
||||||
case GI_INFO_TYPE_INVALID:
|
|
||||||
case GI_INFO_TYPE_FUNCTION:
|
|
||||||
case GI_INFO_TYPE_CONSTANT:
|
|
||||||
- case GI_INFO_TYPE_ERROR_DOMAIN:
|
|
||||||
case GI_INFO_TYPE_VALUE:
|
|
||||||
case GI_INFO_TYPE_SIGNAL:
|
|
||||||
case GI_INFO_TYPE_PROPERTY:
|
|
||||||
@@ -860,7 +856,6 @@
|
|
||||||
case GI_INFO_TYPE_INVALID:
|
|
||||||
case GI_INFO_TYPE_FUNCTION:
|
|
||||||
case GI_INFO_TYPE_CONSTANT:
|
|
||||||
- case GI_INFO_TYPE_ERROR_DOMAIN:
|
|
||||||
case GI_INFO_TYPE_VALUE:
|
|
||||||
case GI_INFO_TYPE_SIGNAL:
|
|
||||||
case GI_INFO_TYPE_PROPERTY:
|
|
||||||
diff -Naur pygobject-2.28.6.orig/gio/gio-types.defs pygobject-2.28.6/gio/gio-types.defs
|
|
||||||
--- pygobject-2.28.6.orig/gio/gio-types.defs 2011-06-13 13:33:49.000000000 -0300
|
|
||||||
+++ pygobject-2.28.6/gio/gio-types.defs 2014-03-04 18:36:07.950079840 -0300
|
|
||||||
@@ -526,7 +526,7 @@
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
-(define-enum MountMountFlags
|
|
||||||
+(define-flags MountMountFlags
|
|
||||||
(in-module "gio")
|
|
||||||
(c-name "GMountMountFlags")
|
|
||||||
(gtype-id "G_TYPE_MOUNT_MOUNT_FLAGS")
|
|
||||||
@@ -545,7 +545,7 @@
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
-(define-enum DriveStartFlags
|
|
||||||
+(define-flags DriveStartFlags
|
|
||||||
(in-module "gio")
|
|
||||||
(c-name "GDriveStartFlags")
|
|
||||||
(gtype-id "G_TYPE_DRIVE_START_FLAGS")
|
|
||||||
@@ -770,7 +770,7 @@
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
-(define-enum SocketMsgFlags
|
|
||||||
+(define-flags SocketMsgFlags
|
|
||||||
(in-module "gio")
|
|
||||||
(c-name "GSocketMsgFlags")
|
|
||||||
(gtype-id "G_TYPE_SOCKET_MSG_FLAGS")
|
|
||||||
diff -Naur pygobject-2.28.6.orig/gobject/gobjectmodule.c pygobject-2.28.6/gobject/gobjectmodule.c
|
|
||||||
--- pygobject-2.28.6.orig/gobject/gobjectmodule.c 2011-06-13 13:33:49.000000000 -0300
|
|
||||||
+++ pygobject-2.28.6/gobject/gobjectmodule.c 2014-03-04 18:36:07.952079793 -0300
|
|
||||||
@@ -312,13 +312,6 @@
|
|
||||||
pyglib_gil_state_release(state);
|
|
||||||
}
|
|
||||||
|
|
||||||
-static void
|
|
||||||
-pyg_object_class_init(GObjectClass *class, PyObject *py_class)
|
|
||||||
-{
|
|
||||||
- class->set_property = pyg_object_set_property;
|
|
||||||
- class->get_property = pyg_object_get_property;
|
|
||||||
-}
|
|
||||||
-
|
|
||||||
typedef struct _PyGSignalAccumulatorData {
|
|
||||||
PyObject *callable;
|
|
||||||
PyObject *user_data;
|
|
||||||
@@ -484,15 +477,14 @@
|
|
||||||
}
|
|
||||||
|
|
||||||
static PyObject *
|
|
||||||
-add_signals (GType instance_type, PyObject *signals)
|
|
||||||
+add_signals (GObjectClass *klass, PyObject *signals)
|
|
||||||
{
|
|
||||||
gboolean ret = TRUE;
|
|
||||||
- GObjectClass *oclass;
|
|
||||||
Py_ssize_t pos = 0;
|
|
||||||
PyObject *key, *value, *overridden_signals = NULL;
|
|
||||||
+ GType instance_type = G_OBJECT_CLASS_TYPE (klass);
|
|
||||||
|
|
||||||
overridden_signals = PyDict_New();
|
|
||||||
- oclass = g_type_class_ref(instance_type);
|
|
||||||
while (PyDict_Next(signals, &pos, &key, &value)) {
|
|
||||||
const gchar *signal_name;
|
|
||||||
gchar *signal_name_canon, *c;
|
|
||||||
@@ -530,7 +522,6 @@
|
|
||||||
if (!ret)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
- g_type_class_unref(oclass);
|
|
||||||
if (ret)
|
|
||||||
return overridden_signals;
|
|
||||||
else {
|
|
||||||
@@ -800,14 +791,12 @@
|
|
||||||
}
|
|
||||||
|
|
||||||
static gboolean
|
|
||||||
-add_properties (GType instance_type, PyObject *properties)
|
|
||||||
+add_properties (GObjectClass *klass, PyObject *properties)
|
|
||||||
{
|
|
||||||
gboolean ret = TRUE;
|
|
||||||
- GObjectClass *oclass;
|
|
||||||
Py_ssize_t pos = 0;
|
|
||||||
PyObject *key, *value;
|
|
||||||
|
|
||||||
- oclass = g_type_class_ref(instance_type);
|
|
||||||
while (PyDict_Next(properties, &pos, &key, &value)) {
|
|
||||||
const gchar *prop_name;
|
|
||||||
GType prop_type;
|
|
||||||
@@ -873,7 +862,7 @@
|
|
||||||
Py_DECREF(slice);
|
|
||||||
|
|
||||||
if (pspec) {
|
|
||||||
- g_object_class_install_property(oclass, 1, pspec);
|
|
||||||
+ g_object_class_install_property(klass, 1, pspec);
|
|
||||||
} else {
|
|
||||||
PyObject *type, *value, *traceback;
|
|
||||||
ret = FALSE;
|
|
||||||
@@ -883,7 +872,7 @@
|
|
||||||
g_snprintf(msg, 256,
|
|
||||||
"%s (while registering property '%s' for GType '%s')",
|
|
||||||
PYGLIB_PyUnicode_AsString(value),
|
|
||||||
- prop_name, g_type_name(instance_type));
|
|
||||||
+ prop_name, G_OBJECT_CLASS_NAME(klass));
|
|
||||||
Py_DECREF(value);
|
|
||||||
value = PYGLIB_PyUnicode_FromString(msg);
|
|
||||||
}
|
|
||||||
@@ -892,11 +881,63 @@
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
- g_type_class_unref(oclass);
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
+pyg_object_class_init(GObjectClass *class, PyObject *py_class)
|
|
||||||
+{
|
|
||||||
+ PyObject *gproperties, *gsignals, *overridden_signals;
|
|
||||||
+ PyObject *class_dict = ((PyTypeObject*) py_class)->tp_dict;
|
|
||||||
+
|
|
||||||
+ class->set_property = pyg_object_set_property;
|
|
||||||
+ class->get_property = pyg_object_get_property;
|
|
||||||
+
|
|
||||||
+ /* install signals */
|
|
||||||
+ /* we look this up in the instance dictionary, so we don't
|
|
||||||
+ * accidentally get a parent type's __gsignals__ attribute. */
|
|
||||||
+ gsignals = PyDict_GetItemString(class_dict, "__gsignals__");
|
|
||||||
+ if (gsignals) {
|
|
||||||
+ if (!PyDict_Check(gsignals)) {
|
|
||||||
+ PyErr_SetString(PyExc_TypeError,
|
|
||||||
+ "__gsignals__ attribute not a dict!");
|
|
||||||
+ return;
|
|
||||||
+ }
|
|
||||||
+ if (!(overridden_signals = add_signals(class, gsignals))) {
|
|
||||||
+ return;
|
|
||||||
+ }
|
|
||||||
+ if (PyDict_SetItemString(class_dict, "__gsignals__",
|
|
||||||
+ overridden_signals)) {
|
|
||||||
+ return;
|
|
||||||
+ }
|
|
||||||
+ Py_DECREF(overridden_signals);
|
|
||||||
+
|
|
||||||
+ PyDict_DelItemString(class_dict, "__gsignals__");
|
|
||||||
+ } else {
|
|
||||||
+ PyErr_Clear();
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ /* install properties */
|
|
||||||
+ /* we look this up in the instance dictionary, so we don't
|
|
||||||
+ * accidentally get a parent type's __gproperties__ attribute. */
|
|
||||||
+ gproperties = PyDict_GetItemString(class_dict, "__gproperties__");
|
|
||||||
+ if (gproperties) {
|
|
||||||
+ if (!PyDict_Check(gproperties)) {
|
|
||||||
+ PyErr_SetString(PyExc_TypeError,
|
|
||||||
+ "__gproperties__ attribute not a dict!");
|
|
||||||
+ return;
|
|
||||||
+ }
|
|
||||||
+ if (!add_properties(class, gproperties)) {
|
|
||||||
+ return;
|
|
||||||
+ }
|
|
||||||
+ PyDict_DelItemString(class_dict, "__gproperties__");
|
|
||||||
+ /* Borrowed reference. Py_DECREF(gproperties); */
|
|
||||||
+ } else {
|
|
||||||
+ PyErr_Clear();
|
|
||||||
+ }
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+static void
|
|
||||||
pyg_register_class_init(GType gtype, PyGClassInitFunc class_init)
|
|
||||||
{
|
|
||||||
GSList *list;
|
|
||||||
@@ -1068,7 +1109,7 @@
|
|
||||||
*/
|
|
||||||
static void
|
|
||||||
pyg_type_add_interfaces(PyTypeObject *class, GType instance_type,
|
|
||||||
- PyObject *bases, gboolean new_interfaces,
|
|
||||||
+ PyObject *bases,
|
|
||||||
GType *parent_interfaces, guint n_parent_interfaces)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
@@ -1082,7 +1123,6 @@
|
|
||||||
guint k;
|
|
||||||
PyObject *base = PyTuple_GET_ITEM(bases, i);
|
|
||||||
GType itype;
|
|
||||||
- gboolean is_new = TRUE;
|
|
||||||
const GInterfaceInfo *iinfo;
|
|
||||||
GInterfaceInfo iinfo_copy;
|
|
||||||
|
|
||||||
@@ -1099,16 +1139,6 @@
|
|
||||||
if (!G_TYPE_IS_INTERFACE(itype))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
- for (k = 0; k < n_parent_interfaces; ++k) {
|
|
||||||
- if (parent_interfaces[k] == itype) {
|
|
||||||
- is_new = FALSE;
|
|
||||||
- break;
|
|
||||||
- }
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
- if ((new_interfaces && !is_new) || (!new_interfaces && is_new))
|
|
||||||
- continue;
|
|
||||||
-
|
|
||||||
iinfo = pyg_lookup_interface_info(itype);
|
|
||||||
if (!iinfo) {
|
|
||||||
gchar *error;
|
|
||||||
@@ -1129,7 +1159,7 @@
|
|
||||||
int
|
|
||||||
pyg_type_register(PyTypeObject *class, const char *type_name)
|
|
||||||
{
|
|
||||||
- PyObject *gtype, *gsignals, *gproperties, *overridden_signals;
|
|
||||||
+ PyObject *gtype;
|
|
||||||
GType parent_type, instance_type;
|
|
||||||
GType *parent_interfaces;
|
|
||||||
guint n_parent_interfaces;
|
|
||||||
@@ -1216,88 +1246,22 @@
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
- * Note: Interfaces to be implemented are searched twice. First
|
|
||||||
- * we register interfaces that are already implemented by a parent
|
|
||||||
- * type. The second time, the remaining interfaces are
|
|
||||||
- * registered, i.e. the ones that are not implemented by a parent
|
|
||||||
- * type. In between these two loops, properties and signals are
|
|
||||||
- * registered. It has to be done this way, in two steps,
|
|
||||||
- * otherwise glib will complain. If registering all interfaces
|
|
||||||
- * always before properties, you get an error like:
|
|
||||||
- *
|
|
||||||
- * ../gobject:121: Warning: Object class
|
|
||||||
- * test_interface+MyObject doesn't implement property
|
|
||||||
- * 'some-property' from interface 'TestInterface'
|
|
||||||
- *
|
|
||||||
- * If, on the other hand, you register interfaces after
|
|
||||||
- * registering the properties, you get something like:
|
|
||||||
- *
|
|
||||||
- * ../gobject:121: Warning: cannot add interface type
|
|
||||||
- * `TestInterface' to type `test_interface+MyUnknown', since
|
|
||||||
- * type `test_interface+MyUnknown' already conforms to
|
|
||||||
- * interface
|
|
||||||
- *
|
|
||||||
- * This looks like a GLib quirk, but no bug has been filed
|
|
||||||
- * upstream. However we have a unit test for this particular
|
|
||||||
- * problem, which can be found in test_interfaces.py, class
|
|
||||||
- * TestInterfaceImpl.
|
|
||||||
+ * Note, all interfaces need to be registered before the first
|
|
||||||
+ * g_type_class_ref(), see bug #686149.
|
|
||||||
*
|
|
||||||
* See also comment above pyg_type_add_interfaces().
|
|
||||||
*/
|
|
||||||
- pyg_type_add_interfaces(class, instance_type, class->tp_bases, FALSE,
|
|
||||||
+ pyg_type_add_interfaces(class, instance_type, class->tp_bases,
|
|
||||||
parent_interfaces, n_parent_interfaces);
|
|
||||||
|
|
||||||
- /* we look this up in the instance dictionary, so we don't
|
|
||||||
- * accidentally get a parent type's __gsignals__ attribute. */
|
|
||||||
- gsignals = PyDict_GetItemString(class->tp_dict, "__gsignals__");
|
|
||||||
- if (gsignals) {
|
|
||||||
- if (!PyDict_Check(gsignals)) {
|
|
||||||
- PyErr_SetString(PyExc_TypeError,
|
|
||||||
- "__gsignals__ attribute not a dict!");
|
|
||||||
- g_free(parent_interfaces);
|
|
||||||
- return -1;
|
|
||||||
- }
|
|
||||||
- if (!(overridden_signals = add_signals(instance_type, gsignals))) {
|
|
||||||
- g_free(parent_interfaces);
|
|
||||||
- return -1;
|
|
||||||
- }
|
|
||||||
- if (PyDict_SetItemString(class->tp_dict, "__gsignals__",
|
|
||||||
- overridden_signals)) {
|
|
||||||
- g_free(parent_interfaces);
|
|
||||||
- return -1;
|
|
||||||
- }
|
|
||||||
- Py_DECREF(overridden_signals);
|
|
||||||
- } else {
|
|
||||||
- PyErr_Clear();
|
|
||||||
- }
|
|
||||||
|
|
||||||
- /* we look this up in the instance dictionary, so we don't
|
|
||||||
- * accidentally get a parent type's __gsignals__ attribute. */
|
|
||||||
- gproperties = PyDict_GetItemString(class->tp_dict, "__gproperties__");
|
|
||||||
- if (gproperties) {
|
|
||||||
- if (!PyDict_Check(gproperties)) {
|
|
||||||
- PyErr_SetString(PyExc_TypeError,
|
|
||||||
- "__gproperties__ attribute not a dict!");
|
|
||||||
- g_free(parent_interfaces);
|
|
||||||
- return -1;
|
|
||||||
- }
|
|
||||||
- if (!add_properties(instance_type, gproperties)) {
|
|
||||||
- g_free(parent_interfaces);
|
|
||||||
- return -1;
|
|
||||||
- }
|
|
||||||
- PyDict_DelItemString(class->tp_dict, "__gproperties__");
|
|
||||||
- /* Borrowed reference. Py_DECREF(gproperties); */
|
|
||||||
- } else {
|
|
||||||
- PyErr_Clear();
|
|
||||||
+ gclass = g_type_class_ref(instance_type);
|
|
||||||
+ if (PyErr_Occurred() != NULL) {
|
|
||||||
+ g_type_class_unref(gclass);
|
|
||||||
+ g_free(parent_interfaces);
|
|
||||||
+ return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
- /* Register new interfaces, that are _not_ already defined by
|
|
||||||
- * the parent type. FIXME: See above.
|
|
||||||
- */
|
|
||||||
- pyg_type_add_interfaces(class, instance_type, class->tp_bases, TRUE,
|
|
||||||
- parent_interfaces, n_parent_interfaces);
|
|
||||||
-
|
|
||||||
- gclass = g_type_class_ref(instance_type);
|
|
||||||
if (pyg_run_class_init(instance_type, gclass, class)) {
|
|
||||||
g_type_class_unref(gclass);
|
|
||||||
g_free(parent_interfaces);
|
|
||||||
@@ -1306,9 +1270,8 @@
|
|
||||||
g_type_class_unref(gclass);
|
|
||||||
g_free(parent_interfaces);
|
|
||||||
|
|
||||||
- if (gsignals)
|
|
||||||
- PyDict_DelItemString(class->tp_dict, "__gsignals__");
|
|
||||||
-
|
|
||||||
+ if (PyErr_Occurred() != NULL)
|
|
||||||
+ return -1;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
diff -Naur pygobject-2.28.6.orig/gobject/propertyhelper.py pygobject-2.28.6/gobject/propertyhelper.py
|
|
||||||
--- pygobject-2.28.6.orig/gobject/propertyhelper.py 2011-06-13 13:30:25.000000000 -0300
|
|
||||||
+++ pygobject-2.28.6/gobject/propertyhelper.py 2014-03-04 18:36:07.953079770 -0300
|
|
||||||
@@ -188,14 +188,16 @@
|
|
||||||
return TYPE_STRING
|
|
||||||
elif type_ == object:
|
|
||||||
return TYPE_PYOBJECT
|
|
||||||
- elif isinstance(type_, type) and issubclass(type_, _gobject.GObject):
|
|
||||||
+ elif (isinstance(type_, type) and
|
|
||||||
+ issubclass(type_, (_gobject.GObject,
|
|
||||||
+ _gobject.GEnum))):
|
|
||||||
return type_.__gtype__
|
|
||||||
elif type_ in [TYPE_NONE, TYPE_INTERFACE, TYPE_CHAR, TYPE_UCHAR,
|
|
||||||
- TYPE_INT, TYPE_UINT, TYPE_BOOLEAN, TYPE_LONG,
|
|
||||||
- TYPE_ULONG, TYPE_INT64, TYPE_UINT64, TYPE_ENUM,
|
|
||||||
- TYPE_FLAGS, TYPE_FLOAT, TYPE_DOUBLE, TYPE_POINTER,
|
|
||||||
- TYPE_BOXED, TYPE_PARAM, TYPE_OBJECT, TYPE_STRING,
|
|
||||||
- TYPE_PYOBJECT]:
|
|
||||||
+ TYPE_INT, TYPE_UINT, TYPE_BOOLEAN, TYPE_LONG,
|
|
||||||
+ TYPE_ULONG, TYPE_INT64, TYPE_UINT64,
|
|
||||||
+ TYPE_FLOAT, TYPE_DOUBLE, TYPE_POINTER,
|
|
||||||
+ TYPE_BOXED, TYPE_PARAM, TYPE_OBJECT, TYPE_STRING,
|
|
||||||
+ TYPE_PYOBJECT]:
|
|
||||||
return type_
|
|
||||||
else:
|
|
||||||
raise TypeError("Unsupported type: %r" % (type_,))
|
|
||||||
@@ -224,6 +226,12 @@
|
|
||||||
elif ptype == TYPE_PYOBJECT:
|
|
||||||
if default is not None:
|
|
||||||
raise TypeError("object types does not have default values")
|
|
||||||
+ elif gobject.type_is_a(ptype, TYPE_ENUM):
|
|
||||||
+ if default is None:
|
|
||||||
+ raise TypeError("enum properties needs a default value")
|
|
||||||
+ elif not gobject.type_is_a(default, ptype):
|
|
||||||
+ raise TypeError("enum value %s must be an instance of %r" %
|
|
||||||
+ (default, ptype))
|
|
||||||
|
|
||||||
def _get_minimum(self):
|
|
||||||
ptype = self.type
|
|
||||||
@@ -291,7 +299,8 @@
|
|
||||||
if ptype in [TYPE_INT, TYPE_UINT, TYPE_LONG, TYPE_ULONG,
|
|
||||||
TYPE_INT64, TYPE_UINT64, TYPE_FLOAT, TYPE_DOUBLE]:
|
|
||||||
args = self._get_minimum(), self._get_maximum(), self.default
|
|
||||||
- elif ptype == TYPE_STRING or ptype == TYPE_BOOLEAN:
|
|
||||||
+ elif (ptype == TYPE_STRING or ptype == TYPE_BOOLEAN or
|
|
||||||
+ ptype.is_a(TYPE_ENUM)):
|
|
||||||
args = (self.default,)
|
|
||||||
elif ptype == TYPE_PYOBJECT:
|
|
||||||
args = ()
|
|
||||||
diff -Naur pygobject-2.28.6.orig/gobject/pygobject.c pygobject-2.28.6/gobject/pygobject.c
|
|
||||||
--- pygobject-2.28.6.orig/gobject/pygobject.c 2011-06-13 13:33:49.000000000 -0300
|
|
||||||
+++ pygobject-2.28.6/gobject/pygobject.c 2014-03-04 18:36:07.954079747 -0300
|
|
||||||
@@ -991,7 +991,9 @@
|
|
||||||
PyObject *
|
|
||||||
pygobject_new_sunk(GObject *obj)
|
|
||||||
{
|
|
||||||
- g_object_set_qdata (obj, pygobject_ref_sunk_key, GINT_TO_POINTER (1));
|
|
||||||
+ if (obj)
|
|
||||||
+ g_object_set_qdata (obj, pygobject_ref_sunk_key, GINT_TO_POINTER (1));
|
|
||||||
+
|
|
||||||
return pygobject_new_full(obj, TRUE, NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
diff -Naur pygobject-2.28.6.orig/Makefile.am pygobject-2.28.6/Makefile.am
|
|
||||||
--- pygobject-2.28.6.orig/Makefile.am 2011-06-13 13:33:49.000000000 -0300
|
|
||||||
+++ pygobject-2.28.6/Makefile.am 2014-03-04 18:36:07.954079747 -0300
|
|
||||||
@@ -1,7 +1,11 @@
|
|
||||||
ACLOCAL_AMFLAGS = -I m4
|
|
||||||
AUTOMAKE_OPTIONS = 1.7
|
|
||||||
|
|
||||||
-SUBDIRS = docs codegen glib gobject gio examples
|
|
||||||
+SUBDIRS = docs glib gobject gio examples
|
|
||||||
+
|
|
||||||
+if ENABLE_CODEGEN
|
|
||||||
+SUBDIRS += codegen
|
|
||||||
+endif
|
|
||||||
|
|
||||||
if ENABLE_INTROSPECTION
|
|
||||||
SUBDIRS += gi
|
|
||||||
diff -Naur pygobject-2.28.6.orig/tests/Makefile.am pygobject-2.28.6/tests/Makefile.am
|
|
||||||
--- pygobject-2.28.6.orig/tests/Makefile.am 2011-06-13 13:33:49.000000000 -0300
|
|
||||||
+++ pygobject-2.28.6/tests/Makefile.am 2014-03-04 18:36:07.955079724 -0300
|
|
||||||
@@ -104,6 +104,7 @@
|
|
||||||
test-floating.h \
|
|
||||||
test-thread.h \
|
|
||||||
test-unknown.h \
|
|
||||||
+ te_ST@nouppera \
|
|
||||||
org.gnome.test.gschema.xml
|
|
||||||
|
|
||||||
EXTRA_DIST += $(TEST_FILES_STATIC) $(TEST_FILES_GI) $(TEST_FILES_GIO)
|
|
||||||
diff -Naur pygobject-2.28.6.orig/tests/test_gdbus.py pygobject-2.28.6/tests/test_gdbus.py
|
|
||||||
--- pygobject-2.28.6.orig/tests/test_gdbus.py 2011-06-13 13:33:49.000000000 -0300
|
|
||||||
+++ pygobject-2.28.6/tests/test_gdbus.py 2014-03-04 18:36:07.956079701 -0300
|
|
||||||
@@ -67,8 +67,10 @@
|
|
||||||
|
|
||||||
def test_native_calls_async(self):
|
|
||||||
def call_done(obj, result, user_data):
|
|
||||||
- user_data['result'] = obj.call_finish(result)
|
|
||||||
- user_data['main_loop'].quit()
|
|
||||||
+ try:
|
|
||||||
+ user_data['result'] = obj.call_finish(result)
|
|
||||||
+ finally:
|
|
||||||
+ user_data['main_loop'].quit()
|
|
||||||
|
|
||||||
main_loop = gobject.MainLoop()
|
|
||||||
data = {'main_loop': main_loop}
|
|
||||||
diff -Naur pygobject-2.28.6.orig/tests/test_properties.py pygobject-2.28.6/tests/test_properties.py
|
|
||||||
--- pygobject-2.28.6.orig/tests/test_properties.py 2011-06-13 13:30:25.000000000 -0300
|
|
||||||
+++ pygobject-2.28.6/tests/test_properties.py 2014-03-04 18:36:07.956079701 -0300
|
|
||||||
@@ -14,6 +14,8 @@
|
|
||||||
G_MININT, G_MAXINT, G_MAXUINT, G_MINLONG, G_MAXLONG, \
|
|
||||||
G_MAXULONG
|
|
||||||
|
|
||||||
+from gi.repository import Gio
|
|
||||||
+
|
|
||||||
if sys.version_info < (3, 0):
|
|
||||||
TEST_UTF8 = "\xe2\x99\xa5"
|
|
||||||
UNICODE_UTF8 = unicode(TEST_UTF8, 'UTF-8')
|
|
||||||
@@ -34,6 +36,9 @@
|
|
||||||
uint64 = gobject.property(
|
|
||||||
type=TYPE_UINT64, flags=PARAM_READWRITE|PARAM_CONSTRUCT)
|
|
||||||
|
|
||||||
+ enum = gobject.property(
|
|
||||||
+ type=Gio.SocketType, default=Gio.SocketType.STREAM)
|
|
||||||
+
|
|
||||||
class TestProperties(unittest.TestCase):
|
|
||||||
def testGetSet(self):
|
|
||||||
obj = PropertyObject()
|
|
||||||
@@ -61,8 +66,9 @@
|
|
||||||
self.failUnless(pspec.name in ['normal',
|
|
||||||
'construct',
|
|
||||||
'construct-only',
|
|
||||||
- 'uint64'])
|
|
||||||
- self.assertEqual(len(obj), 4)
|
|
||||||
+ 'uint64',
|
|
||||||
+ 'enum'])
|
|
||||||
+ self.assertEqual(len(obj), 5)
|
|
||||||
|
|
||||||
def testNormal(self):
|
|
||||||
obj = new(PropertyObject, normal="123")
|
|
||||||
@@ -127,6 +133,34 @@
|
|
||||||
(etype, ex) = sys.exc_info()[2:]
|
|
||||||
self.fail(str(ex))
|
|
||||||
|
|
||||||
+ def testEnum(self):
|
|
||||||
+ obj = new(PropertyObject)
|
|
||||||
+ self.assertEqual(obj.props.enum, Gio.SocketType.STREAM)
|
|
||||||
+ self.assertEqual(obj.enum, Gio.SocketType.STREAM)
|
|
||||||
+ obj.enum = Gio.SocketType.DATAGRAM
|
|
||||||
+ self.assertEqual(obj.props.enum, Gio.SocketType.DATAGRAM)
|
|
||||||
+ self.assertEqual(obj.enum, Gio.SocketType.DATAGRAM)
|
|
||||||
+ obj.props.enum = Gio.SocketType.STREAM
|
|
||||||
+ self.assertEqual(obj.props.enum, Gio.SocketType.STREAM)
|
|
||||||
+ self.assertEqual(obj.enum, Gio.SocketType.STREAM)
|
|
||||||
+ obj.props.enum = 2
|
|
||||||
+ self.assertEqual(obj.props.enum, Gio.SocketType.DATAGRAM)
|
|
||||||
+ self.assertEqual(obj.enum, Gio.SocketType.DATAGRAM)
|
|
||||||
+ obj.enum = 1
|
|
||||||
+ self.assertEqual(obj.props.enum, Gio.SocketType.STREAM)
|
|
||||||
+ self.assertEqual(obj.enum, Gio.SocketType.STREAM)
|
|
||||||
+
|
|
||||||
+ self.assertRaises(TypeError, setattr, obj, 'enum', 'foo')
|
|
||||||
+ self.assertRaises(TypeError, setattr, obj, 'enum', object())
|
|
||||||
+
|
|
||||||
+ self.assertRaises(TypeError, gobject.property, type=Gio.SocketType)
|
|
||||||
+ self.assertRaises(TypeError, gobject.property, type=Gio.SocketType,
|
|
||||||
+ default=Gio.SocketProtocol.TCP)
|
|
||||||
+ self.assertRaises(TypeError, gobject.property, type=Gio.SocketType,
|
|
||||||
+ default=object())
|
|
||||||
+ self.assertRaises(TypeError, gobject.property, type=Gio.SocketType,
|
|
||||||
+ default=1)
|
|
||||||
+
|
|
||||||
def testRange(self):
|
|
||||||
# kiwi code
|
|
||||||
def max(c):
|
|
||||||
@@ -270,8 +304,6 @@
|
|
||||||
# self.assertRaises(TypeError, gobject.property, type=bool, default=0)
|
|
||||||
self.assertRaises(TypeError, gobject.property, type=bool, default='ciao mamma')
|
|
||||||
self.assertRaises(TypeError, gobject.property, type=bool)
|
|
||||||
- self.assertRaises(TypeError, gobject.property, type=GEnum)
|
|
||||||
- self.assertRaises(TypeError, gobject.property, type=GEnum, default=0)
|
|
||||||
self.assertRaises(TypeError, gobject.property, type=object, default=0)
|
|
||||||
self.assertRaises(TypeError, gobject.property, type=complex)
|
|
||||||
self.assertRaises(TypeError, gobject.property, flags=-10)
|
|
|
@ -1,21 +1,20 @@
|
||||||
# Tanım: GLib'in GObject sınıfı için Python 2'nin bağlantılarını sağlar.
|
# Tanım: GLib'in GObject sınıfı için Python 2'nin bağlantılarını sağlar.
|
||||||
# URL: http://www.gnome.org/
|
# URL: http://www.gnome.org/
|
||||||
# Paketçi: milisarge
|
# Paketçi: milisarge
|
||||||
# Gerekler: python-cairo xorg-libxxf86vm gobject-introspection
|
# Gerekler: gtk2
|
||||||
|
|
||||||
isim=python-gobject2
|
isim=python-gobject2
|
||||||
surum=2.28.6
|
surum=2.28.6
|
||||||
devir=1
|
devir=2
|
||||||
|
|
||||||
kaynak=( http://ftp.gnome.org/pub/gnome/sources/pygobject/${surum%.*}/pygobject-$surum.tar.xz
|
kaynak=( http://ftp.gnome.org/pub/gnome/sources/pygobject/${surum%.*}/pygobject-$surum.tar.xz)
|
||||||
pygobject-2.28.6-fixes-1.patch
|
|
||||||
pygobject-2.16.1-fixdetection.patch)
|
|
||||||
|
|
||||||
derle() {
|
derle() {
|
||||||
cd pygobject-$surum
|
cd pygobject-$surum
|
||||||
patch -Np1 -i $SRC/pygobject-2.28.6-fixes-1.patch
|
|
||||||
patch -Np1 -i $SRC/pygobject-2.16.1-fixdetection.patch
|
./configure --prefix=/usr --disable-introspection
|
||||||
./configure --prefix=/usr
|
|
||||||
make
|
make
|
||||||
make DESTDIR=$PKG install
|
make DESTDIR=$PKG install
|
||||||
|
rm -rf $PKG/usr/share/gtk-doc
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue