View Javadoc

1   /*
2    * Copyright 2004-2008 the Seasar Foundation and the Others.
3    *
4    * Licensed under the Apache License, Version 2.0 (the "License");
5    * you may not use this file except in compliance with the License.
6    * You may obtain a copy of the License at
7    *
8    *     http://www.apache.org/licenses/LICENSE-2.0
9    *
10   * Unless required by applicable law or agreed to in writing, software
11   * distributed under the License is distributed on an "AS IS" BASIS,
12   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, 
13   * either express or implied. See the License for the specific language
14   * governing permissions and limitations under the License.
15   */
16  package org.seasar.uruma.binding.method;
17  
18  import java.lang.reflect.Method;
19  
20  import org.seasar.uruma.annotation.AsyncMethod;
21  import org.seasar.uruma.annotation.EventListener;
22  import org.seasar.uruma.annotation.EventListenerType;
23  import org.seasar.uruma.util.AssertionUtil;
24  
25  /**
26   * {@link EventListener} アノテートされたメソッドを表すクラスです。<br />
27   * 
28   * @author y-komori
29   */
30  public class EventListenerDef {
31      private Method targetMethod;
32  
33      private EventListener eventListener;
34  
35      private AsyncMethod asyncMethod;
36  
37      /**
38       * {@link EventListenerDef} を構築します。<br />
39       * 
40       * @param target
41       *            ターゲットメソッド
42       * @param eventListener
43       *            {@link EventListener}
44       * @param asyncMethod
45       *            {@link AsyncMethod} アノテーション
46       */
47      public EventListenerDef(final Method target,
48              final EventListener eventListener, final AsyncMethod asyncMethod) {
49          AssertionUtil.assertNotNull("target", target);
50          AssertionUtil.assertNotNull("eventListener", eventListener);
51          this.targetMethod = target;
52          this.eventListener = eventListener;
53          this.asyncMethod = asyncMethod;
54      }
55  
56      /**
57       * ターゲットメソッドの {@link Method} オブジェクトを取得します。<br />
58       * 
59       * @return ターゲットメソッドの {@link Method} オブジェクト
60       */
61      public Method getTargetMethod() {
62          return this.targetMethod;
63      }
64  
65      /**
66       * 対応するコンポーネントの ID を取得します。<br />
67       * 
68       * @return 対応するコンポーネントの ID
69       */
70      public String[] getId() {
71          return this.eventListener.id();
72      }
73  
74      /**
75       * イベントの種類を返します。<br />
76       * 
77       * @return イベントの種類
78       */
79      public EventListenerType getType() {
80          return this.eventListener.type();
81      }
82  
83      /**
84       * {@link AsyncMethod} アノテーションを返します。<br />
85       * 
86       * @return {@link AsyncMethod} アノテーション。アノテーションが存在しない場合は <code>null</code>。
87       */
88      public AsyncMethod getAsyncMethod() {
89          return this.asyncMethod;
90      }
91  }