/* * Copyright 2010 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.classprocessors; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.castor.core.annotationprocessing.AnnotationTargetException; import org.castor.core.nature.BaseNature; import org.castor.jdo.jpa.natures.JPAClassNature; import org.castor.jdo.jpa.processors.BaseJPAAnnotationProcessor; import javax.persistence.NamedQueries; import javax.persistence.NamedQuery; import java.lang.annotation.Annotation; import java.lang.reflect.AnnotatedElement; import java.util.HashMap; import java.util.Map; /** * Processes the JPA annotation {@link NamedQuery}. After this processor is * done, {@link JPAClassNature#getNamedQuery()} returns a valid value! */ public class JPANamedQueriesProcessor extends BaseJPAAnnotationProcessor { private final Log LOG = LogFactory.getLog(getClass()); /** * {@inheritDoc} * * @see org.castor.core.annotationprocessing.AnnotationProcessor# * forAnnotationClass() */ public Class<? extends Annotation> forAnnotationClass() { return NamedQueries.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) throws AnnotationTargetException { if ((info instanceof JPAClassNature) && (annotation instanceof NamedQueries) && (target instanceof Class<?>) && (target.isAnnotationPresent(NamedQueries.class))) { LOG.debug("Processing class annotation " + annotation.toString()); final JPAClassNature jpaClassNature = (JPAClassNature) info; final NamedQueries namedQueries = (NamedQueries) annotation; final Map<String, String> namedQueryMap = new HashMap<String, String>(); NamedQuery[] namedQueriesValues = namedQueries.value(); if (namedQueriesValues != null && namedQueriesValues.length > 0) for (NamedQuery namedQuery : namedQueriesValues) { namedQueryMap.put(namedQuery.name(), namedQuery.query()); } jpaClassNature.setNamedQuery(namedQueryMap); return true; } return false; } }