1f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project/*
2f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * Copyright (C) 2007 The Android Open Source Project
3f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *
4f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License");
5f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * you may not use this file except in compliance with the License.
6f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * You may obtain a copy of the License at
7f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *
8f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0
9f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *
10f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * Unless required by applicable law or agreed to in writing, software
11f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS,
12f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * See the License for the specific language governing permissions and
14f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * limitations under the License.
15f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project */
16f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
17f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectpackage com.android.dx.dex.file;
18f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
19333201833d506a3accdeac6ceb7caba8d4b95797Jesse Wilsonimport com.android.dx.rop.cst.CstString;
20f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectimport com.android.dx.util.AnnotatedOutput;
21f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectimport com.android.dx.util.ToHuman;
22f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
23f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectimport java.io.PrintWriter;
24f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
25f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project/**
26f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * Representation of a member (field or method) of a class, for the
27f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * purposes of encoding it inside a {@link ClassDataItem}.
28f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project */
29f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectpublic abstract class EncodedMember implements ToHuman {
30f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /** access flags */
31f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    private final int accessFlags;
32f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
33f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /**
34f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * Constructs an instance.
35f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     *
36f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * @param accessFlags access flags for the member
37f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     */
38f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public EncodedMember(int accessFlags) {
39f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        this.accessFlags = accessFlags;
40f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
41f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
42f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /**
43f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * Gets the access flags.
44f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     *
45f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * @return the access flags
46f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     */
47f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public final int getAccessFlags() {
48f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        return accessFlags;
49f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
50f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
51f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /**
52f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * Gets the name.
53f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     *
5499409883d9c4c0ffb49b070ce307bb33a9dfe9f1The Android Open Source Project     * @return {@code non-null;} the name
55f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     */
56333201833d506a3accdeac6ceb7caba8d4b95797Jesse Wilson    public abstract CstString getName();
57f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
58f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /**
59f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * Does a human-friendly dump of this instance.
60f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     *
6199409883d9c4c0ffb49b070ce307bb33a9dfe9f1The Android Open Source Project     * @param out {@code non-null;} where to dump
62f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * @param verbose whether to be verbose with the output
63f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     */
64f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public abstract void debugPrint(PrintWriter out, boolean verbose);
65f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
66f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /**
67f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * Populates a {@link DexFile} with items from within this instance.
68de75089fb7216d19e9c22cce4dc62a49513477d3Carl Shapiro     *
6999409883d9c4c0ffb49b070ce307bb33a9dfe9f1The Android Open Source Project     * @param file {@code non-null;} the file to populate
70f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     */
71f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public abstract void addContents(DexFile file);
72f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
73f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /**
74f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * Encodes this instance to the given output.
75de75089fb7216d19e9c22cce4dc62a49513477d3Carl Shapiro     *
7699409883d9c4c0ffb49b070ce307bb33a9dfe9f1The Android Open Source Project     * @param file {@code non-null;} file this instance is part of
7799409883d9c4c0ffb49b070ce307bb33a9dfe9f1The Android Open Source Project     * @param out {@code non-null;} where to write to
7899409883d9c4c0ffb49b070ce307bb33a9dfe9f1The Android Open Source Project     * @param lastIndex {@code >= 0;} the previous member index value encoded, or
7999409883d9c4c0ffb49b070ce307bb33a9dfe9f1The Android Open Source Project     * {@code 0} if this is the first element to encode
8099409883d9c4c0ffb49b070ce307bb33a9dfe9f1The Android Open Source Project     * @param dumpSeq {@code >= 0;} sequence number of this instance for
81f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * annotation purposes
8299409883d9c4c0ffb49b070ce307bb33a9dfe9f1The Android Open Source Project     * @return {@code >= 0;} the member index value that was encoded
83f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     */
84de75089fb7216d19e9c22cce4dc62a49513477d3Carl Shapiro    public abstract int encode(DexFile file, AnnotatedOutput out,
85f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project            int lastIndex, int dumpSeq);
86f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project}
87