aboutsummaryrefslogtreecommitdiff
path: root/util
diff options
context:
space:
mode:
authorBen Gruver <bgruv@google.com>2015-03-18 20:42:12 -0700
committerBen Gruver <bgruv@google.com>2015-03-18 21:00:32 -0700
commit75bef01d100126e6f2e46614302fe5cad7c8287d (patch)
treebd0fe933ae742498109c7fb0d54fd3b3ae7a1637 /util
parentddc7c35e1cfdddc7276d72e5e79c69bf932046e5 (diff)
parent2a0e4657ea73c67a44d1711da2539aa9c1a88524 (diff)
downloadsmali-75bef01d100126e6f2e46614302fe5cad7c8287d.tar.gz
Merge branch 'master' into smalidea
Diffstat (limited to 'util')
-rw-r--r--util/src/main/java/org/jf/util/TextUtils.java27
-rw-r--r--util/src/test/java/org/jf/util/TextUtilsTest.java53
2 files changed, 78 insertions, 2 deletions
diff --git a/util/src/main/java/org/jf/util/TextUtils.java b/util/src/main/java/org/jf/util/TextUtils.java
index a01e68e7..66a1082d 100644
--- a/util/src/main/java/org/jf/util/TextUtils.java
+++ b/util/src/main/java/org/jf/util/TextUtils.java
@@ -50,10 +50,33 @@ public class TextUtils {
@Nonnull
public static String normalizeWhitespace(@Nonnull String source) {
+ // Go to native system new lines so that ^/$ work correctly
+ source = normalizeNewlines(source);
+
+ // Remove all suffix/prefix whitespace
+ Pattern pattern = Pattern.compile("((^[ \t]+)|([ \t]+$))", Pattern.MULTILINE);
+ Matcher matcher = pattern.matcher(source);
+ source = matcher.replaceAll("");
+
+ // Remove all empty lines
+ Pattern pattern2 = Pattern.compile("^\r?\n?", Pattern.MULTILINE);
+ Matcher matcher2 = pattern2.matcher(source);
+ source = matcher2.replaceAll("");
+
+ // Remove a trailing new line, if present
+ Pattern pattern3 = Pattern.compile("\r?\n?$");
+ Matcher matcher3 = pattern3.matcher(source);
+ source = matcher3.replaceAll("");
+
+ // Go back to unix-style \n newlines
source = normalizeNewlines(source, "\n");
+ return source;
+ }
- Pattern pattern = Pattern.compile("(\n[ \t]*)+");
+ @Nonnull
+ public static String stripComments(@Nonnull String source) {
+ Pattern pattern = Pattern.compile("#(.*)");
Matcher matcher = pattern.matcher(source);
- return matcher.replaceAll("\n");
+ return matcher.replaceAll("");
}
}
diff --git a/util/src/test/java/org/jf/util/TextUtilsTest.java b/util/src/test/java/org/jf/util/TextUtilsTest.java
new file mode 100644
index 00000000..ef14e03a
--- /dev/null
+++ b/util/src/test/java/org/jf/util/TextUtilsTest.java
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2015, Google Inc.
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
+ *
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following disclaimer
+ * in the documentation and/or other materials provided with the
+ * distribution.
+ * * Neither the name of Google Inc. nor the names of its
+ * contributors may be used to endorse or promote products derived from
+ * this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+ * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+ * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+package org.jf.util;
+
+import org.junit.Assert;
+import org.junit.Test;
+
+public class TextUtilsTest {
+ @Test
+ public void testStripComments() {
+ Assert.assertEquals("", TextUtils.stripComments("#world"));
+ Assert.assertEquals("hello", TextUtils.stripComments("hello#world"));
+ Assert.assertEquals("multi\nline", TextUtils.stripComments("multi#hello world\nline#world"));
+ }
+
+ @Test
+ public void testNormalizeWhitespace() {
+ Assert.assertEquals("", TextUtils.normalizeWhitespace(" "));
+ Assert.assertEquals("hello", TextUtils.normalizeWhitespace("hello "));
+ Assert.assertEquals("hello", TextUtils.normalizeWhitespace(" hello"));
+ Assert.assertEquals("hello", TextUtils.normalizeWhitespace(" hello "));
+ Assert.assertEquals("hello\nworld", TextUtils.normalizeWhitespace("hello \n \n world"));
+ }
+} \ No newline at end of file