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
19fe107fb6e3f308ac5174ebdc5a794ee880c741d9Jesse Wilsonimport com.android.dex.SizeOf;
20333201833d506a3accdeac6ceb7caba8d4b95797Jesse Wilsonimport com.android.dx.rop.cst.CstString;
21f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectimport com.android.dx.util.AnnotatedOutput;
22f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectimport com.android.dx.util.Hex;
23f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
24f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project/**
25f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * Representation of a string inside a Dalvik file.
26f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project */
27f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectpublic final class StringIdItem
28f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        extends IndexedItem implements Comparable {
2999409883d9c4c0ffb49b070ce307bb33a9dfe9f1The Android Open Source Project    /** {@code non-null;} the string value */
30333201833d506a3accdeac6ceb7caba8d4b95797Jesse Wilson    private final CstString value;
31f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
3299409883d9c4c0ffb49b070ce307bb33a9dfe9f1The Android Open Source Project    /** {@code null-ok;} associated string data object, if known */
33f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    private StringDataItem data;
34f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
35f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /**
36f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * Constructs an instance.
37de75089fb7216d19e9c22cce4dc62a49513477d3Carl Shapiro     *
3899409883d9c4c0ffb49b070ce307bb33a9dfe9f1The Android Open Source Project     * @param value {@code non-null;} the string value
39f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     */
40333201833d506a3accdeac6ceb7caba8d4b95797Jesse Wilson    public StringIdItem(CstString value) {
41f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        if (value == null) {
42f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project            throw new NullPointerException("value == null");
43f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        }
44f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
45f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        this.value = value;
46f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        this.data = null;
47f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
48f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
49f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /** {@inheritDoc} */
50f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    @Override
51f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public boolean equals(Object other) {
52f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        if (!(other instanceof StringIdItem)) {
53f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project            return false;
54f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        }
55f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
56f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        StringIdItem otherString = (StringIdItem) other;
57f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        return value.equals(otherString.value);
58f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
59f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
60f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /** {@inheritDoc} */
61f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    @Override
62f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public int hashCode() {
63f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        return value.hashCode();
64f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
65f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
66f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /** {@inheritDoc} */
67f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public int compareTo(Object other) {
68f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        StringIdItem otherString = (StringIdItem) other;
69f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        return value.compareTo(otherString.value);
70f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
71f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
72f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /** {@inheritDoc} */
73f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    @Override
74f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public ItemType itemType() {
75f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        return ItemType.TYPE_STRING_ID_ITEM;
76f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
77f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
78f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /** {@inheritDoc} */
79f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    @Override
80f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public int writeSize() {
81081c7142b29ccd6e1744b26e097b6a4d7c12f2bdJesse Wilson        return SizeOf.STRING_ID_ITEM;
82f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
83f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
84f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /** {@inheritDoc} */
85f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    @Override
86f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public void addContents(DexFile file) {
87f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        if (data == null) {
88f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project            // The string data hasn't yet been added, so add it.
89f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project            MixedItemSection stringData = file.getStringData();
90f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project            data = new StringDataItem(value);
91f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project            stringData.add(data);
92f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        }
93f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
94f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
95f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /** {@inheritDoc} */
96f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    @Override
97f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public void writeTo(DexFile file, AnnotatedOutput out) {
98f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        int dataOff = data.getAbsoluteOffset();
99f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
100f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        if (out.annotates()) {
101f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project            out.annotate(0, indexString() + ' ' + value.toQuoted(100));
102f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project            out.annotate(4, "  string_data_off: " + Hex.u4(dataOff));
103f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        }
104f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
105f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        out.writeInt(dataOff);
106f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
107f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
108f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /**
109f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * Gets the string value.
110de75089fb7216d19e9c22cce4dc62a49513477d3Carl Shapiro     *
11199409883d9c4c0ffb49b070ce307bb33a9dfe9f1The Android Open Source Project     * @return {@code non-null;} the value
112f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     */
113333201833d506a3accdeac6ceb7caba8d4b95797Jesse Wilson    public CstString getValue() {
114f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        return value;
115f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
116f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
117f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /**
118f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * Gets the associated data object for this instance, if known.
119de75089fb7216d19e9c22cce4dc62a49513477d3Carl Shapiro     *
12099409883d9c4c0ffb49b070ce307bb33a9dfe9f1The Android Open Source Project     * @return {@code null-ok;} the associated data object or {@code null}
121f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * if not yet known
122f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     */
123f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public StringDataItem getData() {
124f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        return data;
125f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
126f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project}
127