From f051dd0bcdbd35d101420fb1f75f33a565a1e0f8 Mon Sep 17 00:00:00 2001 From: lookshe Date: Tue, 8 Mar 2016 20:34:18 +0100 Subject: Fixes FS#153 - Check if url, phone and email are linkified correctly --- .../java/github/ankushsachdeva/emojicon/EmojiconHandler.java | 10 ++++++++++ 1 file changed, 10 insertions(+) (limited to 'libs') diff --git a/libs/emojicon/src/main/java/github/ankushsachdeva/emojicon/EmojiconHandler.java b/libs/emojicon/src/main/java/github/ankushsachdeva/emojicon/EmojiconHandler.java index 5523314b..f611a263 100644 --- a/libs/emojicon/src/main/java/github/ankushsachdeva/emojicon/EmojiconHandler.java +++ b/libs/emojicon/src/main/java/github/ankushsachdeva/emojicon/EmojiconHandler.java @@ -1407,6 +1407,11 @@ public final class EmojiconHandler { public static final Map ANDROID_EMOTICONS = new HashMap(); private static final Pattern TIME_AND_SCORING_PATTERN = Pattern.compile("[0-9]{1,3}:[0-9]{1,3}"); + private static final Pattern XMPP_PATTERN = Pattern + .compile("xmpp\\:(?:(?:[" + + Patterns.GOOD_IRI_CHAR + + "\\;\\/\\?\\@\\&\\=\\#\\~\\-\\.\\+\\!\\*\\'\\(\\)\\,\\_])" + + "|(?:\\%[a-fA-F0-9]{2}))+"); private static final Spannable.Factory spannableFactory = Spannable.Factory .getInstance(); @@ -1459,6 +1464,11 @@ public final class EmojiconHandler { falsePositives.add(Pair.create(timeAndScoringMatcher.start(), timeAndScoringMatcher.end())); } + Matcher xmppMatcher = XMPP_PATTERN.matcher(spannable); + while (xmppMatcher.find()) { + falsePositives.add(Pair.create(xmppMatcher.start(), xmppMatcher.end())); + } + Map emoticons = ANDROID_EMOTICONS; for (Map.Entry entry : emoticons.entrySet()) { Matcher matcher = entry.getKey().matcher(spannable); -- cgit v1.2.3