2006-03-23 [paul] 2.0.0cvs165
authorPaul Mangan <paul@claws-mail.org>
Thu, 23 Mar 2006 13:12:16 +0000 (13:12 +0000)
committerPaul Mangan <paul@claws-mail.org>
Thu, 23 Mar 2006 13:12:16 +0000 (13:12 +0000)
* src/common/utils.c
fix highlighting of URIs containing "()"
(2.0.0cvs164's reversal fixed)

ChangeLog
PATCHSETS
configure.ac
src/common/utils.c

index f0d9432..acf4757 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2006-03-23 [paul]      2.0.0cvs165
+
+       * src/common/utils.c
+               fix highlighting of URIs containing "()"
+               (2.0.0cvs164's reversal fixed)
+
 2006-03-23 [paul]      2.0.0cvs164
 
        * src/common/utils.c
index d3d5f5b..a13a27f 100644 (file)
--- a/PATCHSETS
+++ b/PATCHSETS
 ( cvs diff -u -r 1.11.2.11 -r 1.11.2.12 src/editgroup.c;  cvs diff -u -r 1.15.2.25 -r 1.15.2.26 src/summary_search.c;  cvs diff -u -r 1.1.2.35 -r 1.1.2.36 src/gtk/quicksearch.c;  ) > 2.0.0cvs162.patchset
 ( cvs diff -u -r 1.654.2.1392 -r 1.654.2.1393 configure.ac;  ) > 2.0.0cvs163.patchset
 ( cvs diff -u -r 1.36.2.58 -r 1.36.2.59 src/common/utils.c;  ) > 2.0.0cvs164.patchset
+( cvs diff -u -r 1.36.2.59 -r 1.36.2.60 src/common/utils.c;  ) > 2.0.0cvs165.patchset
index e63a4b5..87f7083 100644 (file)
@@ -11,7 +11,7 @@ MINOR_VERSION=0
 MICRO_VERSION=0
 INTERFACE_AGE=0
 BINARY_AGE=0
-EXTRA_VERSION=164
+EXTRA_VERSION=165
 EXTRA_RELEASE=
 EXTRA_GTK2_VERSION=
 
index fdc1a0d..d748332 100644 (file)
@@ -4232,6 +4232,7 @@ gboolean get_uri_part(const gchar *start, const gchar *scanpos,
                             const gchar **bp, const gchar **ep, gboolean hdr)
 {
        const gchar *ep_;
+       gint parenthese_cnt = 0;
 
        g_return_val_if_fail(start != NULL, FALSE);
        g_return_val_if_fail(scanpos != NULL, FALSE);
@@ -4244,8 +4245,16 @@ gboolean get_uri_part(const gchar *start, const gchar *scanpos,
        for (ep_ = scanpos; *ep_ != '\0'; ep_++) {
                if (!g_ascii_isgraph(*(const guchar *)ep_) ||
                    !IS_ASCII(*(const guchar *)ep_) ||
-                   strchr("[]{}()<>\"", *ep_))
+                   strchr("[]{}<>\"", *ep_)) {
                        break;
+               } else if (strchr("(", *ep_)) {
+                       parenthese_cnt++;
+               } else if (strchr(")", *ep_)) {
+                       if (parenthese_cnt > 0)
+                               parenthese_cnt--;
+                       else
+                               break;
+               }
        }
 
        /* no punctuation at end of string */
@@ -4254,7 +4263,7 @@ gboolean get_uri_part(const gchar *start, const gchar *scanpos,
         * should pass some URI type to this function and decide on that whether
         * to perform punctuation stripping */
 
-#define IS_REAL_PUNCT(ch)      (g_ascii_ispunct(ch) && !strchr("/?=-", ch))
+#define IS_REAL_PUNCT(ch)      (g_ascii_ispunct(ch) && !strchr("/?=-)", ch))
 
        for (; ep_ - 1 > scanpos + 1 &&
               IS_REAL_PUNCT(*(ep_ - 1));