/* * Copyright 2005 Werner Guttmann * * 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 org.castor.jdo.jpa.processors.fieldprocessors; import java.lang.annotation.Annotation; import java.lang.reflect.AnnotatedElement; import java.lang.reflect.Field; import java.lang.reflect.Method; import javax.persistence.FetchType; import javax.persistence.ManyToOne; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.castor.core.nature.BaseNature; import org.castor.jdo.jpa.natures.JPAFieldNature; import org.castor.jdo.jpa.processors.BaseJPAAnnotationProcessor; /** * Processes the JPA annotation {@link ManyToOne}. After this processor is done, * {@link JPAFieldNature#getRelationTargetEntity()}, * {@link JPAFieldNature#isRelationLazyFetch()} and * {@link JPAFieldNature#isRelationOptional()} will return valid values. * * @author Martin Kandler * @version 2009-01-03 */ public class JPAManyToOneProcessor extends BaseJPAAnnotationProcessor { /** * The <a href="http://jakarta.apache.org/commons/logging/">Jakarta Commons * Logging</a> instance used for all logging. */ private static Log _log = LogFactory.getFactory().getInstance( JPAManyToOneProcessor.class); /** * {@inheritDoc} * * @see org.castor.core.annotationprocessing.AnnotationProcessor#forAnnotationClass() */ public Class<? extends Annotation> forAnnotationClass() { return ManyToOne.class; } /** * {@inheritDoc} * * @see org.castor.core.annotationprocessing.TargetAwareAnnotationProcessor# * processAnnotation(BaseNature, Annotation, AnnotatedElement) */ public <I extends BaseNature, A extends Annotation> boolean processAnnotation( final I info, final A annotation, final AnnotatedElement target) { if ((info instanceof JPAFieldNature) && (annotation instanceof ManyToOne) && ((target instanceof Method) || (target instanceof Field))) { _log.debug("processing field annotation " + annotation.toString()); ManyToOne manyToOne = (ManyToOne) annotation; JPAFieldNature jpaFieldNature = (JPAFieldNature) info; jpaFieldNature.setManyToOne(true); /* * @ManyToOne.targetEntity */ Class<?> targetEntity = null; if (void.class.equals(manyToOne.targetEntity())) { // Target Entity not set if (target instanceof Field) { targetEntity = ((Field) target).getType(); } else { targetEntity = ((Method) target).getReturnType(); } } else { // Target Entity is set targetEntity = manyToOne.targetEntity(); } jpaFieldNature.setRelationTargetEntity(targetEntity); /* * @ManyToOne.cascade */ if (manyToOne.cascade().length > 0) { jpaFieldNature.setCascadeTypes(manyToOne.cascade()); } /* * @ManyToOne.fetch */ jpaFieldNature.setRelationLazyFetch(false); if (manyToOne.fetch() == FetchType.LAZY) { jpaFieldNature.setRelationLazyFetch(true); } /* * @ManyToOne.optional */ if (!manyToOne.optional()) { _log .warn("Checking of null values is not supported by Castor - " + "the database has to check for null values!"); } jpaFieldNature.setRelationOptional(manyToOne.optional()); return true; } return false; } }