 
                        
        
                        
        org.metawidget.inspector.annotation.MetawidgetAnnotationInspector Maven / Gradle / Ivy
// Metawidget
//
// This file is dual licensed under both the LGPL
// (http://www.gnu.org/licenses/lgpl-2.1.html) and the EPL
// (http://www.eclipse.org/org/documents/epl-v10.php). As a
// recipient of Metawidget, you may choose to receive it under either
// the LGPL or the EPL.
//
// Commercial licenses are also available. See http://metawidget.org
// for details.
package org.metawidget.inspector.annotation;
import static org.metawidget.inspector.InspectionResultConstants.*;
import java.util.Map;
import org.metawidget.inspector.impl.BaseObjectInspector;
import org.metawidget.inspector.impl.BaseObjectInspectorConfig;
import org.metawidget.inspector.impl.Trait;
import org.metawidget.inspector.impl.actionstyle.Action;
import org.metawidget.inspector.impl.propertystyle.Property;
import org.metawidget.util.ArrayUtils;
import org.metawidget.util.CollectionUtils;
/**
 * Inspects annotations defined by Metawidget (declared in this same package).
 * 
 * Note: the name of this class is longwinded for extra clarity. It is not just a
 * 'MetawidgetInspector', because of course there are lots of different Metawidget Inspectors.
 * Equally, it is not just an 'AnnotationInspector', because it doesn't generically scan all
 * possible annotations.
 *
 * @author Richard Kennard
 */
public class MetawidgetAnnotationInspector
	extends BaseObjectInspector {
	//
	// Constructor
	//
	public MetawidgetAnnotationInspector() {
		this( new BaseObjectInspectorConfig() );
	}
	public MetawidgetAnnotationInspector( BaseObjectInspectorConfig config ) {
		super( config );
	}
	//
	// Protected methods
	//
	@Override
	protected Map inspectTrait( Trait trait )
		throws Exception {
		Map attributes = CollectionUtils.newHashMap();
		// UiHidden
		if ( trait.isAnnotationPresent( UiHidden.class ) ) {
			attributes.put( HIDDEN, TRUE );
		}
		// UiComesAfter
		UiComesAfter comesAfter = trait.getAnnotation( UiComesAfter.class );
		if ( comesAfter != null ) {
			attributes.put( COMES_AFTER, ArrayUtils.toString( comesAfter.value() ) );
		}
		// UiReadOnly
		UiReadOnly readOnly = trait.getAnnotation( UiReadOnly.class );
		if ( readOnly != null ) {
			attributes.put( READ_ONLY, TRUE );
		}
		// UiSection
		UiSection uiSection = trait.getAnnotation( UiSection.class );
		if ( uiSection != null ) {
			attributes.put( SECTION, ArrayUtils.toString( uiSection.value() ) );
		}
		// UiLabel
		UiLabel label = trait.getAnnotation( UiLabel.class );
		if ( label != null ) {
			attributes.put( LABEL, label.value() );
		}
		// UiAttribute
		UiAttribute uiAttribute = trait.getAnnotation( UiAttribute.class );
		if ( uiAttribute != null ) {
			putUiAttribute( uiAttribute, attributes );
		}
		// UiAttributes
		UiAttributes uiAttributes = trait.getAnnotation( UiAttributes.class );
		if ( uiAttributes != null ) {
			for ( UiAttribute nestedUiAttribute : uiAttributes.value() ) {
				putUiAttribute( nestedUiAttribute, attributes );
			}
		}
		return attributes;
	}
	@Override
	protected Map inspectProperty( Property property )
		throws Exception {
		Map attributes = CollectionUtils.newHashMap();
		// UiRequired
		if ( property.isAnnotationPresent( UiRequired.class ) ) {
			attributes.put( REQUIRED, TRUE );
		}
		// UiLookup
		UiLookup lookup = property.getAnnotation( UiLookup.class );
		if ( lookup != null ) {
			attributes.put( LOOKUP, ArrayUtils.toString( lookup.value() ) );
			// (note: values().length == labels().length() is not validated
			// here, as XmlInspector could bypass it anyway)
			if ( lookup.labels().length > 0 ) {
				attributes.put( LOOKUP_LABELS, ArrayUtils.toString( lookup.labels() ) );
			}
		}
		// UiMasked
		if ( property.isAnnotationPresent( UiMasked.class ) ) {
			attributes.put( MASKED, TRUE );
		}
		// UiLarge
		if ( property.isAnnotationPresent( UiLarge.class ) ) {
			attributes.put( LARGE, TRUE );
		}
		// UiWide
		if ( property.isAnnotationPresent( UiWide.class ) ) {
			attributes.put( WIDE, TRUE );
		}
		// UiDontExpand
		UiDontExpand dontExpand = property.getAnnotation( UiDontExpand.class );
		if ( dontExpand != null ) {
			attributes.put( DONT_EXPAND, TRUE );
		}
		return attributes;
	}
	@Override
	protected Map inspectAction( Action action )
		throws Exception {
		Map attributes = CollectionUtils.newHashMap();
		// UiAction (this is kind of a dummy match)
		if ( action.isAnnotationPresent( UiAction.class ) ) {
			attributes.put( NAME, action.getName() );
		}
		return attributes;
	}
	//
	// Private methods
	//
	private void putUiAttribute( UiAttribute uiAttribute, Map attributes ) {
		for ( String name : uiAttribute.name() ) {
			attributes.put( name, uiAttribute.value() );
		}
	}
}