diff --git a/epiphany-2.22.0.tar.bz2 b/epiphany-2.22.0.tar.bz2 deleted file mode 100644 index e96641a..0000000 --- a/epiphany-2.22.0.tar.bz2 +++ /dev/null @@ -1,3 +0,0 @@ -version https://git-lfs.github.com/spec/v1 -oid sha256:692c642f99ea52ac86acf1c00c31f2567cba1e155e5d93462625bd208dca7122 -size 5163182 diff --git a/epiphany-2.22.1.1.tar.bz2 b/epiphany-2.22.1.1.tar.bz2 new file mode 100644 index 0000000..64452ec --- /dev/null +++ b/epiphany-2.22.1.1.tar.bz2 @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:46100589113150e8233ada4a26de030f0a240378c103406559d56fe403433866 +size 5184989 diff --git a/epiphany-avahi-bookmarks.patch b/epiphany-avahi-bookmarks.patch deleted file mode 100644 index 02c8be2..0000000 --- a/epiphany-avahi-bookmarks.patch +++ /dev/null @@ -1,506 +0,0 @@ -Index: src/bookmarks/ephy-bookmarks.c -=================================================================== ---- src/bookmarks/ephy-bookmarks.c (Revision 8092) -+++ src/bookmarks/ephy-bookmarks.c (Arbeitskopie) -@@ -136,40 +136,11 @@ - static void ephy_bookmarks_finalize (GObject *object); - static char *impl_resolve_address (EphyBookmarks*, const char*, const char*); - --static GObjectClass *parent_class = NULL; -+G_DEFINE_TYPE_WITH_CODE (EphyBookmarks, ephy_bookmarks, G_TYPE_OBJECT, -+ volatile GType flags_type; /* work around gcc's optimiser */ -+ /* make sure the flags type is known */ -+ flags_type = EPHY_TYPE_BOOKMARK_PROPERTY;) - --GType --ephy_bookmarks_get_type (void) --{ -- static GType type = 0; -- -- if (G_UNLIKELY (type == 0)) -- { -- const GTypeInfo our_info = -- { -- sizeof (EphyBookmarksClass), -- NULL, /* base_init */ -- NULL, /* base_finalize */ -- (GClassInitFunc) ephy_bookmarks_class_init, -- NULL, -- NULL, /* class_data */ -- sizeof (EphyBookmarks), -- 0, /* n_preallocs */ -- (GInstanceInitFunc) ephy_bookmarks_init -- }; -- volatile GType flags_type; /* work around gcc's optimiser */ -- -- /* make sure the flags type is known */ -- flags_type = EPHY_TYPE_BOOKMARK_PROPERTY; -- -- type = g_type_register_static (G_TYPE_OBJECT, -- "EphyBookmarks", -- &our_info, 0); -- } -- -- return type; --} -- - static void - ephy_bookmarks_init_defaults (EphyBookmarks *eb) - { -@@ -194,8 +165,6 @@ - { - GObjectClass *object_class = G_OBJECT_CLASS (klass); - -- parent_class = g_type_class_peek_parent (klass); -- - object_class->finalize = ephy_bookmarks_finalize; - - klass->resolve_address = impl_resolve_address; -@@ -799,7 +768,10 @@ - char *key_dup, *value_dup; - char *raw_txt; - size_t raw_txt_len; -- -+ -+ if (!input_text) -+ return NULL; -+ - raw_txt_len = avahi_string_list_serialize (input_text, NULL, 0); - raw_txt = g_malloc (raw_txt_len); - raw_txt_len = avahi_string_list_serialize (input_text, raw_txt, raw_txt_len); -@@ -868,41 +840,14 @@ - name); - } - --static EphyNode * --get_node_for_id (EphyBookmarks *bookmarks, -- char *node_id) --{ -- EphyBookmarksPrivate *priv = bookmarks->priv; -- EphyNode *kid, *node = NULL; -- GPtrArray *children; -- const char *id; -- guint i; -- -- children = ephy_node_get_children (priv->local); -- for (i = 0; i < children->len; i++) -- { -- kid = g_ptr_array_index (children, i); -- -- id = ephy_node_get_property_string (kid, -- EPHY_NODE_BMK_PROP_SERVICE_ID); -- -- if (g_str_equal (id, node_id)) -- { -- node = kid; -- break; -- } -- } -- -- g_free (node_id); -- -- return node; --} -- - typedef struct - { - EphyBookmarks *bookmarks; -+ GaServiceResolver *resolver; - EphyNode *node; -- guint new_node : 1; -+ char *name; -+ char *type; -+ char *domain; - } ResolveData; - - static void -@@ -921,20 +866,20 @@ - { - EphyBookmarks *bookmarks = data->bookmarks; - EphyBookmarksPrivate *priv = bookmarks->priv; -- EphyNode *node = data->node; - GValue value = { 0, }; - const char *path = NULL; - char host[128]; - GHashTable *text_table; - char *url; - gboolean was_immutable; -+ gboolean is_new_node = FALSE; - guint i; - -+ g_print ("resolver_found_cb resolver %p\n", resolver); -+ - was_immutable = ephy_node_db_is_immutable (priv->db); - ephy_node_db_set_immutable (priv->db, FALSE); - -- g_hash_table_steal (priv->resolve_handles, node); -- - /* Find the protocol */ - for (i = 0; i < G_N_ELEMENTS (zeroconf_protos); ++i) - { -@@ -945,6 +890,12 @@ - } - if (i == G_N_ELEMENTS (zeroconf_protos)) return; - -+ if (address == NULL) -+ { -+ g_warning ("Zeroconf failed to resolve host %s", name); -+ return; -+ } -+ - text_table = decode_txt_record (txt); - - if (text_table != NULL) -@@ -956,32 +907,60 @@ - path = "/"; - } - -- if (address == NULL) -- { -- g_warning ("Zeroconf failed to resolve host %s", name); -- return; -- } - avahi_address_snprint (host, sizeof (host), address); - - LOG ("0conf RESOLVED type=%s domain=%s name=%s => proto=%s host=%s port=%d path=%s\n", - type, domain, name, - zeroconf_protos[i], host, port, path); - -+ was_immutable = ephy_node_db_is_immutable (priv->db); -+ ephy_node_db_set_immutable (priv->db, FALSE); -+ -+ if (data->node == NULL) -+ { -+ is_new_node = TRUE; -+ -+ data->node = ephy_node_new (priv->db); -+ g_assert (data->node != NULL); -+ -+ /* don't allow dragging this node */ -+ ephy_node_set_is_drag_source (data->node, FALSE); -+ -+ g_value_init (&value, G_TYPE_STRING); -+ g_value_take_string (&value, -+ get_id_for_response (data->type, -+ data->domain, -+ data->name)); -+ ephy_node_set_property (data->node, EPHY_NODE_BMK_PROP_SERVICE_ID, &value); -+ g_value_unset (&value); -+ -+ /* FIXME: limit length! */ -+ ephy_node_set_property_string (data->node, -+ EPHY_NODE_BMK_PROP_TITLE, -+ name); -+ -+ ephy_node_set_property_boolean (data->node, -+ EPHY_NODE_BMK_PROP_IMMUTABLE, -+ TRUE); -+ } -+ - /* FIXME: limit length! */ - url = g_strdup_printf ("%s://%s:%d%s", zeroconf_protos[i], host, port, path); - - g_value_init (&value, G_TYPE_STRING); - g_value_take_string (&value, url); -- ephy_node_set_property (node, EPHY_NODE_BMK_PROP_LOCATION, &value); -+ ephy_node_set_property (data->node, EPHY_NODE_BMK_PROP_LOCATION, &value); - g_value_unset (&value); - -- if (data->new_node) -+ if (is_new_node) - { -- ephy_node_add_child (priv->bookmarks, node); -- ephy_node_add_child (priv->local, node); -+ ephy_node_add_child (priv->bookmarks, data->node); -+ ephy_node_add_child (priv->local, data->node); - } - - ephy_node_db_set_immutable (priv->db, was_immutable); -+ -+ g_hash_table_unref (text_table); - } - - static void -@@ -989,56 +968,36 @@ - GError *error, - ResolveData *data) - { -- EphyBookmarks *bookmarks = data->bookmarks; -- EphyBookmarksPrivate *priv = bookmarks->priv; -- EphyNode *node = data->node; -- gboolean was_immutable; -+ g_print ("resolver_failure_cb resolver %p: %s\n", resolver, error?error->message:"(null)"); - -- was_immutable = ephy_node_db_is_immutable (priv->db); -- ephy_node_db_set_immutable (priv->db, FALSE); -+ /* Remove the node, if present */ -+ if (data->node != NULL) -+ { -+ EphyBookmarks *bookmarks = data->bookmarks; -+ EphyBookmarksPrivate *priv = bookmarks->priv; -+ gboolean was_immutable; - -- g_hash_table_steal (priv->resolve_handles, node); -- -- /* Error, don't add the service */ -- ephy_node_unref (node); -- ephy_node_db_set_immutable (priv->db, was_immutable); -- -- return; -+ was_immutable = ephy_node_db_is_immutable (priv->db); -+ ephy_node_db_set_immutable (priv->db, FALSE); -+ ephy_node_unref (data->node); -+ data->node = NULL; -+ ephy_node_db_set_immutable (priv->db, was_immutable); -+ } - } - - static void --free_resolve_cb_data (gpointer data) -+resolve_data_free (ResolveData* data) - { -+ if (data->resolver) -+ g_object_unref (data->resolver); -+ -+ g_free (data->type); -+ g_free (data->name); -+ g_free (data->domain); - g_slice_free (ResolveData, data); - } - - static void --browser_removed_service_cb (GaServiceBrowser *browser, -- int interface, -- GaProtocol protocol, -- const char *name, -- const char *type, -- const char *domain, -- glong flags, -- EphyBookmarks *bookmarks) --{ -- EphyBookmarksPrivate *priv = bookmarks->priv; -- EphyNode *node; -- char *node_id; -- -- node_id = get_id_for_response (type, domain, name); -- node = get_node_for_id (bookmarks, node_id); -- -- if (node != NULL) -- { -- g_hash_table_remove (priv->resolve_handles, node); -- ephy_node_unref (node); -- } -- -- return; --} -- --static void - browser_new_service_cb (GaServiceBrowser *browser, - int interface, - GaProtocol protocol, -@@ -1049,84 +1008,91 @@ - EphyBookmarks *bookmarks) - { - EphyBookmarksPrivate *priv = bookmarks->priv; -- EphyNode *node; -- GValue value = { 0, }; -- gboolean new_node = FALSE; -- GaServiceResolver *resolver = NULL; - ResolveData *data; - char *node_id; -+ GError *error = NULL; - - node_id = get_id_for_response (type, domain, name); -- node = get_node_for_id (bookmarks, node_id); - - LOG ("0conf ADD: type=%s domain=%s name=%s\n", - type, domain, name); - -- if (node != NULL && -- g_hash_table_lookup (priv->resolve_handles, node) != NULL) return; -- -- if (node == NULL) -+ if (g_hash_table_lookup (priv->resolve_handles, node_id) != NULL) - { -- gboolean was_immutable; -- -- was_immutable = ephy_node_db_is_immutable (priv->db); -- ephy_node_db_set_immutable (priv->db, FALSE); -- -- node = ephy_node_new (priv->db); -- g_assert (node != NULL); -- -- new_node = TRUE; -- -- /* don't allow dragging this node */ -- ephy_node_set_is_drag_source (node, FALSE); -- -- g_value_init (&value, G_TYPE_STRING); -- g_value_take_string (&value, get_id_for_response (type, domain, name)); -- ephy_node_set_property (node, EPHY_NODE_BMK_PROP_SERVICE_ID, &value); -- g_value_unset (&value); -- -- /* FIXME: limit length! */ -- ephy_node_set_property_string (node, -- EPHY_NODE_BMK_PROP_TITLE, -- name); -- -- ephy_node_set_property_boolean (node, -- EPHY_NODE_BMK_PROP_IMMUTABLE, -- TRUE); -- -- ephy_node_db_set_immutable (priv->db, was_immutable); -+ g_free (node_id); -+ return; - } - - data = g_slice_new0 (ResolveData); - data->bookmarks = bookmarks; -- data->node = node; -- data->new_node = new_node; -+ data->node = NULL; -+ data->type = g_strdup (type); -+ data->name = g_strdup (name); -+ data->domain = g_strdup (domain); - -- resolver = ga_service_resolver_new (AVAHI_IF_UNSPEC, -- AVAHI_PROTO_UNSPEC, -- name, type, domain, -- AVAHI_PROTO_UNSPEC, -- GA_LOOKUP_USE_MULTICAST); -- g_signal_connect_data (resolver, "found", -- G_CALLBACK (resolver_found_cb), data, -- (GClosureNotify) free_resolve_cb_data, 0); -- g_signal_connect_data (resolver, "failure", -- G_CALLBACK (resolver_failure_cb), data, -- (GClosureNotify) free_resolve_cb_data, 0); -- if (!ga_service_resolver_attach (resolver, -+ data->resolver = ga_service_resolver_new (AVAHI_IF_UNSPEC, -+ AVAHI_PROTO_UNSPEC, -+ name, type, domain, -+ AVAHI_PROTO_UNSPEC, -+ GA_LOOKUP_USE_MULTICAST); -+ g_signal_connect (data->resolver, "found", -+ G_CALLBACK (resolver_found_cb), data); -+ g_signal_connect (data->resolver, "failure", -+ G_CALLBACK (resolver_failure_cb), data); -+ if (!ga_service_resolver_attach (data->resolver, - priv->ga_client, -- NULL)) -+ &error)) - { -- g_warning ("Unable to resolve Zeroconf service %s", name); -- ephy_node_unref (node); -- free_resolve_cb_data (data); -+ g_warning ("Unable to resolve Zeroconf service %s: %s", name, error ? error->message : "(null)"); -+ g_clear_error (&error); -+ resolve_data_free (data); -+ g_free (node_id); - return; - } -+ - g_hash_table_insert (priv->resolve_handles, -- node, resolver); -+ node_id /* transfer ownership */, data); - } - - static void -+browser_removed_service_cb (GaServiceBrowser *browser, -+ int interface, -+ GaProtocol protocol, -+ const char *name, -+ const char *type, -+ const char *domain, -+ glong flags, -+ EphyBookmarks *bookmarks) -+{ -+ EphyBookmarksPrivate *priv = bookmarks->priv; -+ char *node_id; -+ ResolveData *data; -+ -+ node_id = get_id_for_response (type, domain, name); -+ data = g_hash_table_lookup (priv->resolve_handles, node_id); -+ /* shouldn't really happen, but let's play safe */ -+ if (!data) -+ { -+ g_free (node_id); -+ return; -+ } -+ -+ if (data->node != NULL) -+ { -+ gboolean was_immutable; -+ -+ was_immutable = ephy_node_db_is_immutable (priv->db); -+ ephy_node_db_set_immutable (priv->db, FALSE); -+ ephy_node_unref (data->node); -+ data->node = NULL; -+ ephy_node_db_set_immutable (priv->db, was_immutable); -+ } -+ -+ g_hash_table_remove (priv->resolve_handles, node_id); -+ g_free (node_id); -+} -+ -+static void - start_browsing (GaClient *ga_client, - EphyBookmarks *bookmarks) - { -@@ -1150,9 +1116,10 @@ - NULL)) - { - g_warning ("Unable to start Zeroconf subsystem"); -+ g_object_unref (browser); - return; - } -- -+ - priv->browse_handles[i] = browser; - } - } -@@ -1166,6 +1133,7 @@ - { - if (avahi_client_errno (ga_client->avahi_client) == AVAHI_ERR_DISCONNECTED) - { -+ /* FIXMEchpe: is this correct */ - /* Destroy and reconnect */ - avahi_client_free (ga_client->avahi_client); - ga_client->avahi_client = NULL; -@@ -1197,7 +1165,9 @@ - return; - } - priv->ga_client = ga_client; -- priv->resolve_handles = g_hash_table_new (g_direct_hash, g_direct_equal); -+ priv->resolve_handles = g_hash_table_new_full (g_str_hash, g_str_equal, -+ g_free, -+ (GDestroyNotify) resolve_data_free); - } - - static void -@@ -1210,6 +1180,7 @@ - { - if (priv->browse_handles[i] != NULL) - { -+ g_object_unref (priv->browse_handles[i]); - priv->browse_handles[i] = NULL; - } - } -@@ -1222,7 +1193,8 @@ - - if (priv->local != NULL) - { -- ephy_node_remove_child (priv->keywords, priv->local); -+ ephy_node_unref (priv->local); -+ priv->local = NULL; - } - - if (priv->ga_client != NULL) -@@ -1431,7 +1403,7 @@ - - LOG ("Bookmarks finalized"); - -- G_OBJECT_CLASS (parent_class)->finalize (object); -+ G_OBJECT_CLASS (ephy_bookmarks_parent_class)->finalize (object); - } - - EphyBookmarks * diff --git a/epiphany.changes b/epiphany.changes index f57bd2f..e5958c1 100644 --- a/epiphany.changes +++ b/epiphany.changes @@ -1,3 +1,26 @@ +------------------------------------------------------------------- +Thu Apr 10 16:41:28 CEST 2008 - maw@suse.de + +- Update to version 2.22.1.1: + + Revert the bookmark/history item no-dupes patch; it was slowing + down ephy + + Remove the unnecessary setting of the preferred action in the + cases that action was going to be the default one anyway; don't + open twice, just let gecko handle opening in the preferred + application + + Make the extra column pack-end so that when we hide it when + it's empty, the other column expands; this makes bookmarks + take up all the space instead of being truncated at the half + + Bugs fixed: + * Use ephy_password_info_new to allocate EphyPasswordInfo, not + g_new; fixes a crash in the PDM passwords tab + * Fix multiple crashers in the zeroconf bookmarks (bgo#516008) + * Use g_slice for EphyCookie allocation (bgo#520560) + * Use g_slice for EphyPasswordInfo, EphyPermissionInfo, + PixbufCacheEntry (bgo#521017) + + Updated translations +- Drop epiphany-avahi-bookmarks.patch. + ------------------------------------------------------------------- Wed Mar 26 10:42:39 CET 2008 - sbrabec@suse.cz diff --git a/epiphany.spec b/epiphany.spec index 39d8864..ff3b685 100644 --- a/epiphany.spec +++ b/epiphany.spec @@ -1,5 +1,5 @@ # -# spec file for package epiphany (Version 2.22.0) +# spec file for package epiphany (Version 2.22.1.1) # # Copyright (c) 2008 SUSE LINUX Products GmbH, Nuernberg, Germany. # This file and all modifications and additions to the pristine @@ -29,8 +29,8 @@ BuildRequires: mozilla-devel Requires: mozilla = %{mozilla_ver} %endif %endif -Version: 2.22.0 -Release: 9 +Version: 2.22.1.1 +Release: 1 Requires: %{name}-lang = %{version} License: GPL v2 or later Group: Productivity/Networking/Web/Browsers @@ -41,8 +41,7 @@ Patch1: epiphany-browser-plugins.patch #PATCH-FIX-OPENSUSE default-bookmarks.patch bnc293690 -- openSUSE specific bookmarks #BRAND: FIXME: There is no way to customize vendor bookmarks in epiphany yet. Patch2: default-bookmarks.patch -#PATCH-FIX-UPSTREAM epiphany-avahi-bookmarks.patch bgo516008 -- avahi bookmarks processing -Patch3: epiphany-avahi-bookmarks.patch +### #PATCH-FIX-UPSTREAM epiphany-avahi-bookmarks.patch bgo516008 -- avahi bookmarks processing Url: http://www.gnome.org/projects/epiphany/ BuildRoot: %{_tmppath}/%{name}-%{version}-build Requires: python-gtk python-gnome iso-codes gnome-icon-theme @@ -65,6 +64,7 @@ Authors: Crispin Flowerday %package devel +License: GPL v2 or later Summary: GNOME Web Browser based on the Mozilla Rendering Engine Group: Development/Libraries/GNOME Requires: gtk2-devel libxml2-devel @@ -86,6 +86,7 @@ Authors: Crispin Flowerday %package doc +License: GPL v2 or later Summary: Developer Documentation for Epiphany Group: Productivity/Networking/Web/Browsers Requires: %{name} = %{version} @@ -112,7 +113,6 @@ Authors: %setup -q %patch1 %patch2 -p1 -%patch3 %build #cp -i data/default-prefs-gecko-1-8.js data/default-prefs-xulrunner.js @@ -186,6 +186,26 @@ rm -rf $RPM_BUILD_ROOT %{_datadir}/gtk-doc/html/epiphany %changelog +* Thu Apr 10 2008 maw@suse.de +- Update to version 2.22.1.1: + + Revert the bookmark/history item no-dupes patch; it was slowing + down ephy + + Remove the unnecessary setting of the preferred action in the + cases that action was going to be the default one anyway; don't + open twice, just let gecko handle opening in the preferred + application + + Make the extra column pack-end so that when we hide it when + it's empty, the other column expands; this makes bookmarks + take up all the space instead of being truncated at the half + + Bugs fixed: + * Use ephy_password_info_new to allocate EphyPasswordInfo, not + g_new; fixes a crash in the PDM passwords tab + * Fix multiple crashers in the zeroconf bookmarks (bgo#516008) + * Use g_slice for EphyCookie allocation (bgo#520560) + * Use g_slice for EphyPasswordInfo, EphyPermissionInfo, + PixbufCacheEntry (bgo#521017) + + Updated translations +- Drop epiphany-avahi-bookmarks.patch. * Wed Mar 26 2008 sbrabec@suse.cz - Fixed crashes in avahi bookmarks processing (bgo#516008). * Fri Mar 21 2008 jpr@suse.de @@ -257,7 +277,7 @@ rm -rf $RPM_BUILD_ROOT - Use %%fdupes. * Sat Jul 14 2007 aj@suse.de - It's really libwnck-devel. -* Mon Jul 09 2007 maw@suse.de +* Tue Jul 10 2007 maw@suse.de - Update to version 2.19.2 - Fixes for bugzilla.gnome.org #348350, #452769, #450590, #450146, [#346243], #351100, #433796 , #441419, #336739, #422114, #437798, @@ -268,7 +288,7 @@ rm -rf $RPM_BUILD_ROOT * Fixed printing of frames. * Fixed Epiphany not finding some Gecko plugins. - Removed Flash crash work-around (upstream part of ephy-main.c). -* Tue Apr 03 2007 maw@suse.de +* Wed Apr 04 2007 maw@suse.de - Remove all references to epiphany-dbus-connection-close-fix-thoenig-01.patch (#260495). * Mon Apr 02 2007 maw@suse.de @@ -365,7 +385,7 @@ rm -rf $RPM_BUILD_ROOT - Explicitly require iso-codes (#147467). * Wed Jan 25 2006 mls@suse.de - converted neededforbuild to BuildRequires -* Wed Nov 30 2005 gekker@suse.de +* Thu Dec 01 2005 gekker@suse.de - Update to version 1.8.3 - Remove upstreamed xulrunner patch * Wed Nov 16 2005 sbrabec@suse.cz