aboutsummaryrefslogtreecommitdiffstats
path: root/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/util
diff options
context:
space:
mode:
authorVincent Breitmoser <valodim@mugenguild.com>2015-12-29 00:31:44 +0100
committerVincent Breitmoser <valodim@mugenguild.com>2015-12-29 00:35:37 +0100
commit807e5f7901f98ad14f78f6b038c286e6ff0f6fe1 (patch)
treef6e7f7c10edfea62a8c2e79c74f8f55bc912d1d1 /OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/util
parent24ef87535f922354e4f468496c1577d0329b23f8 (diff)
downloadopen-keychain-807e5f7901f98ad14f78f6b038c286e6ff0f6fe1.tar.gz
open-keychain-807e5f7901f98ad14f78f6b038c286e6ff0f6fe1.tar.bz2
open-keychain-807e5f7901f98ad14f78f6b038c286e6ff0f6fe1.zip
keylist: fix highlighter (fixes #1637)
Diffstat (limited to 'OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/util')
-rw-r--r--OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/util/Highlighter.java43
1 files changed, 19 insertions, 24 deletions
diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/util/Highlighter.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/util/Highlighter.java
index ac34d5526..ccaa9d408 100644
--- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/util/Highlighter.java
+++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/util/Highlighter.java
@@ -1,20 +1,3 @@
-/*
- * Copyright (C) 2014 Thialfihar <thi@thialfihar.org>
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-
package org.sufficientlysecure.keychain.ui.util;
import android.content.Context;
@@ -22,7 +5,6 @@ import android.text.Spannable;
import android.text.style.ForegroundColorSpan;
import org.sufficientlysecure.keychain.R;
-import org.sufficientlysecure.keychain.ui.util.FormattingUtils;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
@@ -43,19 +25,32 @@ public class Highlighter {
return highlight;
}
- Pattern pattern = Pattern.compile("(?i)(" + mQuery.trim().replaceAll("\\s+", "|") + ")");
+ String queryPattern = buildPatternFromQuery(mQuery);
+ Pattern pattern = Pattern.compile("(" + queryPattern + ")", Pattern.CASE_INSENSITIVE);
Matcher matcher = pattern.matcher(text);
int colorEmphasis = FormattingUtils.getColorFromAttr(mContext, R.attr.colorEmphasis);
while (matcher.find()) {
- highlight.setSpan(
- new ForegroundColorSpan(colorEmphasis),
- matcher.start(),
- matcher.end(),
- Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
+ highlight.setSpan(new ForegroundColorSpan(colorEmphasis),
+ matcher.start(), matcher.end(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
}
return highlight;
}
+
+ private static String buildPatternFromQuery(String mQuery) {
+ String chunks[] = mQuery.split(" *, *");
+ boolean firstChunk = true;
+ StringBuilder patternPiece = new StringBuilder();
+ for (int i = 0; i < chunks.length; ++i) {
+ patternPiece.append(Pattern.quote(chunks[i]));
+ if (firstChunk) {
+ firstChunk = false;
+ continue;
+ }
+ patternPiece.append('|');
+ }
+ return patternPiece.toString();
+ }
}