diff options
author | Artur Signell <artur@vaadin.com> | 2012-12-10 11:32:39 +0200 |
---|---|---|
committer | Artur Signell <artur@vaadin.com> | 2012-12-10 11:32:55 +0200 |
commit | 467edbbe2042a6ab4885e7bc0906415c529b6235 (patch) | |
tree | 9c41aad76207c54aabd19e9330fceb5980f1d89f | |
parent | c5cbf6243d4f2c7cd4c42f00fff94d7870670543 (diff) | |
download | vaadin-framework-467edbbe2042a6ab4885e7bc0906415c529b6235.tar.gz vaadin-framework-467edbbe2042a6ab4885e7bc0906415c529b6235.zip |
Better error messages for unknown legacy variable types (#10481)
Change-Id: I22127da446b1035d6b0868d47646af543ea0a876
-rw-r--r-- | client/src/com/vaadin/client/communication/JsonEncoder.java | 15 |
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; |