/******************************************************************************* * Copyright (c) 2008, 2015 Matthew Hall and others. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * Matthew Hall - initial API and implementation (bug 194734) * Matthew Hall - bug 195222, 247997, 261843, 264307 ******************************************************************************/ package org.eclipse.core.databinding.beans; import java.beans.PropertyChangeEvent; import java.beans.PropertyDescriptor; import java.util.ArrayList; import java.util.List; import org.eclipse.core.databinding.property.list.IListProperty; import org.eclipse.core.databinding.property.map.IMapProperty; import org.eclipse.core.databinding.property.set.ISetProperty; import org.eclipse.core.databinding.property.value.IValueProperty; import org.eclipse.core.internal.databinding.beans.AnonymousPojoListProperty; import org.eclipse.core.internal.databinding.beans.AnonymousPojoMapProperty; import org.eclipse.core.internal.databinding.beans.AnonymousPojoSetProperty; import org.eclipse.core.internal.databinding.beans.AnonymousPojoValueProperty; import org.eclipse.core.internal.databinding.beans.BeanPropertyHelper; import org.eclipse.core.internal.databinding.beans.PojoListProperty; import org.eclipse.core.internal.databinding.beans.PojoListPropertyDecorator; import org.eclipse.core.internal.databinding.beans.PojoMapProperty; import org.eclipse.core.internal.databinding.beans.PojoMapPropertyDecorator; import org.eclipse.core.internal.databinding.beans.PojoSetProperty; import org.eclipse.core.internal.databinding.beans.PojoSetPropertyDecorator; import org.eclipse.core.internal.databinding.beans.PojoValueProperty; import org.eclipse.core.internal.databinding.beans.PojoValuePropertyDecorator; /** * A factory for creating properties for POJOs (plain old java objects) that * conform to idea of an object with getters and setters but does not provide * {@link PropertyChangeEvent property change events} on change. This factory is * identical to {@link BeanProperties} except for this fact. * * @since 1.2 */ public class PojoProperties { /** * Returns a value property for the given property name of an arbitrary bean * class. Objects lacking the named property are treated the same as if the * property always contains null. * * @param propertyName * the property name. May be nested e.g. "parent.name" * @return a value property for the given property name of an arbitrary bean * class. */ public static IBeanValueProperty value(String propertyName) { return value(null, propertyName, null); } /** * Returns a value property for the given property name of an arbitrary bean * class. Objects lacking the named property are treated the same as if the * property always contains null. * * @param propertyName * the property name. May be nested e.g. "parent.name" * @param valueType * the value type of the returned value property * @return a value property for the given property name of an arbitrary bean * class. */ public static IBeanValueProperty value(String propertyName, Class valueType) { return value(null, propertyName, valueType); } /** * Returns a value property for the given property name of the given bean * class. * * @param beanClass * the bean class * @param propertyName * the property name. May be nested e.g. "parent.name" * @return a value property for the given property name of the given bean * class. */ public static IBeanValueProperty value(Class beanClass, String propertyName) { return value(beanClass, propertyName, null); } /** * Returns a value property for the given property name of the given bean * class. * * @param beanClass * the bean class * @param propertyName * the property name. May be nested e.g. "parent.name" * @param valueType * the value type of the returned value property * @return a value property for the given property name of the given bean * class. */ public static IBeanValueProperty value(Class beanClass, String propertyName, Class valueType) { String[] propertyNames = split(propertyName); if (propertyNames.length > 1) valueType = null; IValueProperty property; PropertyDescriptor propertyDescriptor; if (beanClass == null) { propertyDescriptor = null; property = new PojoValuePropertyDecorator( new AnonymousPojoValueProperty(propertyNames[0], valueType), null); } else { propertyDescriptor = BeanPropertyHelper.getPropertyDescriptor( beanClass, propertyNames[0]); property = new PojoValueProperty(propertyDescriptor, valueType); } IBeanValueProperty beanProperty = new PojoValuePropertyDecorator( property, propertyDescriptor); for (int i = 1; i < propertyNames.length; i++) { beanProperty = beanProperty.value(propertyNames[i]); } return beanProperty; } private static String[] split(String propertyName) { if (propertyName.indexOf('.') == -1) return new String[] { propertyName }; List propertyNames = new ArrayList(); int index; while ((index = propertyName.indexOf('.')) != -1) { propertyNames.add(propertyName.substring(0, index)); propertyName = propertyName.substring(index + 1); } propertyNames.add(propertyName); return (String[]) propertyNames .toArray(new String[propertyNames.size()]); } /** * Returns a value property array for the given property names of the given * bean class. * * @param beanClass * the bean class * @param propertyNames * array of property names. May be nested e.g. "parent.name" * @return a value property array for the given property names of the given * bean class. */ public static IBeanValueProperty[] values(Class beanClass, String[] propertyNames) { IBeanValueProperty[] properties = new IBeanValueProperty[propertyNames.length]; for (int i = 0; i < properties.length; i++) properties[i] = value(beanClass, propertyNames[i], null); return properties; } /** * Returns a value property array for the given property names of an * arbitrary bean class. * * @param propertyNames * array of property names. May be nested e.g. "parent.name" * @return a value property array for the given property names of the given * bean class. */ public static IBeanValueProperty[] values(String... propertyNames) { return values(null, propertyNames); } /** * Returns a set property for the given property name of an arbitrary bean * class. Objects lacking the named property are treated the same as if the * property always contains an empty set. * * @param propertyName * the property name * @return a set property for the given property name of an arbitrary bean * class. */ public static IBeanSetProperty set(String propertyName) { return set(null, propertyName, null); } /** * Returns a set property for the given property name of an arbitrary bean * class. Objects lacking the named property are treated the same as if the * property always contains an empty set. * * @param propertyName * the property name * @param elementType * the element type of the returned set property * @return a set property for the given property name of an arbitrary bean * class. */ public static IBeanSetProperty set(String propertyName, Class elementType) { return set(null, propertyName, elementType); } /** * Returns a set property for the given property name of the given bean * class. * * @param beanClass * the bean class * @param propertyName * the property name * @return a set property for the given property name of the given bean * class. */ public static IBeanSetProperty set(Class beanClass, String propertyName) { return set(beanClass, propertyName, null); } /** * Returns a set property for the given property name of the given bean * class. * * @param beanClass * the bean class * @param propertyName * the property name * @param elementType * the element type of the returned set property * @return a set property for the given property name of the given bean * class. */ public static IBeanSetProperty set(Class beanClass, String propertyName, Class elementType) { PropertyDescriptor propertyDescriptor; ISetProperty property; if (beanClass == null) { propertyDescriptor = null; property = new AnonymousPojoSetProperty(propertyName, elementType); } else { propertyDescriptor = BeanPropertyHelper.getPropertyDescriptor( beanClass, propertyName); property = new PojoSetProperty(propertyDescriptor, elementType); } return new PojoSetPropertyDecorator(property, propertyDescriptor); } /** * Returns a list property for the given property name of an arbitrary bean * class. Objects lacking the named property are treated the same as if the * property always contains an empty list. * * @param propertyName * the property name * @return a list property for the given property name of an arbitrary bean * class. */ public static IBeanListProperty list(String propertyName) { return list(null, propertyName, null); } /** * Returns a list property for the given property name of an arbitrary bean * class. Objects lacking the named property are treated the same as if the * property always contains an empty list. * * @param propertyName * the property name * @param elementType * the element type of the returned list property * @return a list property for the given property name of the given bean * class. */ public static IBeanListProperty list(String propertyName, Class elementType) { return list(null, propertyName, elementType); } /** * Returns a list property for the given property name of the given bean * class. * * @param beanClass * the bean class * @param propertyName * the property name * @return a list property for the given property name of the given bean * class. */ public static IBeanListProperty list(Class beanClass, String propertyName) { return list(beanClass, propertyName, null); } /** * Returns a list property for the given property name of the given bean * class. * * @param beanClass * the bean class * @param propertyName * the property name * @param elementType * the element type of the returned list property * @return a list property for the given property name of the given bean * class. */ public static IBeanListProperty list(Class beanClass, String propertyName, Class elementType) { PropertyDescriptor propertyDescriptor; IListProperty property; if (beanClass == null) { propertyDescriptor = null; property = new AnonymousPojoListProperty(propertyName, elementType); } else { propertyDescriptor = BeanPropertyHelper.getPropertyDescriptor( beanClass, propertyName); property = new PojoListProperty(propertyDescriptor, elementType); } return new PojoListPropertyDecorator(property, propertyDescriptor); } /** * Returns a map property for the given property name of an arbitrary bean * class. Objects lacking the named property are treated the same as if the * property always contains an empty map. * * @param propertyName * the property name * @return a map property for the given property name of an arbitrary bean * class. */ public static IBeanMapProperty map(String propertyName) { return map(null, propertyName, null, null); } /** * Returns a map property for the given property name of an arbitrary bean * class. Objects lacking the named property are treated the same as if the * property always contains an empty map. * * @param propertyName * the property name * @param keyType * the key type for the returned map property * @param valueType * the value type for the returned map property * @return a map property for the given property name of an arbitrary bean * class. */ public static IBeanMapProperty map(String propertyName, Class keyType, Class valueType) { return map(null, propertyName, keyType, valueType); } /** * Returns a map property for the given property name of the given bean * class. * * @param beanClass * the bean class * @param propertyName * the property name * @return a map property for the given property name of the given bean * class. */ public static IBeanMapProperty map(Class beanClass, String propertyName) { return map(beanClass, propertyName, null, null); } /** * Returns a map property for the given property name of the given bean * class. * * @param beanClass * the bean class * @param propertyName * the property name * @param keyType * the key type of the returned map property * @param valueType * the value type of the returned map property * @return a map property for the given property name of the given bean * class. */ public static IBeanMapProperty map(Class beanClass, String propertyName, Class keyType, Class valueType) { PropertyDescriptor propertyDescriptor; IMapProperty property; if (beanClass == null) { propertyDescriptor = null; property = new AnonymousPojoMapProperty(propertyName, keyType, valueType); } else { propertyDescriptor = BeanPropertyHelper.getPropertyDescriptor( beanClass, propertyName); property = new PojoMapProperty(propertyDescriptor, keyType, valueType); } return new PojoMapPropertyDecorator(property, propertyDescriptor); } }