Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
   *
   * Copyright (c) 2010-2011 Oracle and/or its affiliates. All rights reserved.
   *
   * The contents of this file are subject to the terms of either the GNU
   * General Public License Version 2 only ("GPL") or the Common Development
   * and Distribution License("CDDL") (collectively, the "License").  You
   * may not use this file except in compliance with the License.  You can
  * obtain a copy of the License at
  * http://glassfish.java.net/public/CDDL+GPL_1_1.html
  * or packager/legal/LICENSE.txt.  See the License for the specific
  * language governing permissions and limitations under the License.
  *
  * When distributing the software, include this License Header Notice in each
  * file and include the License file at packager/legal/LICENSE.txt.
  *
  * GPL Classpath Exception:
  * Oracle designates this particular file as subject to the "Classpath"
  * exception as provided by Oracle in the GPL Version 2 section of the License
  * file that accompanied this code.
  *
  * Modifications:
  * If applicable, add the following below the License Header, with the fields
  * enclosed by brackets [] replaced by your own identifying information:
  * "Portions Copyright [year] [name of copyright owner]"
  *
  * Contributor(s):
  * If you wish your version of this file to be governed by only the CDDL or
  * only the GPL Version 2, indicate your decision by adding "[Contributor]
  * elects to include this software in this distribution under the [CDDL or GPL
  * Version 2] license."  If you don't indicate a single choice of license, a
  * recipient has the option to distribute your version of this file under
  * either the CDDL, the GPL Version 2 or to extend the choice of license to
  * its licensees as provided above.  However, if you add GPL Version 2 code
  * and therefore, elected the GPL Version 2 license, then the option applies
  * only if the new code is made subject to such option by the copyright
  * holder.
  */
 
 package com.sun.jersey.core.reflection;
 
 import java.util.List;
 import java.util.Set;

Author(s):
Paul.Sandoz@Sun.Com
 
 public final class AnnotatedMethod implements AnnotatedElement {
     @SuppressWarnings("unchecked")
     private static final Set<Class<? extends Annotation>> 
             METHOD_META_ANNOTATIONS = getSet(
                 HttpMethod.class);
     
     @SuppressWarnings("unchecked")
     private static final Set<Class<? extends Annotation>> 
             METHOD_ANNOTATIONS = getSet(
                 Path.class
                 Produces.class
                 Consumes.class);
         
     @SuppressWarnings("unchecked")
     private static final Set<Class<? extends Annotation>> 
             PARAMETER_ANNOTATIONS = getSet
         Context.class
         Encoded.class
         DefaultValue.class,
         MatrixParam.class,
         QueryParam.class,
         CookieParam.class
         HeaderParam.class
         PathParam.class,
         FormParam.class);
     
     private static Set<Class<? extends Annotation>> getSet(Class<? extends Annotation>... cs) {
         Set<Class<? extends Annotation>> s = new HashSet<Class<? extends Annotation>>();
         for (Class<? extends Annotationc : css.add(c);
         return s;
    }
        
    private final Method m;
    
    private final Method am;
    private final Annotation[] methodAnnotations;
    
    private final Annotation[][] parameterAnnotations;
    
    public AnnotatedMethod(Method m) {
        this. = m;
        this. = findAnnotatedMethod(m);
        
        if (m.equals()) {
             = m.getAnnotations();
             = m.getParameterAnnotations();
        } else {
             = mergeMethodAnnotations(m);
             = mergeParameterAnnotations(m);
        }
    }
    public Method getMethod() {
        return ;
    }
    public Annotation[][] getParameterAnnotations() {
        return .clone();
    }
    
    public Class<?>[] getParameterTypes() {
        return .getParameterTypes();
    }
    
    public TypeVariable<Method>[] getTypeParameters() {
        return .getTypeParameters();
    } 
    
    public Type[] getGenericParameterTypes() {
        return .getGenericParameterTypes();
    }
                            
    public <T extends AnnotationList<T> getMetaMethodAnnotations(
            Class<T> annotation) {
        List <T> ma = new ArrayList<T>();
        for (Annotation a : ) {
            if (a.annotationType().getAnnotation(annotation) != null) {
                ma.add(a.annotationType().getAnnotation(annotation));
            }
        }
        
        return ma;
    }
    
    @Override
    public String toString() {
        return .toString();
    }
    
    // AnnotatedElement
    
    public boolean isAnnotationPresent(Class<? extends AnnotationannotationType) {
        for (Annotation ma : ) {
            if (ma.annotationType() == annotationType)
                return true;
        }
        return false;
    }
    public <T extends Annotation> T getAnnotation(Class<T> annotationType) {
        for (Annotation ma : ) {
            if (ma.annotationType() == annotationType)
                return annotationType.cast(ma);
        }
        return .getAnnotation(annotationType);
    }
    public Annotation[] getAnnotations() {
        return .clone();
    }
    public Annotation[] getDeclaredAnnotations() {
        return getAnnotations();
    }
    
    // 
    
    private static Annotation[] mergeMethodAnnotations(Method mMethod am) {
        List<Annotational = asList(m.getAnnotations());
        for (Annotation a : am.getAnnotations()) {
            if (!m.isAnnotationPresent(a.getClass()))
                al.add(a);
        }
        
        return al.toArray(new Annotation[0]);
    }
    
    private static Annotation[][] mergeParameterAnnotations(Method mMethod am) {        
        Annotation[][] mp = m.getParameterAnnotations();
        Annotation[][] amp = am.getParameterAnnotations();
        
        List<List<Annotation>> ala = new ArrayList<List<Annotation>>();        
        for (int i = 0; i < mp.lengthi++) {
            List<Annotational = asList(mp[i]);
            for (Annotation a : amp[i])
                if (!isAnnotatonPresent(a.getClass(), al))
                    al.add(a);
            ala.add(al);            
        }
        
        Annotation[][] paa = new Annotation[mp.length][];
        for (int i = 0; i < mp.lengthi++) {
            paa[i] = ala.get(i).toArray(new Annotation[0]);
        }
        
        return paa;
    }
    private static boolean isAnnotatonPresent(Class<? extends AnnotationcaList<Annotationla) {
        for (Annotation a : la) {
            if (ca == a.getClass())
                return true;
        }
        return false;
    }
    private static Method findAnnotatedMethod(Method m) {   
        Method am = findAnnotatedMethod(m.getDeclaringClass(), m);
        return (am != null) ? am : m;
    }
    private static Method findAnnotatedMethod(Class<?> cMethod m) {
        if (c == Object.class)
            return null;
        m = ReflectionHelper.findMethodOnClass(cm);
        if (m == null)
            return null;
        if (hasAnnotations(m)) return m;
        
        // Super classes take precendence over interfaces
        Class<?> sc = c.getSuperclass();
        if (sc != null && sc != Object.class) {
            Method sm = findAnnotatedMethod(scm);
            if (sm != nullreturn sm;
        }
        
        for (Class<?> ic : c.getInterfaces()) {
            Method im = findAnnotatedMethod(icm);
            if (im != nullreturn im;
        }
        return null;
    }    
    
    private static boolean hasAnnotations(Method m) {
        return hasMetaMethodAnnotations(m) || 
                hasMethodAnnotations(m) || 
                hasParameterAnnotations(m);
    }
    
    private static boolean hasMetaMethodAnnotations(Method m) {
        for (Class<? extends Annotationac : )
            for (Annotation a : m.getAnnotations())
                if (a.annotationType().getAnnotation(ac) != nullreturn true;
        
        return false;
    }
    
    private static boolean hasMethodAnnotations(Method m) {
        for (Class<? extends Annotationac : )
            if (m.isAnnotationPresent(ac)) return true;
        
        return false;
    }
    
    private static boolean hasParameterAnnotations(Method m) {
        for (Annotation[] as : m.getParameterAnnotations()) 
            for (Annotation a : as)
                if (.contains(a.annotationType())) return true;
                
        return false;
    }
    
    private static <T> List<T> asList(T... ts) {
        List<T> l = new ArrayList<T>();
        for (T t : tsl.add(t);
        return l;
    }
New to GrepCode? Check out our FAQ X