View Javadoc

1   package org.apache.onami.autobind.aop;
2   
3   /*
4    * Licensed to the Apache Software Foundation (ASF) under one or more
5    * contributor license agreements.  See the NOTICE file distributed with
6    * this work for additional information regarding copyright ownership.
7    * The ASF licenses this file to You under the Apache License, Version 2.0
8    * (the "License"); you may not use this file except in compliance with
9    * the License.  You may obtain a copy of the License at
10   *
11   *  http://www.apache.org/licenses/LICENSE-2.0
12   *
13   * Unless required by applicable law or agreed to in writing, software
14   * distributed under the License is distributed on an "AS IS" BASIS,
15   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16   * See the License for the specific language governing permissions and
17   * limitations under the License.
18   */
19  
20  import static java.lang.annotation.ElementType.METHOD;
21  import static java.lang.annotation.RetentionPolicy.RUNTIME;
22  
23  import java.lang.annotation.Documented;
24  import java.lang.annotation.Retention;
25  import java.lang.annotation.Target;
26  import java.lang.reflect.Method;
27  
28  import org.aopalliance.intercept.MethodInterceptor;
29  
30  /**
31   * This Annotation marks a Method, which returns an Object of Type
32   * {@link Matcher}. This Matcher is used by Guice, to decide if a
33   * {@link MethodInterceptor} should be invoked for that {@link Method}.
34   *
35   * <pre>@MethodMatcher
36   * public Matcher<? super Method> getMethodMatcher()
37   * {
38   *     return Matchers.annotatedWith( Intercept.class );
39   * }
40   */
41  @Documented
42  @Retention( RUNTIME )
43  @Target( { METHOD } )
44  public @interface MethodMatcher
45  {
46  }