This commit is contained in:
parent
f6474b2ab6
commit
cfec3f9042
@ -1,3 +0,0 @@
|
|||||||
version https://git-lfs.github.com/spec/v1
|
|
||||||
oid sha256:692c642f99ea52ac86acf1c00c31f2567cba1e155e5d93462625bd208dca7122
|
|
||||||
size 5163182
|
|
3
epiphany-2.22.1.1.tar.bz2
Normal file
3
epiphany-2.22.1.1.tar.bz2
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
version https://git-lfs.github.com/spec/v1
|
||||||
|
oid sha256:46100589113150e8233ada4a26de030f0a240378c103406559d56fe403433866
|
||||||
|
size 5184989
|
@ -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 *
|
|
@ -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
|
Wed Mar 26 10:42:39 CET 2008 - sbrabec@suse.cz
|
||||||
|
|
||||||
|
@ -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.
|
# Copyright (c) 2008 SUSE LINUX Products GmbH, Nuernberg, Germany.
|
||||||
# This file and all modifications and additions to the pristine
|
# This file and all modifications and additions to the pristine
|
||||||
@ -29,8 +29,8 @@ BuildRequires: mozilla-devel
|
|||||||
Requires: mozilla = %{mozilla_ver}
|
Requires: mozilla = %{mozilla_ver}
|
||||||
%endif
|
%endif
|
||||||
%endif
|
%endif
|
||||||
Version: 2.22.0
|
Version: 2.22.1.1
|
||||||
Release: 9
|
Release: 1
|
||||||
Requires: %{name}-lang = %{version}
|
Requires: %{name}-lang = %{version}
|
||||||
License: GPL v2 or later
|
License: GPL v2 or later
|
||||||
Group: Productivity/Networking/Web/Browsers
|
Group: Productivity/Networking/Web/Browsers
|
||||||
@ -41,8 +41,7 @@ Patch1: epiphany-browser-plugins.patch
|
|||||||
#PATCH-FIX-OPENSUSE default-bookmarks.patch bnc293690 -- openSUSE specific bookmarks
|
#PATCH-FIX-OPENSUSE default-bookmarks.patch bnc293690 -- openSUSE specific bookmarks
|
||||||
#BRAND: FIXME: There is no way to customize vendor bookmarks in epiphany yet.
|
#BRAND: FIXME: There is no way to customize vendor bookmarks in epiphany yet.
|
||||||
Patch2: default-bookmarks.patch
|
Patch2: default-bookmarks.patch
|
||||||
#PATCH-FIX-UPSTREAM epiphany-avahi-bookmarks.patch bgo516008 -- avahi bookmarks processing
|
### #PATCH-FIX-UPSTREAM epiphany-avahi-bookmarks.patch bgo516008 -- avahi bookmarks processing
|
||||||
Patch3: epiphany-avahi-bookmarks.patch
|
|
||||||
Url: http://www.gnome.org/projects/epiphany/
|
Url: http://www.gnome.org/projects/epiphany/
|
||||||
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
||||||
Requires: python-gtk python-gnome iso-codes gnome-icon-theme
|
Requires: python-gtk python-gnome iso-codes gnome-icon-theme
|
||||||
@ -65,6 +64,7 @@ Authors:
|
|||||||
Crispin Flowerday <crispin@flowerday.cx>
|
Crispin Flowerday <crispin@flowerday.cx>
|
||||||
|
|
||||||
%package devel
|
%package devel
|
||||||
|
License: GPL v2 or later
|
||||||
Summary: GNOME Web Browser based on the Mozilla Rendering Engine
|
Summary: GNOME Web Browser based on the Mozilla Rendering Engine
|
||||||
Group: Development/Libraries/GNOME
|
Group: Development/Libraries/GNOME
|
||||||
Requires: gtk2-devel libxml2-devel
|
Requires: gtk2-devel libxml2-devel
|
||||||
@ -86,6 +86,7 @@ Authors:
|
|||||||
Crispin Flowerday <crispin@flowerday.cx>
|
Crispin Flowerday <crispin@flowerday.cx>
|
||||||
|
|
||||||
%package doc
|
%package doc
|
||||||
|
License: GPL v2 or later
|
||||||
Summary: Developer Documentation for Epiphany
|
Summary: Developer Documentation for Epiphany
|
||||||
Group: Productivity/Networking/Web/Browsers
|
Group: Productivity/Networking/Web/Browsers
|
||||||
Requires: %{name} = %{version}
|
Requires: %{name} = %{version}
|
||||||
@ -112,7 +113,6 @@ Authors:
|
|||||||
%setup -q
|
%setup -q
|
||||||
%patch1
|
%patch1
|
||||||
%patch2 -p1
|
%patch2 -p1
|
||||||
%patch3
|
|
||||||
|
|
||||||
%build
|
%build
|
||||||
#cp -i data/default-prefs-gecko-1-8.js data/default-prefs-xulrunner.js
|
#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
|
%{_datadir}/gtk-doc/html/epiphany
|
||||||
|
|
||||||
%changelog
|
%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
|
* Wed Mar 26 2008 sbrabec@suse.cz
|
||||||
- Fixed crashes in avahi bookmarks processing (bgo#516008).
|
- Fixed crashes in avahi bookmarks processing (bgo#516008).
|
||||||
* Fri Mar 21 2008 jpr@suse.de
|
* Fri Mar 21 2008 jpr@suse.de
|
||||||
@ -257,7 +277,7 @@ rm -rf $RPM_BUILD_ROOT
|
|||||||
- Use %%fdupes.
|
- Use %%fdupes.
|
||||||
* Sat Jul 14 2007 aj@suse.de
|
* Sat Jul 14 2007 aj@suse.de
|
||||||
- It's really libwnck-devel.
|
- 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
|
- Update to version 2.19.2
|
||||||
- Fixes for bugzilla.gnome.org #348350, #452769, #450590, #450146,
|
- Fixes for bugzilla.gnome.org #348350, #452769, #450590, #450146,
|
||||||
[#346243], #351100, #433796 , #441419, #336739, #422114, #437798,
|
[#346243], #351100, #433796 , #441419, #336739, #422114, #437798,
|
||||||
@ -268,7 +288,7 @@ rm -rf $RPM_BUILD_ROOT
|
|||||||
* Fixed printing of frames.
|
* Fixed printing of frames.
|
||||||
* Fixed Epiphany not finding some Gecko plugins.
|
* Fixed Epiphany not finding some Gecko plugins.
|
||||||
- Removed Flash crash work-around (upstream part of ephy-main.c).
|
- 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
|
- Remove all references to
|
||||||
epiphany-dbus-connection-close-fix-thoenig-01.patch (#260495).
|
epiphany-dbus-connection-close-fix-thoenig-01.patch (#260495).
|
||||||
* Mon Apr 02 2007 maw@suse.de
|
* Mon Apr 02 2007 maw@suse.de
|
||||||
@ -365,7 +385,7 @@ rm -rf $RPM_BUILD_ROOT
|
|||||||
- Explicitly require iso-codes (#147467).
|
- Explicitly require iso-codes (#147467).
|
||||||
* Wed Jan 25 2006 mls@suse.de
|
* Wed Jan 25 2006 mls@suse.de
|
||||||
- converted neededforbuild to BuildRequires
|
- converted neededforbuild to BuildRequires
|
||||||
* Wed Nov 30 2005 gekker@suse.de
|
* Thu Dec 01 2005 gekker@suse.de
|
||||||
- Update to version 1.8.3
|
- Update to version 1.8.3
|
||||||
- Remove upstreamed xulrunner patch
|
- Remove upstreamed xulrunner patch
|
||||||
* Wed Nov 16 2005 sbrabec@suse.cz
|
* Wed Nov 16 2005 sbrabec@suse.cz
|
||||||
|
Loading…
Reference in New Issue
Block a user