aboutsummaryrefslogtreecommitdiffstats
path: root/src/bookmarks/ephy-topics-entry.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/bookmarks/ephy-topics-entry.c')
-rw-r--r--src/bookmarks/ephy-topics-entry.c132
1 files changed, 78 insertions, 54 deletions
diff --git a/src/bookmarks/ephy-topics-entry.c b/src/bookmarks/ephy-topics-entry.c
index 8c3af0007..64145ca66 100644
--- a/src/bookmarks/ephy-topics-entry.c
+++ b/src/bookmarks/ephy-topics-entry.c
@@ -42,7 +42,8 @@ struct _EphyTopicsEntryPrivate
GtkListStore *store;
GtkEntryCompletion *completion;
gboolean update_keywords;
- char *action;
+ char *input;
+ char *key;
};
enum
@@ -85,22 +86,20 @@ ephy_topics_entry_get_type (void)
static void
update_widget (EphyTopicsEntry *entry)
{
+ EphyTopicsEntryPrivate *priv = entry->priv;
+ GtkEditable *editable = GTK_EDITABLE (entry);
+
EphyNode *node;
GPtrArray *children, *topics;
GtkTreeIter iter;
- gint i, priority;
+ gint i, priority, pos;
const char *title;
char *tmp1, *tmp2;
gboolean update_text;
- entry->priv->update_keywords = FALSE;
-
- update_text = !GTK_WIDGET_HAS_FOCUS (GTK_WIDGET (entry));
- gtk_entry_set_completion (GTK_ENTRY (entry), NULL);
- gtk_list_store_clear (entry->priv->store);
- if (update_text) gtk_entry_set_text (GTK_ENTRY (entry), "");
+ priv->update_keywords = FALSE;
- node = ephy_bookmarks_get_keywords (entry->priv->bookmarks);
+ node = ephy_bookmarks_get_keywords (priv->bookmarks);
children = ephy_node_get_children (node);
topics = g_ptr_array_sized_new (children->len);
@@ -117,51 +116,57 @@ update_widget (EphyTopicsEntry *entry)
g_ptr_array_sort (topics, ephy_bookmarks_compare_topic_pointers);
+ gtk_list_store_clear (priv->store);
+ update_text = !GTK_WIDGET_HAS_FOCUS (GTK_WIDGET (entry));
+ if (update_text) gtk_editable_delete_text (editable, 0, -1);
+ pos = 0;
+
for (i = 0; i < topics->len; i++)
{
node = g_ptr_array_index (topics, i);
title = ephy_node_get_property_string (node, EPHY_NODE_KEYWORD_PROP_NAME);
- if (ephy_node_has_child (node, entry->priv->bookmark))
+ if (ephy_node_has_child (node, priv->bookmark))
{
if (update_text)
{
- gtk_entry_append_text (GTK_ENTRY (entry), title);
- gtk_entry_append_text (GTK_ENTRY (entry), "; ");
+ gtk_editable_insert_text (editable, title, -1, &pos);
+ gtk_editable_insert_text (editable, "; ", -1, &pos);
}
}
- else
- {
- tmp1 = g_utf8_casefold (title, -1);
- tmp2 = g_utf8_normalize (tmp1, -1, G_NORMALIZE_DEFAULT);
- gtk_list_store_append (entry->priv->store, &iter);
- gtk_list_store_set (entry->priv->store, &iter, 0, title, 1, tmp2, -1);
- g_free (tmp2);
- g_free (tmp1);
- }
+
+ /* We just include all topics, else we get odd behaviour after you
+ * just finish entering a topic (it gets selected, so wouldn't show) */
+ tmp1 = g_utf8_casefold (title, -1);
+ tmp2 = g_utf8_normalize (tmp1, -1, G_NORMALIZE_DEFAULT);
+ gtk_list_store_append (priv->store, &iter);
+ gtk_list_store_set (priv->store, &iter, 0, title, 1, tmp2, -1);
+ g_free (tmp2);
+ g_free (tmp1);
}
g_ptr_array_free (topics, TRUE);
-
- gtk_entry_set_completion (GTK_ENTRY (entry), entry->priv->completion);
- if (update_text) gtk_editable_set_position (GTK_EDITABLE (entry), -1);
+
+ if (update_text) gtk_editable_set_position (editable, -1);
- entry->priv->update_keywords = TRUE;
+ priv->update_keywords = TRUE;
}
static void
-update_action (EphyTopicsEntry *entry)
+update_input (EphyTopicsEntry *entry)
{
GtkEditable *editable = GTK_EDITABLE (entry);
const char *text = gtk_entry_get_text (GTK_ENTRY (entry));
- char *key;
+ char *input;
gint start, end;
- if(entry->priv->action)
+ if (entry->priv->input)
{
gtk_entry_completion_delete_action (entry->priv->completion, 0);
- g_free (entry->priv->action);
- entry->priv->action = 0;
+ g_free (entry->priv->input);
+ g_free (entry->priv->key);
+ entry->priv->input = 0;
+ entry->priv->key = 0;
}
/* Find the start and end locations */
@@ -181,16 +186,32 @@ update_action (EphyTopicsEntry *entry)
}
/* If no text to work with, exit */
- key = g_strndup (text+start, end-start);
- g_strstrip (key);
- if (*key != 0 && ephy_bookmarks_find_keyword (entry->priv->bookmarks, key, FALSE) == NULL)
+ input = g_strndup (text+start, end-start);
+ g_strstrip (input);
+ if (*input != 0)
{
- entry->priv->action = key;
- key = g_strdup_printf (_("Create topic ā€œ%sā€"), key);
- gtk_entry_completion_insert_action_text (entry->priv->completion, 0, key);
+ entry->priv->input = input;
+
+ input = g_utf8_casefold (input, -1);
+ entry->priv->key = g_utf8_normalize (input, -1, G_NORMALIZE_DEFAULT);
+ g_free (input);
+
+ if (ephy_bookmarks_find_keyword (entry->priv->bookmarks, entry->priv->input, FALSE) == NULL)
+ {
+ input = g_strdup_printf (_("Create topic ā€œ%sā€"), entry->priv->input);
+ gtk_entry_completion_insert_action_text (entry->priv->completion, 0, input);
+ g_free (input);
+ }
+ else
+ {
+ g_free (entry->priv->input);
+ entry->priv->input = 0;
+ }
+ }
+ else
+ {
+ g_free (input);
}
-
- g_free (key);
}
static void
@@ -255,8 +276,6 @@ update_keywords (EphyTopicsEntry *entry)
}
g_strfreev (split);
-
- update_action (entry);
}
static void
@@ -305,7 +324,6 @@ insert_text (EphyTopicsEntry *entry,
g_free (key);
return;
}
-
}
/* Replace the text in the current position with the title */
@@ -322,7 +340,7 @@ action_cb (GtkEntryCompletion *completion,
gpointer user_data)
{
EphyTopicsEntry *entry = EPHY_TOPICS_ENTRY (gtk_entry_completion_get_entry (completion));
- char *action = g_strdup(entry->priv->action);
+ char *action = g_strdup(entry->priv->input);
if (ephy_bookmarks_find_keyword (entry->priv->bookmarks, action, FALSE) == NULL)
{
@@ -371,18 +389,17 @@ match_func (GtkEntryCompletion *completion,
GtkTreeIter *iter,
gpointer user_data)
{
+ GtkEntry *entry = gtk_entry_completion_get_entry (completion);
+ GtkTreeModel *model = gtk_entry_completion_get_model (completion);
+ EphyTopicsEntryPrivate *priv = EPHY_TOPICS_ENTRY(entry)->priv;
+
gboolean result;
- const char *real_key;
char *text;
- real_key = g_strrstr (key, ";");
- if (real_key) real_key++;
- else real_key = key;
- while (*real_key == ' ') real_key++;
-
- gtk_tree_model_get (gtk_entry_completion_get_model (completion), iter, 1, &text, -1);
+ if (priv->key == NULL) return TRUE;
+ gtk_tree_model_get (model, iter, 1, &text, -1);
if (text == NULL) return FALSE;
- result = g_str_has_prefix (text, real_key);
+ result = g_str_has_prefix (text, priv->key);
g_free (text);
return result;
@@ -435,17 +452,23 @@ ephy_topics_entry_constructor (GType type,
gtk_entry_completion_set_text_column (priv->completion, 0);
gtk_entry_completion_set_popup_completion (priv->completion, TRUE);
gtk_entry_completion_set_popup_single_match (priv->completion, TRUE);
-
gtk_entry_completion_set_match_func (priv->completion, match_func, NULL, NULL);
+ gtk_entry_set_completion (GTK_ENTRY (entry), priv->completion);
g_signal_connect (priv->completion, "match-selected",
G_CALLBACK (match_selected_cb), NULL);
+ g_signal_connect (priv->completion, "action-activated",
+ G_CALLBACK (action_cb), NULL);
+
g_signal_connect (object, "focus-out-event",
G_CALLBACK (focus_out_cb), NULL);
g_signal_connect (object, "changed",
G_CALLBACK (update_keywords), NULL);
- g_signal_connect (G_OBJECT (priv->completion), "action-activated",
- G_CALLBACK (action_cb), NULL);
+
+ g_signal_connect (object, "notify::cursor-position",
+ G_CALLBACK (update_input), NULL);
+ g_signal_connect (object, "notify::text",
+ G_CALLBACK (update_input), NULL);
update_widget (entry);
@@ -464,7 +487,8 @@ ephy_topics_entry_finalize (GObject *object)
{
EphyTopicsEntry *entry = EPHY_TOPICS_ENTRY (object);
- g_free (entry->priv->action);
+ g_free (entry->priv->input);
+ g_free (entry->priv->key);
parent_class->finalize (object);
}