summaryrefslogtreecommitdiffstats
path: root/shared
diff options
context:
space:
mode:
authorArtur Signell <artur@vaadin.com>2015-05-27 22:03:26 +0300
committerVaadin Code Review <review@vaadin.com>2015-05-29 13:33:47 +0000
commited5ad86b114ccb4d6ab08e19a734bdb8b3342399 (patch)
treefa6bfdda2d616589acc2205ad3da84e9f513a691 /shared
parent4a79c3c5c5cf14dde6f696a0fe924227d00a0ec5 (diff)
downloadvaadin-framework-ed5ad86b114ccb4d6ab08e19a734bdb8b3342399.tar.gz
vaadin-framework-ed5ad86b114ccb4d6ab08e19a734bdb8b3342399.zip
Ensure method and property names are capitalized using English locale (#13389)
Change-Id: Idde4fc54950f2bb83e0bb8d36a84a5bf075eb8de
Diffstat (limited to 'shared')
-rw-r--r--shared/src/com/vaadin/shared/util/SharedUtil.java30
-rw-r--r--shared/tests/src/com/vaadin/shared/util/SharedUtilTests.java42
2 files changed, 70 insertions, 2 deletions
diff --git a/shared/src/com/vaadin/shared/util/SharedUtil.java b/shared/src/com/vaadin/shared/util/SharedUtil.java
index bc5d87b9f5..d363d767be 100644
--- a/shared/src/com/vaadin/shared/util/SharedUtil.java
+++ b/shared/src/com/vaadin/shared/util/SharedUtil.java
@@ -149,11 +149,12 @@ public class SharedUtil implements Serializable {
sb.append(parts[i]);
sb.append(separator);
}
- return sb.substring(0, sb.length() - 1);
+ return sb.substring(0, sb.length() - separator.length());
}
/**
- * Capitalizes the first character in the given string
+ * Capitalizes the first character in the given string in a way suitable for
+ * use in code (methods, properties etc)
*
* @since 7.4
* @param string
@@ -239,4 +240,29 @@ public class SharedUtil implements Serializable {
return uri;
}
+ /**
+ * Converts a dash ("-") separated string into camelCase.
+ * <p>
+ * Examples:
+ * <p>
+ * {@literal foo} becomes {@literal foo} {@literal foo-bar} becomes
+ * {@literal fooBar} {@literal foo--bar} becomes {@literal fooBar}
+ *
+ * @since
+ * @param dashSeparated
+ * The dash separated string to convert
+ * @return a camelCase version of the input string
+ */
+ public static String dashSeparatedToCamelCase(String dashSeparated) {
+ if (dashSeparated == null) {
+ return null;
+ }
+ String[] parts = dashSeparated.split("-");
+ for (int i = 1; i < parts.length; i++) {
+ parts[i] = capitalize(parts[i]);
+ }
+
+ return join(parts, "");
+ }
+
}
diff --git a/shared/tests/src/com/vaadin/shared/util/SharedUtilTests.java b/shared/tests/src/com/vaadin/shared/util/SharedUtilTests.java
index 208d4ca7c7..e77501a446 100644
--- a/shared/tests/src/com/vaadin/shared/util/SharedUtilTests.java
+++ b/shared/tests/src/com/vaadin/shared/util/SharedUtilTests.java
@@ -3,6 +3,8 @@ package com.vaadin.shared.util;
import static org.hamcrest.CoreMatchers.is;
import static org.junit.Assert.assertThat;
+import java.util.Locale;
+
import org.junit.Assert;
import org.junit.Test;
@@ -76,4 +78,44 @@ public class SharedUtilTests {
String[] splitParts = SharedUtil.splitCamelCase(camelCaseString);
Assert.assertArrayEquals(parts, splitParts);
}
+
+ @Test
+ public void join() {
+ String s1 = "foo-bar-baz";
+ String s2 = "foo--bar";
+
+ Assert.assertEquals("foobarbaz", SharedUtil.join(s1.split("-"), ""));
+ Assert.assertEquals("foo!bar!baz", SharedUtil.join(s1.split("-"), "!"));
+ Assert.assertEquals("foo!!bar!!baz",
+ SharedUtil.join(s1.split("-"), "!!"));
+
+ Assert.assertEquals("foo##bar", SharedUtil.join(s2.split("-"), "#"));
+ }
+
+ @Test
+ public void dashSeparatedToCamelCase() {
+ Assert.assertEquals(null, SharedUtil.dashSeparatedToCamelCase(null));
+ Assert.assertEquals("", SharedUtil.dashSeparatedToCamelCase(""));
+ Assert.assertEquals("foo", SharedUtil.dashSeparatedToCamelCase("foo"));
+ Assert.assertEquals("fooBar",
+ SharedUtil.dashSeparatedToCamelCase("foo-bar"));
+ Assert.assertEquals("fooBar",
+ SharedUtil.dashSeparatedToCamelCase("foo--bar"));
+ Assert.assertEquals("fooBarBaz",
+ SharedUtil.dashSeparatedToCamelCase("foo-bar-baz"));
+ Assert.assertEquals("fooBarBaz",
+ SharedUtil.dashSeparatedToCamelCase("foo-Bar-Baz"));
+ }
+
+ @Test
+ public void methodUppercaseWithTurkishLocale() {
+ Locale defaultLocale = Locale.getDefault();
+ try {
+ Locale.setDefault(new Locale("tr", "TR"));
+ Assert.assertEquals("Integer", SharedUtil.capitalize("integer"));
+ } finally {
+ Locale.setDefault(defaultLocale);
+ }
+ }
+
}