com.vaadin.data.util.MethodPropertyDescriptor Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of vaadin Show documentation
Show all versions of vaadin Show documentation
Vaadin is a web application framework for Rich Internet Applications (RIA).
Vaadin enables easy development and maintenance of fast and secure rich web
applications with a stunning look and feel and a wide browser support.
It features a server-side architecture with the majority of the logic running
on the server. Ajax technology is used at the browser-side to ensure a rich
and interactive user experience.
/*
* Copyright 2011 Vaadin Ltd.
*
* 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.vaadin.data.util;
import java.io.IOException;
import java.lang.reflect.Method;
import java.util.logging.Level;
import java.util.logging.Logger;
import com.vaadin.data.Property;
import com.vaadin.util.SerializerHelper;
/**
* Property descriptor that is able to create simple {@link MethodProperty}
* instances for a bean, using given accessors.
*
* @param
* bean type
*
* @since 6.6
*/
public class MethodPropertyDescriptor implements
VaadinPropertyDescriptor {
private final String name;
private Class propertyType;
private transient Method readMethod;
private transient Method writeMethod;
/**
* Creates a property descriptor that can create MethodProperty instances to
* access the underlying bean property.
*
* @param name
* of the property
* @param propertyType
* type (class) of the property
* @param readMethod
* getter {@link Method} for the property
* @param writeMethod
* setter {@link Method} for the property or null if read-only
* property
*/
public MethodPropertyDescriptor(String name, Class propertyType,
Method readMethod, Method writeMethod) {
this.name = name;
this.propertyType = propertyType;
this.readMethod = readMethod;
this.writeMethod = writeMethod;
}
/* Special serialization to handle method references */
private void writeObject(java.io.ObjectOutputStream out) throws IOException {
out.defaultWriteObject();
SerializerHelper.writeClass(out, propertyType);
if (writeMethod != null) {
out.writeObject(writeMethod.getName());
SerializerHelper.writeClass(out, writeMethod.getDeclaringClass());
SerializerHelper.writeClassArray(out,
writeMethod.getParameterTypes());
} else {
out.writeObject(null);
out.writeObject(null);
out.writeObject(null);
}
if (readMethod != null) {
out.writeObject(readMethod.getName());
SerializerHelper.writeClass(out, readMethod.getDeclaringClass());
SerializerHelper.writeClassArray(out,
readMethod.getParameterTypes());
} else {
out.writeObject(null);
out.writeObject(null);
out.writeObject(null);
}
}
/* Special serialization to handle method references */
private void readObject(java.io.ObjectInputStream in) throws IOException,
ClassNotFoundException {
in.defaultReadObject();
try {
@SuppressWarnings("unchecked")
// business assumption; type parameters not checked at runtime
Class class1 = (Class) SerializerHelper.readClass(in);
propertyType = class1;
String name = (String) in.readObject();
Class writeMethodClass = SerializerHelper.readClass(in);
Class[] paramTypes = SerializerHelper.readClassArray(in);
if (name != null) {
writeMethod = writeMethodClass.getMethod(name, paramTypes);
} else {
writeMethod = null;
}
name = (String) in.readObject();
Class readMethodClass = SerializerHelper.readClass(in);
paramTypes = SerializerHelper.readClassArray(in);
if (name != null) {
readMethod = readMethodClass.getMethod(name, paramTypes);
} else {
readMethod = null;
}
} catch (SecurityException e) {
getLogger().log(Level.SEVERE, "Internal deserialization error", e);
} catch (NoSuchMethodException e) {
getLogger().log(Level.SEVERE, "Internal deserialization error", e);
}
};
public String getName() {
return name;
}
public Class getPropertyType() {
return propertyType;
}
public Property createProperty(Object bean) {
return new MethodProperty