From ae7ac91c31ce9aa316c7da86d03a53155b017f4f Mon Sep 17 00:00:00 2001 From: alecpl <alec@alec.pl> Date: Tue, 22 Nov 2011 03:47:45 -0500 Subject: [PATCH] - Fixed bug in handling link with '!' character in it (#1488195) --- program/include/rcube_string_replacer.php | 9 +++++---- 1 files changed, 5 insertions(+), 4 deletions(-) diff --git a/program/include/rcube_string_replacer.php b/program/include/rcube_string_replacer.php index 8fcbeca..1cd1ef9 100644 --- a/program/include/rcube_string_replacer.php +++ b/program/include/rcube_string_replacer.php @@ -5,7 +5,7 @@ | program/include/rcube_string_replacer.php | | | | This file is part of the Roundcube Webmail client | - | Copyright (C) 2009, Roundcube Dev. - Switzerland | + | Copyright (C) 2009, The Roundcube Dev Team | | Licensed under the GNU GPL | | | | PURPOSE: | @@ -36,9 +36,10 @@ function __construct() { // Simplified domain expression for UTF8 characters handling - $utf_domain = '[^?&@"\'\\/()\s\r\t\n]+\\.[a-z]{2,5}'; - $url1 = '.:;'; - $url2 = 'a-z0-9%=#@+?&\\/_~\\[\\]-'; + // Support unicode/punycode in top-level domain part + $utf_domain = '[^?&@"\'\\/()\s\r\t\n]+\\.([^\\x00-\\x2f\\x3b-\\x40\\x5b-\\x60\\x7b-\\x7f]{2,}|xn--[a-z0-9]{2,})'; + $url1 = '.:;,'; + $url2 = 'a-z0-9%=#@+?!&\\/_~\\[\\]{}-'; $this->link_pattern = "/([\w]+:\/\/|\Wwww\.)($utf_domain([$url1]?[$url2]+)*)/i"; $this->mailto_pattern = "/(" -- Gitblit v1.9.1