[evolution/gnome-3-18] Bug 759337 - Busy loop after sending a message with a space on the end of paragraph
- From: Tomas Popela <tpopela src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [evolution/gnome-3-18] Bug 759337 - Busy loop after sending a message with a space on the end of paragraph
- Date: Fri, 11 Dec 2015 10:51:40 +0000 (UTC)
commit 8416e625a2060b91991d37e6ab271deddd215010
Author: Tomas Popela <tpopela redhat com>
Date: Fri Dec 11 10:58:30 2015 +0100
Bug 759337 - Busy loop after sending a message with a space on the end of paragraph
Fix the code to avoid the busy loop and also change the trailing space to
non-breaking space, otherwise it will be hidden by WebKit (just this would be
enough to fix this bug).
e-util/e-html-editor-selection.c | 54 ++++++++++++++++++++++++++++++++-----
e-util/e-html-editor-view.c | 2 +-
2 files changed, 47 insertions(+), 9 deletions(-)
---
diff --git a/e-util/e-html-editor-selection.c b/e-util/e-html-editor-selection.c
index efab355..a64c939 100644
--- a/e-util/e-html-editor-selection.c
+++ b/e-util/e-html-editor-selection.c
@@ -6333,6 +6333,27 @@ find_where_to_break_line (WebKitDOMCharacterData *node,
}
static void
+mark_and_remove_trailing_space (WebKitDOMDocument *document,
+ WebKitDOMNode *node)
+{
+ WebKitDOMElement *element;
+
+ element = webkit_dom_document_create_element (document, "SPAN", NULL);
+ webkit_dom_element_set_attribute (element, "data-hidden-space", "", NULL);
+ webkit_dom_node_insert_before (
+ webkit_dom_node_get_parent_node (node),
+ WEBKIT_DOM_NODE (element),
+ webkit_dom_node_get_next_sibling (node),
+ NULL);
+ webkit_dom_character_data_replace_data (
+ WEBKIT_DOM_CHARACTER_DATA (node),
+ webkit_dom_character_data_get_length (WEBKIT_DOM_CHARACTER_DATA (node)),
+ 1,
+ "",
+ NULL);
+}
+
+static void
mark_and_remove_leading_space (WebKitDOMDocument *document,
WebKitDOMNode *node)
{
@@ -6826,6 +6847,11 @@ wrap_lines (EHTMLEditorSelection *selection,
if (nd_content && *nd_content) {
if (*nd_content == ' ')
mark_and_remove_leading_space (document, nd);
+
+ if
(!webkit_dom_node_get_next_sibling (nd) &&
+ g_str_has_suffix
(nd_content, " "))
+
mark_and_remove_trailing_space (document, nd);
+
g_free (nd_content);
}
@@ -6875,29 +6901,41 @@ wrap_lines (EHTMLEditorSelection *selection,
nd = node;
if (nd) {
+ gboolean no_sibling = FALSE;
gchar *nd_content;
nd_content = webkit_dom_node_get_text_content (nd);
if (nd_content && *nd_content) {
if (*nd_content == ' ')
mark_and_remove_leading_space (document, nd);
+
+ if (!webkit_dom_node_get_next_sibling (nd) &&
+ g_str_has_suffix (nd_content, " ")) {
+ mark_and_remove_trailing_space (document, nd);
+ no_sibling = TRUE;
+ }
+
g_free (nd_content);
}
- webkit_dom_node_insert_before (
- webkit_dom_node_get_parent_node (node),
- WEBKIT_DOM_NODE (element),
- nd,
- NULL);
-
+ if (!no_sibling)
+ webkit_dom_node_insert_before (
+ webkit_dom_node_get_parent_node (node),
+ WEBKIT_DOM_NODE (element),
+ nd,
+ NULL);
offset = 0;
nd_content = webkit_dom_node_get_text_content (nd);
if (!*nd_content)
remove_node (nd);
g_free (nd_content);
- node = webkit_dom_node_get_next_sibling (
- WEBKIT_DOM_NODE (element));
+
+ if (no_sibling)
+ node = NULL;
+ else
+ node = webkit_dom_node_get_next_sibling (
+ WEBKIT_DOM_NODE (element));
} else {
webkit_dom_node_append_child (
webkit_dom_node_get_parent_node (node),
diff --git a/e-util/e-html-editor-view.c b/e-util/e-html-editor-view.c
index ef0a36b..408c8ca 100644
--- a/e-util/e-html-editor-view.c
+++ b/e-util/e-html-editor-view.c
@@ -7147,7 +7147,7 @@ parse_html_into_paragraphs (EHTMLEditorView *view,
/* Replace single spaces on the beginning of line, 2+ spaces and
* tabulators with non breaking spaces */
- regex_nbsp = g_regex_new ("^\\s{1}|\\s{2,}|\x9", 0, 0, NULL);
+ regex_nbsp = g_regex_new ("^\\s{1}|\\s{2,}|\x9|\\s$", 0, 0, NULL);
while (next_br) {
gboolean local_ignore_next_br = ignore_next_br;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]