From b76fc4ec68e91618c86e3e1e9a0ea29c26876d8e Mon Sep 17 00:00:00 2001 From: "Owen W. Taylor" Date: Tue, 21 Sep 2010 13:32:20 -0400 Subject: [PATCH] Update to 0.9.6 --- .gitignore | 3 +- ...ually-verify-header-of-loaded-typeli.patch | 409 ------------------ gobject-introspection.spec | 16 +- py2.7-compat.patch | 39 -- sources | 2 +- 5 files changed, 9 insertions(+), 460 deletions(-) delete mode 100644 0001-girepository-Actually-verify-header-of-loaded-typeli.patch delete mode 100644 py2.7-compat.patch diff --git a/.gitignore b/.gitignore index f478ec1..26def0c 100644 --- a/.gitignore +++ b/.gitignore @@ -1,2 +1 @@ -gobject-introspection-0.9.2.tar.gz -gobject-introspection-0.9.3.tar.gz +gobject-introspection-0.9.6.tar.bz2 diff --git a/0001-girepository-Actually-verify-header-of-loaded-typeli.patch b/0001-girepository-Actually-verify-header-of-loaded-typeli.patch deleted file mode 100644 index fd67dbc..0000000 --- a/0001-girepository-Actually-verify-header-of-loaded-typeli.patch +++ /dev/null @@ -1,409 +0,0 @@ -From 05ffd85793207a40264a701de609614ba6e32d44 Mon Sep 17 00:00:00 2001 -From: Colin Walters -Date: Wed, 14 Jul 2010 11:59:11 -0400 -Subject: [PATCH] [girepository] Actually verify header of loaded typelibs in g_irepository_require - -Take a GError * for typelib loading code, validate the header. This -fixes bizarre errors from gjs where g_irepository_require would happily -load old typelibs. ---- - girepository/girepository.c | 4 +- - girepository/girmodule.c | 8 +++- - girepository/gitypelib.c | 71 +++++++++++++++++++++++-------- - girepository/gitypelib.h | 13 ++++-- - tools/compiler.c | 4 +- - tools/generate.c | 96 ++++++------------------------------------- - 6 files changed, 87 insertions(+), 109 deletions(-) - -diff --git a/girepository/girepository.c b/girepository/girepository.c -index ba6756e..ef3d6d2 100644 ---- a/girepository/girepository.c -+++ b/girepository/girepository.c -@@ -1221,7 +1221,9 @@ g_irepository_require (GIRepository *repository, - goto out; - } - -- typelib = g_typelib_new_from_mapped_file (mfile); -+ typelib = g_typelib_new_from_mapped_file (mfile, error); -+ if (!typelib) -+ goto out; - header = (Header *) typelib->data; - typelib_namespace = g_typelib_get_string (typelib, header->namespace); - typelib_version = g_typelib_get_string (typelib, header->nsversion); -diff --git a/girepository/girmodule.c b/girepository/girmodule.c -index 1c62319..066d516 100644 ---- a/girepository/girmodule.c -+++ b/girepository/girmodule.c -@@ -206,6 +206,7 @@ GTypelib * - g_ir_module_build_typelib (GIrModule *module, - GList *modules) - { -+ GError *error = NULL; - GTypelib *typelib; - gsize length; - guint i; -@@ -434,7 +435,12 @@ g_ir_module_build_typelib (GIrModule *module, - data = g_realloc (data, offset2); - header = (Header*) data; - length = header->size = offset2; -- typelib = g_typelib_new_from_memory (data, length); -+ typelib = g_typelib_new_from_memory (data, length, &error); -+ if (!typelib) -+ { -+ g_error ("error building typelib: %s", -+ error->message); -+ } - - g_hash_table_destroy (strings); - g_hash_table_destroy (types); -diff --git a/girepository/gitypelib.c b/girepository/gitypelib.c -index 0741bcb..5469e8b 100644 ---- a/girepository/gitypelib.c -+++ b/girepository/gitypelib.c -@@ -260,30 +260,30 @@ validate_name (GTypelib *typelib, - return TRUE; - } - -+/* Fast path sanity check, operates on a memory blob */ - static gboolean --validate_header (ValidateContext *ctx, -- GError **error) -+validate_header_basic (const guint8 *memory, -+ gsize len, -+ GError **error) - { -- GTypelib *typelib = ctx->typelib; -- Header *header; -+ Header *header = (Header *)memory; - -- if (typelib->len < sizeof (Header)) -+ if (len < sizeof (Header)) - { - g_set_error (error, - G_TYPELIB_ERROR, - G_TYPELIB_ERROR_INVALID, -- "The buffer is too short"); -+ "The specified typelib length %" G_GSIZE_FORMAT " is too short", -+ len); - return FALSE; - } - -- header = (Header *)typelib->data; -- - if (strncmp (header->magic, G_IR_MAGIC, 16) != 0) - { - g_set_error (error, - G_TYPELIB_ERROR, - G_TYPELIB_ERROR_INVALID_HEADER, -- "Magic string not found"); -+ "Invalid magic header"); - return FALSE; - - } -@@ -293,7 +293,7 @@ validate_header (ValidateContext *ctx, - g_set_error (error, - G_TYPELIB_ERROR, - G_TYPELIB_ERROR_INVALID_HEADER, -- "Version mismatch; expected 3, found %d", -+ "Typelib version mismatch; expected 3, found %d", - header->major_version); - return FALSE; - -@@ -308,12 +308,13 @@ validate_header (ValidateContext *ctx, - return FALSE; - } - -- if (header->size != typelib->len) -+ if (header->size != len) - { - g_set_error (error, - G_TYPELIB_ERROR, - G_TYPELIB_ERROR_INVALID_HEADER, -- "Typelib size mismatch"); -+ "Typelib size %" G_GSIZE_FORMAT " does not match %" G_GSIZE_FORMAT, -+ header->size, len); - return FALSE; - } - -@@ -378,9 +379,24 @@ validate_header (ValidateContext *ctx, - return FALSE; - } - -- if (!validate_name (typelib, "namespace", typelib->data, header->namespace, error)) -+ return TRUE; -+} -+ -+static gboolean -+validate_header (ValidateContext *ctx, -+ GError **error) -+{ -+ GTypelib *typelib = ctx->typelib; -+ -+ if (!validate_header_basic (typelib->data, typelib->len, error)) - return FALSE; - -+ { -+ Header *header = (Header*)typelib->data; -+ if (!validate_name (typelib, "namespace", typelib->data, header->namespace, error)) -+ return FALSE; -+ } -+ - return TRUE; - } - -@@ -2056,6 +2072,7 @@ _g_typelib_ensure_open (GTypelib *typelib) - * g_typelib_new_from_memory: - * @memory: address of memory chunk containing the typelib - * @len: length of memory chunk containing the typelib -+ * @error: a #GError - * - * Creates a new #GTypelib from a memory location. The memory block - * pointed to by @typelib will be automatically g_free()d when the -@@ -2064,10 +2081,15 @@ _g_typelib_ensure_open (GTypelib *typelib) - * Return value: the new #GTypelib - **/ - GTypelib * --g_typelib_new_from_memory (guchar *memory, gsize len) -+g_typelib_new_from_memory (guint8 *memory, -+ gsize len, -+ GError **error) - { - GTypelib *meta; - -+ if (!validate_header_basic (memory, len, error)) -+ return NULL; -+ - meta = g_slice_new0 (GTypelib); - meta->data = memory; - meta->len = len; -@@ -2081,16 +2103,22 @@ g_typelib_new_from_memory (guchar *memory, gsize len) - * g_typelib_new_from_const_memory: - * @memory: address of memory chunk containing the typelib - * @len: length of memory chunk containing the typelib -+ * @error: A #GError - * - * Creates a new #GTypelib from a memory location. - * - * Return value: the new #GTypelib - **/ - GTypelib * --g_typelib_new_from_const_memory (const guchar *memory, gsize len) -+g_typelib_new_from_const_memory (const guchar *memory, -+ gsize len, -+ GError **error) - { - GTypelib *meta; - -+ if (!validate_header_basic (memory, len, error)) -+ return NULL; -+ - meta = g_slice_new0 (GTypelib); - meta->data = (guchar *) memory; - meta->len = len; -@@ -2103,21 +2131,28 @@ g_typelib_new_from_const_memory (const guchar *memory, gsize len) - /** - * g_typelib_new_from_mapped_file: - * @mfile: a #GMappedFile, that will be free'd when the repository is destroyed -+ * @error: a #GError - * - * Creates a new #GTypelib from a #GMappedFile. - * - * Return value: the new #GTypelib - **/ - GTypelib * --g_typelib_new_from_mapped_file (GMappedFile *mfile) -+g_typelib_new_from_mapped_file (GMappedFile *mfile, -+ GError **error) - { - GTypelib *meta; -+ guint8 *data = (guint8 *) g_mapped_file_get_contents (mfile); -+ gsize len = g_mapped_file_get_length (mfile); -+ -+ if (!validate_header_basic (data, len, error)) -+ return NULL; - - meta = g_slice_new0 (GTypelib); - meta->mfile = mfile; - meta->owns_memory = FALSE; -- meta->data = (guchar *) g_mapped_file_get_contents (mfile); -- meta->len = g_mapped_file_get_length (mfile); -+ meta->data = data; -+ meta->len = len; - - return meta; - } -diff --git a/girepository/gitypelib.h b/girepository/gitypelib.h -index 5d5eda5..0a61008 100644 ---- a/girepository/gitypelib.h -+++ b/girepository/gitypelib.h -@@ -34,11 +34,14 @@ G_BEGIN_DECLS - - typedef struct _GTypelib GTypelib; - --GTypelib * g_typelib_new_from_memory (guchar *memory, -- gsize len); --GTypelib * g_typelib_new_from_const_memory (const guchar *memory, -- gsize len); --GTypelib * g_typelib_new_from_mapped_file (GMappedFile *mfile); -+GTypelib * g_typelib_new_from_memory (guint8 *memory, -+ gsize len, -+ GError **error); -+GTypelib * g_typelib_new_from_const_memory (const guint8 *memory, -+ gsize len, -+ GError **error); -+GTypelib * g_typelib_new_from_mapped_file (GMappedFile *mfile, -+ GError **error); - void g_typelib_free (GTypelib *typelib); - - gboolean g_typelib_symbol (GTypelib *typelib, -diff --git a/tools/compiler.c b/tools/compiler.c -index e6cddb8..d066428 100644 ---- a/tools/compiler.c -+++ b/tools/compiler.c -@@ -54,6 +54,7 @@ format_output (GTypelib *typelib) - - result = g_string_sized_new (6 * typelib->len); - -+ g_string_append_printf (result, "/* GENERATED CODE - DO NOT EDIT */\n"); - g_string_append_printf (result, "#include \n"); - g_string_append_printf (result, "#include \n\n"); - -@@ -84,7 +85,8 @@ format_output (GTypelib *typelib) - "register_typelib (void)\n" - "{\n" - "\tGTypelib *typelib;\n" -- "\ttypelib = g_typelib_new_from_const_memory (_G_TYPELIB, _G_TYPELIB_SIZE);\n" -+ "\ttypelib = g_typelib_new_from_const_memory (_G_TYPELIB, _G_TYPELIB_SIZE, NULL);\n" -+ "\tg_assert (typelib != NULL);\n" - "\tg_irepository_load_typelib (NULL, typelib, G_IREPOSITORY_LOAD_FLAG_LAZY, NULL);\n" - "}\n\n"); - } -diff --git a/tools/generate.c b/tools/generate.c -index cd1fedc..b456901 100644 ---- a/tools/generate.c -+++ b/tools/generate.c -@@ -29,45 +29,6 @@ - #include "girepository.h" - #include "gitypelib-internal.h" - --static const guchar * --load_typelib (const gchar *filename, -- GModule **dlhandle, -- gsize *len) --{ -- guchar *typelib; -- gsize *typelib_size; -- GModule *handle; -- -- handle = g_module_open (filename, G_MODULE_BIND_LOCAL|G_MODULE_BIND_LAZY); -- if (handle == NULL) -- { -- g_printerr ("Could not load typelib from '%s': %s\n", -- filename, g_module_error ()); -- return NULL; -- } -- -- if (!g_module_symbol (handle, "_G_TYPELIB", (gpointer *) &typelib)) -- { -- g_printerr ("Could not load typelib from '%s': %s\n", -- filename, g_module_error ()); -- return NULL; -- } -- -- if (!g_module_symbol (handle, "_G_TYPELIB_SIZE", (gpointer *) &typelib_size)) -- { -- g_printerr ("Could not load typelib from '%s': %s\n", -- filename, g_module_error ()); -- return NULL; -- } -- -- *len = *typelib_size; -- -- if (dlhandle) -- *dlhandle = handle; -- -- return typelib; --} -- - int - main (int argc, char *argv[]) - { -@@ -114,62 +75,31 @@ main (int argc, char *argv[]) - - for (i = 0; input[i]; i++) - { -- GModule *dlhandle = NULL; -- const guchar *typelib; -- gsize len; -+ GError *error = NULL; - const char *namespace; -+ GMappedFile *mfile; -+ GTypelib *typelib; - -- if (!shlib) -- { -- if (!g_file_get_contents (input[i], (gchar **)&typelib, &len, &error)) -- { -- g_fprintf (stderr, "failed to read '%s': %s\n", -- input[i], error->message); -- g_clear_error (&error); -- continue; -- } -- } -- else -- { -- typelib = load_typelib (input[i], &dlhandle, &len); -- if (!typelib) -- { -- g_fprintf (stderr, "failed to load typelib from '%s'\n", -- input[i]); -- continue; -- } -- } -+ mfile = g_mapped_file_new (input[i], FALSE, &error); -+ if (!mfile) -+ g_error ("failed to read '%s': %s", input[i], error->message); - - if (input[i + 1] && output) - needs_prefix = TRUE; - else - needs_prefix = FALSE; - -- data = g_typelib_new_from_const_memory (typelib, len); -- { -- GError *error = NULL; -- if (!g_typelib_validate (data, &error)) { -- g_printerr ("typelib not valid: %s\n", error->message); -- g_clear_error (&error); -- return 1; -- } -- } -- namespace = g_irepository_load_typelib (g_irepository_get_default (), data, 0, -+ typelib = g_typelib_new_from_mapped_file (mfile, &error); -+ if (!typelib) -+ g_error ("failed to create typelib '%s': %s", input[i], error->message); -+ -+ namespace = g_irepository_load_typelib (g_irepository_get_default (), typelib, 0, - &error); - if (namespace == NULL) -- { -- g_printerr ("failed to load typelib: %s\n", error->message); -- return 1; -- } -- -+ g_error ("failed to load typelib: %s", error->message); -+ - gir_writer_write (output, namespace, needs_prefix, show_all); - -- if (dlhandle) -- { -- g_module_close (dlhandle); -- dlhandle = NULL; -- } -- - /* when writing to stdout, stop after the first module */ - if (input[i + 1] && !output) - { --- -1.7.1.1 - diff --git a/gobject-introspection.spec b/gobject-introspection.spec index 61c9918..6871775 100644 --- a/gobject-introspection.spec +++ b/gobject-introspection.spec @@ -2,15 +2,15 @@ %{!?python_sitearch: %define python_sitearch %(%{__python} -c "from distutils.sysconfig import get_python_lib; print get_python_lib(1)")} Name: gobject-introspection -Version: 0.9.3 -Release: 6%{?dist} +Version: 0.9.6 +Release: 1%{?dist} Summary: Introspection system for GObject-based libraries Group: Development/Libraries License: GPLv2+, LGPLv2+, MIT URL: http://live.gnome.org/GObjectIntrospection #VCS: git:git://git.gnome.org/gobject-introspection -Source0: gobject-introspection-0.9.3.tar.gz +Source0: gobject-introspection-%{version}.tar.bz2 Obsoletes: gir-repository @@ -51,7 +51,7 @@ Obsoletes: gir-repository-devel Libraries and headers for gobject-introspection %prep -%setup -q -n gobject-introspection-0.9.3 +%setup -q %build (if ! test -x configure; then NOCONFIGURE=1 ./autogen.sh; CONFIGFLAGS=--enable-gtk-doc; fi; @@ -61,11 +61,6 @@ make V=1 %{?_smp_mflags} %install make install DESTDIR=$RPM_BUILD_ROOT -# Strip out the test libraries; these will go away upstream -rm $RPM_BUILD_ROOT/%{_libdir}/libgirepository-{everything,gimarshallingtests}*.so* -rm $RPM_BUILD_ROOT/%{_libdir}/girepository-1.0/{GIMarshallingTests,Everything}*.typelib -rm $RPM_BUILD_ROOT/%{_datadir}/gir-1.0/{GIMarshallingTests,Everything}*.gir - # Die libtool, die. find $RPM_BUILD_ROOT -type f -name "*.la" -exec rm -f {} ';' find $RPM_BUILD_ROOT -type f -name "*.a" -exec rm -f {} ';' @@ -99,6 +94,9 @@ find $RPM_BUILD_ROOT -type f -name "*.a" -exec rm -f {} ';' #%{_datadir}/gtk-doc/html/gi/* %changelog +* Tue Sep 21 2010 Owen Taylor - 0.9.6-1 +- Update to 0.9.6 + * Thu Sep 2 2010 Colin Walters - 0.9.3-6 - Strip out test libraries; they're gone in upstream git, and create a dependency on cairo (which requires libX11, which makes diff --git a/py2.7-compat.patch b/py2.7-compat.patch deleted file mode 100644 index bd2efd6..0000000 --- a/py2.7-compat.patch +++ /dev/null @@ -1,39 +0,0 @@ -From 7bcb292e7ff35764a02629213589f304df8b5076 Mon Sep 17 00:00:00 2001 -From: Johan Dahlin -Date: Thu, 22 Jul 2010 14:43:02 -0300 -Subject: [PATCH] [scanner] Make it compatible with python 2.y - -https://bugzilla.gnome.org/show_bug.cgi?id=618562 ---- - giscanner/sourcescanner.py | 2 +- - giscanner/xmlwriter.py | 2 +- - 2 files changed, 2 insertions(+), 2 deletions(-) - -diff --git a/giscanner/sourcescanner.py b/giscanner/sourcescanner.py -index acfc048..ae3d29d 100644 ---- a/giscanner/sourcescanner.py -+++ b/giscanner/sourcescanner.py -@@ -196,7 +196,7 @@ class SourceSymbol(object): - class SourceScanner(object): - - def __init__(self): -- with LibtoolImporter: -+ with LibtoolImporter(None, None): - from giscanner._giscanner import SourceScanner - self._scanner = SourceScanner() - self._filenames = [] -diff --git a/giscanner/xmlwriter.py b/giscanner/xmlwriter.py -index 0db286b..c10bcc6 100644 ---- a/giscanner/xmlwriter.py -+++ b/giscanner/xmlwriter.py -@@ -67,7 +67,7 @@ def collect_attributes(tag_name, attributes, self_indent, - return attr_value - - --with LibtoolImporter: -+with LibtoolImporter(None, None): - from giscanner._giscanner import collect_attributes - - --- -1.7.0.4 \ No newline at end of file diff --git a/sources b/sources index fadd71d..3be859d 100644 --- a/sources +++ b/sources @@ -1 +1 @@ -7a9264c7a8d4174d97b9b10f4efa286e gobject-introspection-0.9.3.tar.gz +756bf1b012b97d64821e6d892d527173 gobject-introspection-0.9.6.tar.bz2