[evolution/wip/webkit2] Bug 759564 - Pasting a plain text paragraph starting with an URL will linkify the entire paragraph
- From: Milan Crha <mcrha src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [evolution/wip/webkit2] Bug 759564 - Pasting a plain text paragraph starting with an URL will linkify the entire paragraph
- Date: Thu, 3 Mar 2016 13:42:27 +0000 (UTC)
commit 3a5fa24bf021325570abef3d9d987f2d6d453ab1
Author: Tomas Popela <tpopela redhat com>
Date: Thu Mar 3 13:49:53 2016 +0100
Bug 759564 - Pasting a plain text paragraph starting with an URL will linkify the entire paragraph
.../e-html-editor-selection-dom-functions.h | 4 +-
.../composer/e-html-editor-view-dom-functions.c | 33 +++++++++++++++----
2 files changed, 28 insertions(+), 9 deletions(-)
---
diff --git a/web-extensions/composer/e-html-editor-selection-dom-functions.h
b/web-extensions/composer/e-html-editor-selection-dom-functions.h
index 65c2d82..c2b1314 100644
--- a/web-extensions/composer/e-html-editor-selection-dom-functions.h
+++ b/web-extensions/composer/e-html-editor-selection-dom-functions.h
@@ -27,9 +27,9 @@
#define UNICODE_NBSP "\xc2\xa0"
/* stephenhay from https://mathiasbynens.be/demo/url-regex */
-#define URL_PROTOCOLS "news|telnet|nntp|file|https?|s?ftp||webcal|localhost|ssh"
+#define URL_PROTOCOLS "news|telnet|nntp|file|https?|s?ftp|webcal|localhost|ssh"
#define URL_PATTERN_BASE "(?=((?:(?:(?:" URL_PROTOCOLS
")\\:\\/\\/)|(?:www\\.|ftp\\.))[^\\s\\/\\$\\.\\?#].[^\\s]*)"
-#define URL_PATTERN_NO_NBSP ")((?! ).)*"
+#define URL_PATTERN_NO_NBSP ")((?:(?! ).)*)"
#define URL_PATTERN URL_PATTERN_BASE URL_PATTERN_NO_NBSP
#define URL_PATTERN_SPACE URL_PATTERN_BASE "\\s$" URL_PATTERN_NO_NBSP
/* Taken from camel-url-scanner.c */
diff --git a/web-extensions/composer/e-html-editor-view-dom-functions.c
b/web-extensions/composer/e-html-editor-view-dom-functions.c
index d7b1367..ffc1e63 100644
--- a/web-extensions/composer/e-html-editor-view-dom-functions.c
+++ b/web-extensions/composer/e-html-editor-view-dom-functions.c
@@ -3997,17 +3997,32 @@ create_anchor_for_link (const GMatchInfo *info,
GString *res,
gpointer data)
{
+ gboolean link_surrounded, with_nbsp = FALSE;
gint offset = 0, truncate_from_end = 0;
+ gint match_start, match_end;
+ gchar *match_with_nbsp, *match_without_nbsp;
const gchar *end_of_match = NULL;
- gchar *match;
- gboolean link_surrounded;
+ const gchar *match, *match_extra_characters;
- match = g_match_info_fetch (info, 0);
+ match_with_nbsp = g_match_info_fetch (info, 1);
+ /* E-mail addresses will be here. */
+ match_without_nbsp = g_match_info_fetch (info, 0);
+
+ if (!match_with_nbsp || (strstr (match_with_nbsp, " ") && !g_str_has_prefix (match_with_nbsp,
" "))) {
+ match = match_without_nbsp;
+ match_extra_characters = match_with_nbsp;
+ g_match_info_fetch_pos (info, 0, &match_start, &match_end);
+ with_nbsp = TRUE;
+ } else {
+ match = match_with_nbsp;
+ match_extra_characters = match_without_nbsp;
+ g_match_info_fetch_pos (info, 1, &match_start, &match_end);
+ }
if (g_str_has_prefix (match, " "))
offset += 6;
- end_of_match = match + strlen (match) - 1;
+ end_of_match = match + match_end - match_start - 1;
/* Taken from camel-url-scanner.c */
/* URLs are extremely unlikely to end with any punctuation, so
* strip any trailing punctuation off from link and put it after
@@ -4051,7 +4066,11 @@ create_anchor_for_link (const GMatchInfo *info,
if (truncate_from_end > 0)
g_string_append (res, end_of_match);
- g_free (match);
+ if (!with_nbsp && match_extra_characters)
+ g_string_append (res, match_extra_characters + (match_end - match_start));
+
+ g_free (match_with_nbsp);
+ g_free (match_without_nbsp);
return FALSE;
}
@@ -4357,7 +4376,7 @@ parse_html_into_blocks (WebKitDOMDocument *document,
rest_to_insert,
-1,
0,
- 0,
+ G_REGEX_MATCH_NOTEMPTY,
create_anchor_for_link,
NULL,
NULL);
@@ -4533,7 +4552,7 @@ parse_html_into_blocks (WebKitDOMDocument *document,
rest_to_insert,
-1,
0,
- 0,
+ G_REGEX_MATCH_NOTEMPTY,
create_anchor_for_link,
NULL,
NULL);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]