OBS User unknown 2008-04-24 07:24:04 +00:00 committed by Git OBS Bridge
parent f6474b2ab6
commit cfec3f9042
5 changed files with 55 additions and 518 deletions

View File

@ -1,3 +0,0 @@
version https://git-lfs.github.com/spec/v1
oid sha256:692c642f99ea52ac86acf1c00c31f2567cba1e155e5d93462625bd208dca7122
size 5163182

View File

@ -0,0 +1,3 @@
version https://git-lfs.github.com/spec/v1
oid sha256:46100589113150e8233ada4a26de030f0a240378c103406559d56fe403433866
size 5184989

View File

@ -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 *

View File

@ -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

View File

@ -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 <crispin@flowerday.cx>
%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 <crispin@flowerday.cx>
%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