/* * Copyright 2011 Google Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); you may not * use this file except in compliance with the License. You may obtain a copy of * the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the * License for the specific language governing permissions and limitations under * the License. */ package com.google.gwt.user.server.rpc.core.java.util; import com.google.gwt.user.client.rpc.SerializationException; import com.google.gwt.user.client.rpc.SerializationStreamReader; import com.google.gwt.user.client.rpc.SerializationStreamWriter; import com.google.gwt.user.server.rpc.ServerCustomFieldSerializer; import com.google.gwt.user.server.rpc.impl.DequeMap; import com.google.gwt.user.server.rpc.impl.SerializabilityUtil; import com.google.gwt.user.server.rpc.impl.ServerSerializationStreamReader; import java.lang.reflect.Array; import java.lang.reflect.Type; import java.lang.reflect.TypeVariable; import java.util.List; /** * Dummy class for nesting the server-side custom serializer. */ public final class Arrays { /** * Server-side Custom field serializer for {@link java.util.Arrays.ArrayList}. */ @SuppressWarnings("rawtypes") public static final class ArrayList_ServerCustomFieldSerializer extends ServerCustomFieldSerializer<List> { public static String concreteType() { return java.util.Arrays.asList().getClass().getName(); } /* * Note: the reason this implementation differs from that of a standard List * (which serializes a number and then each element) is the requirement that * the underlying array retain its correct type across the wire. This gives * toArray() results the correct type, and can generate internal * ArrayStoreExceptions. * * The type checking is messy because we need some way of converting the * List<X> or related type that we are expecting into the array type that we * are about to try to read. You can't create objects of class Type * directly, so we need to create a dummy array and then use it's class as a * type. */ public static List<?> instantiate(ServerSerializationStreamReader streamReader, Type[] expectedParameterTypes, DequeMap<TypeVariable<?>, Type> resolvedTypes) throws SerializationException { Class<?> componentClass = SerializabilityUtil.getClassFromType(expectedParameterTypes[0], resolvedTypes); if (componentClass == null) { return com.google.gwt.user.client.rpc.core.java.util.Arrays.ArrayList_CustomFieldSerializer .instantiate(streamReader); } Object expectedArray = Array.newInstance(componentClass, 0); Object[] array = (Object[]) streamReader.readObject(expectedArray.getClass(), resolvedTypes); return java.util.Arrays.asList(array); } @Override public void deserializeInstance(SerializationStreamReader streamReader, List instance) throws SerializationException { com.google.gwt.user.client.rpc.core.java.util.Arrays.ArrayList_CustomFieldSerializer .deserialize(streamReader, instance); } @SuppressWarnings("unused") @Override public void deserializeInstance(ServerSerializationStreamReader streamReader, List instance, Type[] expectedParameterTypes, DequeMap<TypeVariable<?>, Type> actualParameterTypes) throws SerializationException { // Handled in instantiateInstance. } @Override public boolean hasCustomInstantiateInstance() { return true; } @Override public List instantiateInstance(SerializationStreamReader streamReader) throws SerializationException { return com.google.gwt.user.client.rpc.core.java.util.Arrays.ArrayList_CustomFieldSerializer .instantiate(streamReader); } @Override public List instantiateInstance(ServerSerializationStreamReader streamReader, Type[] expectedParameterTypes, DequeMap<TypeVariable<?>, Type> resolvedTypes) throws SerializationException { return instantiate(streamReader, expectedParameterTypes, resolvedTypes); } @Override public void serializeInstance(SerializationStreamWriter streamWriter, List instance) throws SerializationException { com.google.gwt.user.client.rpc.core.java.util.Arrays.ArrayList_CustomFieldSerializer .serialize(streamWriter, instance); } } }