1917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul/* 2917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Copyright (C) 2007 The Android Open Source Project 3917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 4917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Licensed under the Apache License, Version 2.0 (the "License"); 5917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * you may not use this file except in compliance with the License. 6917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * You may obtain a copy of the License at 7917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 8917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * http://www.apache.org/licenses/LICENSE-2.0 9917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 10917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Unless required by applicable law or agreed to in writing, software 11917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * distributed under the License is distributed on an "AS IS" BASIS, 12917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * See the License for the specific language governing permissions and 14917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * limitations under the License. 15917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul */ 16917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 17917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgulpackage com.android.dexgen.rop.cst; 18917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 19917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgulimport com.android.dexgen.rop.type.Type; 20917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgulimport com.android.dexgen.util.FixedSizeList; 21917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 22917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul/** 23917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Constant type to represent a fixed array of other constants. The contents 24917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * may be of any type <i>other</i> than {@link CstUtf8}. 25917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul */ 26917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgulpublic final class CstArray extends Constant { 27917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** {@code non-null;} the actual list of contents */ 28917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul private final List list; 29917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 30917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** 31917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Constructs an instance. 32917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 33917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * @param list {@code non-null;} the actual list of contents 34917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul */ 35917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public CstArray(List list) { 36917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul if (list == null) { 37917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul throw new NullPointerException("list == null"); 38917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 39917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 40917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul list.throwIfMutable(); 41917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 42917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul this.list = list; 43917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 44917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 45917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** {@inheritDoc} */ 46917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul @Override 47917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public boolean equals(Object other) { 48917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul if (! (other instanceof CstArray)) { 49917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul return false; 50917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 51917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 52917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul return list.equals(((CstArray) other).list); 53917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 54917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 55917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** {@inheritDoc} */ 56917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul @Override 57917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public int hashCode() { 58917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul return list.hashCode(); 59917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 60917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 61917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** {@inheritDoc} */ 62917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul @Override 63917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul protected int compareTo0(Constant other) { 64917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul return list.compareTo(((CstArray) other).list); 65917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 66917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 67917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** {@inheritDoc} */ 68917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul @Override 69917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public String toString() { 70917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul return list.toString("array{", ", ", "}"); 71917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 72917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 73917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** {@inheritDoc} */ 74917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul @Override 75917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public String typeName() { 76917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul return "array"; 77917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 78917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 79917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** {@inheritDoc} */ 80917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul @Override 81917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public boolean isCategory2() { 82917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul return false; 83917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 84917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 85917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** {@inheritDoc} */ 86917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public String toHuman() { 87917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul return list.toHuman("{", ", ", "}"); 88917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 89917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 90917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** 91917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Get the underlying list. 92917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 93917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * @return {@code non-null;} the list 94917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul */ 95917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public List getList() { 96917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul return list; 97917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 98917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 99917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** 100917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * List of {@link Constant} instances. 101917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul */ 102917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public static final class List 103917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul extends FixedSizeList implements Comparable<List> { 104917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** 105917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Constructs an instance. All indices initially contain 106917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * {@code null}. 107917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 108917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * @param size the size of the list 109917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul */ 110917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public List(int size) { 111917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul super(size); 112917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 113917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 114917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** {@inheritDoc} */ 115917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public int compareTo(List other) { 116917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul int thisSize = size(); 117917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul int otherSize = other.size(); 118917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul int compareSize = (thisSize < otherSize) ? thisSize : otherSize; 119917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 120917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul for (int i = 0; i < compareSize; i++) { 121917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul Constant thisItem = (Constant) get0(i); 122917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul Constant otherItem = (Constant) other.get0(i); 123917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul int compare = thisItem.compareTo(otherItem); 124917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul if (compare != 0) { 125917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul return compare; 126917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 127917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 128917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 129917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul if (thisSize < otherSize) { 130917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul return -1; 131917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } else if (thisSize > otherSize) { 132917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul return 1; 133917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 134917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 135917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul return 0; 136917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 137917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 138917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** 139917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Gets the element at the given index. It is an error to call 140917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * this with the index for an element which was never set; if you 141917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * do that, this will throw {@code NullPointerException}. 142917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 143917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * @param n {@code >= 0, < size();} which index 144917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * @return {@code non-null;} element at that index 145917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul */ 146917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public Constant get(int n) { 147917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul return (Constant) get0(n); 148917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 149917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 150917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** 151917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Sets the element at the given index. 152917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 153917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * @param n {@code >= 0, < size();} which index 154917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * @param a {@code null-ok;} the element to set at {@code n} 155917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul */ 156917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public void set(int n, Constant a) { 157917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul if (a instanceof CstUtf8) { 158917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul throw new IllegalArgumentException("bad value: " + a); 159917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 160917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 161917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul set0(n, a); 162917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 163917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul } 164917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul} 165