123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227 |
- /*
- @VaadinApache2LicenseForJavaFiles@
- */
-
- package com.vaadin.tests.widgetset.client;
-
- import java.util.ArrayList;
- import java.util.Arrays;
- import java.util.Collections;
- import java.util.HashMap;
- import java.util.HashSet;
- import java.util.List;
- import java.util.Map;
- import java.util.Map.Entry;
- import java.util.Set;
-
- import com.vaadin.terminal.gwt.client.Connector;
- import com.vaadin.terminal.gwt.client.communication.RpcProxy;
- import com.vaadin.terminal.gwt.client.communication.StateChangeEvent;
- import com.vaadin.terminal.gwt.client.extensions.AbstractExtensionConnector;
- import com.vaadin.terminal.gwt.client.ui.Connect;
- import com.vaadin.tests.widgetset.server.SerializerTestExtension;
-
- @Connect(SerializerTestExtension.class)
- public class SerializerTestConnector extends AbstractExtensionConnector {
-
- private SerializerTestRpc rpc = RpcProxy.create(SerializerTestRpc.class,
- this);
-
- public SerializerTestConnector() {
- registerRpc(SerializerTestRpc.class, new SerializerTestRpc() {
- public void sendWrappedGenerics(
- Map<Set<SimpleTestBean>, Map<Integer, List<SimpleTestBean>>> generics) {
- Map<Set<SimpleTestBean>, Map<Integer, List<SimpleTestBean>>> updated = new HashMap<Set<SimpleTestBean>, Map<Integer, List<SimpleTestBean>>>();
-
- SimpleTestBean firstValue = generics.values().iterator().next()
- .get(Integer.valueOf(1)).get(0);
- Set<SimpleTestBean> key = new HashSet<SimpleTestBean>(Arrays
- .asList(firstValue));
-
- Map<Integer, List<SimpleTestBean>> value = new HashMap<Integer, List<SimpleTestBean>>();
- Set<SimpleTestBean> firstKeyValue = generics.keySet()
- .iterator().next();
- value.put(Integer.valueOf(1), new ArrayList<SimpleTestBean>(
- firstKeyValue));
-
- updated.put(key, value);
-
- rpc.sendWrappedGenerics(updated);
- }
-
- public void sendString(String value) {
- char[] chars = value.toCharArray();
- Arrays.sort(chars);
- rpc.sendString(new String(chars));
- }
-
- public void sendSet(Set<Integer> intSet,
- Set<Connector> connectorSet, Set<SimpleTestBean> beanSet) {
-
- beanSet.iterator().next().setValue(intSet.size());
- Set<Integer> updatedIntSet = new HashSet<Integer>();
-
- for (Integer integer : intSet) {
- updatedIntSet.add(Integer.valueOf(-integer.intValue()));
- }
- rpc.sendSet(updatedIntSet,
- Collections.singleton(getRootConnector()), beanSet);
- }
-
- public void sendNestedArray(int[][] nestedIntArray,
- SimpleTestBean[][] nestedBeanArray) {
- rpc.sendNestedArray(new int[][] { { nestedIntArray[1][0],
- nestedIntArray[0][0] } }, new SimpleTestBean[][] {
- { nestedBeanArray[0][1] }, { nestedBeanArray[0][0] } });
- }
-
- public void sendMap(Map<String, SimpleTestBean> stringMap,
- Map<Connector, Boolean> connectorMap,
- Map<Integer, Connector> intMap,
- Map<SimpleTestBean, SimpleTestBean> beanMap) {
- Map<SimpleTestBean, SimpleTestBean> updatedBeanMap = new HashMap<SimpleTestBean, SimpleTestBean>();
- for (Entry<SimpleTestBean, SimpleTestBean> entry : beanMap
- .entrySet()) {
- updatedBeanMap.put(entry.getValue(), entry.getKey());
- }
-
- rpc.sendMap(Collections.singletonMap("a", stringMap.get("b")),
- Collections.singletonMap(getThisConnector(),
- connectorMap.get(getRootConnector())),
- Collections.singletonMap(
- Integer.valueOf(stringMap.size()),
- getThisConnector()), updatedBeanMap);
- }
-
- public void sendLong(long value, Long boxedValue, long[] array) {
- rpc.sendLong(array[0], Long.valueOf(value), new long[] {
- array[1], boxedValue.longValue() });
- }
-
- public void sendList(List<Integer> intList,
- List<Connector> connectorList, List<SimpleTestBean> beanList) {
- Collections.sort(intList);
- Collections.reverse(beanList);
- rpc.sendList(intList,
- Arrays.asList(getThisConnector(), getRootConnector()),
- beanList);
- }
-
- public void sendInt(int value, Integer boxedValue, int[] array) {
- rpc.sendInt(array.length, Integer.valueOf(array[0]), new int[] {
- value, boxedValue.intValue() });
- }
-
- public void sendFloat(float value, Float boxedValue, float[] array) {
- Arrays.sort(array);
- rpc.sendFloat(boxedValue.floatValue(), Float.valueOf(value),
- array);
- }
-
- public void sendDouble(double value, Double boxedValue,
- double[] array) {
- rpc.sendDouble(value + boxedValue.doubleValue(),
- Double.valueOf(value - boxedValue.doubleValue()),
- new double[] { array.length, array[0], array[1] });
- }
-
- public void sendConnector(Connector connector) {
- rpc.sendConnector(getThisConnector());
- }
-
- public void sendChar(char value, Character boxedValue, char[] array) {
- rpc.sendChar(Character.toUpperCase(boxedValue.charValue()),
- Character.valueOf(value), new String(array)
- .toLowerCase().toCharArray());
- }
-
- public void sendByte(byte value, Byte boxedValue, byte[] array) {
- // There will most certainly be a bug that is not discovered
- // because this particular method doesn't do anything with it's
- // values...
- rpc.sendByte(value, boxedValue, array);
- }
-
- public void sendBoolean(boolean value, Boolean boxedValue,
- boolean[] array) {
- boolean[] inverseArray = new boolean[array.length];
- for (int i = 0; i < array.length; i++) {
- inverseArray[i] = !array[i];
- }
- rpc.sendBoolean(boxedValue == Boolean.TRUE,
- Boolean.valueOf(!value), inverseArray);
- }
-
- public void sendBean(ComplexTestBean complexBean,
- SimpleTestBean simpleBean, SimpleTestBean[] array) {
- SimpleTestBean updatedSimpleBean = new SimpleTestBean();
- updatedSimpleBean.setValue(complexBean.getInnerBean1()
- .getValue());
-
- ComplexTestBean updatedComplexBean = new ComplexTestBean();
- updatedComplexBean.setInnerBean1(complexBean.getInnerBean2());
- updatedComplexBean.setInnerBean2(complexBean
- .getInnerBeanCollection().get(0));
- updatedComplexBean.setInnerBeanCollection(Arrays.asList(
- simpleBean, updatedSimpleBean));
- updatedComplexBean.setPrivimite(complexBean.getPrivimite() + 1);
-
- ArrayList<SimpleTestBean> arrayList = new ArrayList<SimpleTestBean>(
- Arrays.asList(array));
- Collections.reverse(arrayList);
-
- rpc.sendBean(updatedComplexBean, updatedSimpleBean,
- arrayList.toArray(new SimpleTestBean[array.length]));
- }
-
- public void sendArrayList(List<int[]> primitiveArrayList,
- List<Integer[]> objectArrayList,
- List<SimpleTestBean[]> beanArrayList) {
- Collections.reverse(beanArrayList);
- List<Integer[]> updatedObjectArrayList = new ArrayList<Integer[]>();
- for (int[] array : primitiveArrayList) {
- updatedObjectArrayList.add(new Integer[] {
- Integer.valueOf(array.length),
- Integer.valueOf(array[0]) });
- }
-
- rpc.sendArrayList(Arrays.asList(
- new int[] { primitiveArrayList.size() },
- new int[] { objectArrayList.get(0).length }),
- updatedObjectArrayList, beanArrayList);
- }
-
- public void sendNull(String value1, String value2) {
- rpc.sendNull(value2, value1);
- }
-
- public void sendListArray(List<Integer>[] objectListArray,
- List<SimpleTestBean>[] beanListArray) {
- rpc.sendListArray(new List[] { objectListArray[1],
- objectListArray[0] }, new List[] { Collections
- .singletonList(beanListArray[0].get(0)) });
- }
- });
- }
-
- private Connector getRootConnector() {
- return getConnection().getRootConnector();
- }
-
- private Connector getThisConnector() {
- // Cast to Connector for use in e.g. Collections.singleton() to get a
- // Set<Connector>
- return this;
- }
-
- @Override
- public ComplexTestBean getState() {
- return (ComplexTestBean) super.getState();
- }
-
- @Override
- public void onStateChanged(StateChangeEvent stateChangeEvent) {
- // TODO do something clever
- }
-
- }
|