1/*
2 * Copyright (C) 2007 The Android Open Source Project
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, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17package com.android.dx.cf.iface;
18
19import com.android.dx.rop.cst.ConstantPool;
20import com.android.dx.rop.cst.CstType;
21import com.android.dx.rop.cst.CstUtf8;
22import com.android.dx.rop.type.TypeList;
23
24/**
25 * Interface for things which purport to be class files or reasonable
26 * facsimiles thereof.
27 *
28 * <p><b>Note:</b> The fields referred to in this documentation are of the
29 * {@code ClassFile} structure defined in vmspec-2 sec4.1.
30 */
31public interface ClassFile {
32    /**
33     * Gets the field {@code magic}.
34     *
35     * @return the value in question
36     */
37    public int getMagic();
38
39    /**
40     * Gets the field {@code minor_version}.
41     *
42     * @return the value in question
43     */
44    public int getMinorVersion();
45
46    /**
47     * Gets the field {@code major_version}.
48     *
49     * @return the value in question
50     */
51    public int getMajorVersion();
52
53    /**
54     * Gets the field {@code access_flags}.
55     *
56     * @return the value in question
57     */
58    public int getAccessFlags();
59
60    /**
61     * Gets the field {@code this_class}, interpreted as a type constant.
62     *
63     * @return {@code non-null;} the value in question
64     */
65    public CstType getThisClass();
66
67    /**
68     * Gets the field {@code super_class}, interpreted as a type constant
69     * if non-zero.
70     *
71     * @return {@code null-ok;} the value in question
72     */
73    public CstType getSuperclass();
74
75    /**
76     * Gets the field {@code constant_pool} (along with
77     * {@code constant_pool_count}).
78     *
79     * @return {@code non-null;} the constant pool
80     */
81    public ConstantPool getConstantPool();
82
83    /**
84     * Gets the field {@code interfaces} (along with
85     * {@code interfaces_count}).
86     *
87     * @return {@code non-null;} the list of interfaces
88     */
89    public TypeList getInterfaces();
90
91    /**
92     * Gets the field {@code fields} (along with
93     * {@code fields_count}).
94     *
95     * @return {@code non-null;} the list of fields
96     */
97    public FieldList getFields();
98
99    /**
100     * Gets the field {@code methods} (along with
101     * {@code methods_count}).
102     *
103     * @return {@code non-null;} the list of fields
104     */
105    public MethodList getMethods();
106
107    /**
108     * Gets the field {@code attributes} (along with
109     * {@code attributes_count}).
110     *
111     * @return {@code non-null;} the list of attributes
112     */
113    public AttributeList getAttributes();
114
115    /**
116     * Gets the name out of the {@code SourceFile} attribute of this
117     * file, if any. This is a convenient shorthand for scrounging around
118     * the class's attributes.
119     *
120     * @return {@code non-null;} the constant pool
121     */
122    public CstUtf8 getSourceFile();
123}
124