Blob Blame History Raw
diff -up evolution-3.22.6/e-util/e-name-selector-entry.c.name-selector-entry-fake-changed-signal evolution-3.22.6/e-util/e-name-selector-entry.c
--- evolution-3.22.6/e-util/e-name-selector-entry.c.name-selector-entry-fake-changed-signal	2017-01-27 12:06:11.000000000 +0100
+++ evolution-3.22.6/e-util/e-name-selector-entry.c	2017-04-18 10:51:23.716045722 +0200
@@ -65,6 +65,8 @@ struct _ENameSelectorEntryPrivate {
 	GQueue cancellables;
 
 	GHashTable *known_contacts; /* gchar * ~> 1 */
+
+	gboolean block_entry_changed_signal;
 };
 
 enum {
@@ -2028,6 +2030,16 @@ sanitize_entry (ENameSelectorEntry *name
 	generate_attribute_list (name_selector_entry);
 }
 
+static void
+maybe_block_entry_changed_cb (ENameSelectorEntry *name_selector_entry,
+			      gpointer user_data)
+{
+	g_return_if_fail (E_IS_NAME_SELECTOR_ENTRY (name_selector_entry));
+
+	if (name_selector_entry->priv->block_entry_changed_signal)
+		g_signal_stop_emission_by_name (name_selector_entry, "changed");
+}
+
 static gboolean
 user_focus_in (ENameSelectorEntry *name_selector_entry,
                GdkEventFocus *event_focus)
@@ -2037,6 +2049,8 @@ user_focus_in (ENameSelectorEntry *name_
 	GString *str = g_string_new ("");
 	EDestination *dest_dummy = e_destination_new ();
 
+	/* To not send fake 'changed' signals, which can influence message composer */
+	name_selector_entry->priv->block_entry_changed_signal = TRUE;
 	g_signal_handlers_block_matched (name_selector_entry, G_SIGNAL_MATCH_DATA, 0, 0, NULL, NULL, name_selector_entry);
 	g_signal_handlers_block_matched (name_selector_entry->priv->destination_store, G_SIGNAL_MATCH_DATA, 0, 0, NULL, NULL, name_selector_entry);
 
@@ -2072,6 +2086,7 @@ user_focus_in (ENameSelectorEntry *name_
 
 	g_signal_handlers_unblock_matched (name_selector_entry->priv->destination_store, G_SIGNAL_MATCH_DATA, 0, 0, NULL, NULL, name_selector_entry);
 	g_signal_handlers_unblock_matched (name_selector_entry, G_SIGNAL_MATCH_DATA, 0, 0, NULL, NULL, name_selector_entry);
+	name_selector_entry->priv->block_entry_changed_signal = FALSE;
 
 	generate_attribute_list (name_selector_entry);
 
@@ -3381,11 +3396,15 @@ e_name_selector_entry_init (ENameSelecto
 
 	name_selector_entry->priv->minimum_query_length = 3;
 	name_selector_entry->priv->show_address = FALSE;
+	name_selector_entry->priv->block_entry_changed_signal = FALSE;
 	name_selector_entry->priv->known_contacts = g_hash_table_new_full (g_str_hash, g_str_equal, g_free, NULL);
 
 	/* Edit signals */
 
 	g_signal_connect (
+		name_selector_entry, "changed",
+		G_CALLBACK (maybe_block_entry_changed_cb), NULL);
+	g_signal_connect (
 		name_selector_entry, "insert-text",
 		G_CALLBACK (user_insert_text), name_selector_entry);
 	g_signal_connect (