01: /*
02: * Licensed to the Apache Software Foundation (ASF) under one or more
03: * contributor license agreements. See the NOTICE file distributed with
04: * this work for additional information regarding copyright ownership.
05: * The ASF licenses this file to You under the Apache License, Version 2.0
06: * (the "License"); you may not use this file except in compliance with
07: * the License. You may obtain a copy of the License at
08: *
09: * http://www.apache.org/licenses/LICENSE-2.0
10: *
11: * Unless required by applicable law or agreed to in writing, software
12: * distributed under the License is distributed on an "AS IS" BASIS,
13: * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14: * See the License for the specific language governing permissions and
15: * limitations under the License.
16: */
17:
18: package java.lang.reflect;
19:
20: /**
21: * Implementors of this interface model a class member.
22: *
23: * @see Field
24: * @see Constructor
25: * @see Method
26: */
27: public interface Member {
28:
29: public static final int PUBLIC = 0;
30:
31: public static final int DECLARED = 1;
32:
33: /**
34: * Return the {@link Class} associated with the class that defined this
35: * member.
36: *
37: * @return the declaring class
38: */
39: @SuppressWarnings("unchecked")
40: Class getDeclaringClass();
41:
42: /**
43: * Return the modifiers for the member. The Modifier class should be used to
44: * decode the result.
45: *
46: * @return the modifiers
47: * @see java.lang.reflect.Modifier
48: */
49: int getModifiers();
50:
51: /**
52: * Return the name of the member.
53: *
54: * @return the name
55: */
56: String getName();
57:
58: /**
59: * Indicates whether or not this member is synthetic (artificially
60: * introduced by the compiler).
61: *
62: * @return A value of <code>true</code> if synthetic, otherwise
63: * <code>false</code>.
64: */
65: boolean isSynthetic();
66: }
|