summaryrefslogtreecommitdiffstats
path: root/client
diff options
context:
space:
mode:
authorArtur Signell <artur@vaadin.com>2012-12-10 11:32:39 +0200
committerArtur Signell <artur@vaadin.com>2012-12-10 11:32:55 +0200
commit467edbbe2042a6ab4885e7bc0906415c529b6235 (patch)
tree9c41aad76207c54aabd19e9330fceb5980f1d89f /client
parentc5cbf6243d4f2c7cd4c42f00fff94d7870670543 (diff)
downloadvaadin-framework-467edbbe2042a6ab4885e7bc0906415c529b6235.tar.gz
vaadin-framework-467edbbe2042a6ab4885e7bc0906415c529b6235.zip
Better error messages for unknown legacy variable types (#10481)
Change-Id: I22127da446b1035d6b0868d47646af543ea0a876
Diffstat (limited to 'client')
-rw-r--r--client/src/com/vaadin/client/communication/JsonEncoder.java15
1 files changed, 14 insertions, 1 deletions
diff --git a/client/src/com/vaadin/client/communication/JsonEncoder.java b/client/src/com/vaadin/client/communication/JsonEncoder.java
index 07908c8147..162becf8ff 100644
--- a/client/src/com/vaadin/client/communication/JsonEncoder.java
+++ b/client/src/com/vaadin/client/communication/JsonEncoder.java
@@ -138,7 +138,20 @@ public class JsonEncoder {
Object value = uidlValue.getValue();
JSONArray jsonArray = new JSONArray();
- jsonArray.set(0, new JSONString(getTransportType(value)));
+ String transportType = getTransportType(value);
+ if (transportType == null) {
+ /*
+ * This should not happen unless you try to send an unsupported type
+ * in a legacy variable change from the client to the server.
+ */
+ String valueType = null;
+ if (value != null) {
+ valueType = value.getClass().getName();
+ }
+ throw new IllegalArgumentException("Cannot encode object of type "
+ + valueType);
+ }
+ jsonArray.set(0, new JSONString(transportType));
jsonArray.set(1, encode(value, true, connection));
return jsonArray;