summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTobrun <tobrun.van.nuland@gmail.com>2018-08-29 18:10:10 +0200
committerTobrun <tobrun@mapbox.com>2018-09-04 10:19:16 +0200
commit1099bb4920f670017327efaf9db24097d60e34e8 (patch)
tree7ba0063903502e3ddc07f273b5fbc2f866c83f29
parente7642f28fe6abf07c4e92db3dca63eb20811f477 (diff)
downloadqtlocation-mapboxgl-1099bb4920f670017327efaf9db24097d60e34e8.tar.gz
[android] - add quotes to toString representation of a String literal
-rw-r--r--platform/android/MapboxGLAndroidSDK/src/main/java/com/mapbox/mapboxsdk/style/expressions/Expression.java13
-rw-r--r--platform/android/MapboxGLAndroidSDK/src/test/java/com/mapbox/mapboxsdk/style/expressions/ExpressionTest.java11
2 files changed, 14 insertions, 10 deletions
diff --git a/platform/android/MapboxGLAndroidSDK/src/main/java/com/mapbox/mapboxsdk/style/expressions/Expression.java b/platform/android/MapboxGLAndroidSDK/src/main/java/com/mapbox/mapboxsdk/style/expressions/Expression.java
index 626d83d299..2322d8211b 100644
--- a/platform/android/MapboxGLAndroidSDK/src/main/java/com/mapbox/mapboxsdk/style/expressions/Expression.java
+++ b/platform/android/MapboxGLAndroidSDK/src/main/java/com/mapbox/mapboxsdk/style/expressions/Expression.java
@@ -2834,8 +2834,8 @@ public class Expression {
* CircleLayer circleLayer = new CircleLayer("layer-id", "source-id");
* circleLayer.setProperties(
* circleColor(switchCase(
- eq(literal("it"), resolvedLocale(collator(true, true, "it"))), literal(ColorUtils.colorToRgbaString(Color.GREEN)),
- literal(ColorUtils.colorToRgbaString(Color.RED))))
+ * eq(literal("it"), resolvedLocale(collator(true, true, "it"))), literal(ColorUtils.colorToRgbaString(Color.GREEN)),
+ * literal(ColorUtils.colorToRgbaString(Color.RED))))
* );
* }
* </pre>
@@ -3921,13 +3921,10 @@ public class Expression {
// special case for handling unusual input like 'rgba(r, g, b, a)'
if (literalValue instanceof String) {
- if (((String) literalValue).contains(",")) {
- builder.append("\"").append(literalValue).append("\"");
- continue;
- }
+ builder.append("\"").append(literalValue).append("\"");
+ } else {
+ builder.append(literalValue);
}
-
- builder.append(literalValue);
} else {
builder.append(argument.toString());
}
diff --git a/platform/android/MapboxGLAndroidSDK/src/test/java/com/mapbox/mapboxsdk/style/expressions/ExpressionTest.java b/platform/android/MapboxGLAndroidSDK/src/test/java/com/mapbox/mapboxsdk/style/expressions/ExpressionTest.java
index 79bcdd7b5e..b38026a572 100644
--- a/platform/android/MapboxGLAndroidSDK/src/test/java/com/mapbox/mapboxsdk/style/expressions/ExpressionTest.java
+++ b/platform/android/MapboxGLAndroidSDK/src/test/java/com/mapbox/mapboxsdk/style/expressions/ExpressionTest.java
@@ -1101,7 +1101,7 @@ public class ExpressionTest {
@Test
public void testExpressionConcatToString() throws Exception {
- String expected = "[\"concat\", foo, bar]";
+ String expected = "[\"concat\", \"foo\", \"bar\"]";
String actual = concat(literal("foo"), literal("bar")).toString();
assertEquals("toString should match", expected, actual);
}
@@ -1116,7 +1116,7 @@ public class ExpressionTest {
@Test
public void testExpressionExponentialToString() throws Exception {
String expected = "[\"interpolate\", [\"cubic-bezier\", 1.0, 1.0, 1.0, 1.0],"
- + " [\"get\", x], 0.0, 100.0, 100.0, 200.0]";
+ + " [\"get\", \"x\"], 0.0, 100.0, 100.0, 200.0]";
String actual = interpolate(cubicBezier(literal(1), literal(1), literal(1), literal(1)),
get(literal("x")), literal(0), literal(100), literal(100), literal(200)).toString();
assertEquals("toString should match", expected, actual);
@@ -1367,4 +1367,11 @@ public class ExpressionTest {
String actual = collator(literal(false), eq(literal(2), literal(1)), literal("it")).toString();
assertEquals("expression should match", expected, actual);
}
+
+ @Test
+ public void testStringReverseConversion() {
+ String expected = "[\"to-string\", [\"get\", \"name_en\"]]";
+ String actual = Expression.toString(get("name_en")).toString();
+ assertEquals("Reverse string conversion should match", expected, actual);
+ }
} \ No newline at end of file