• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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 
17 package com.android.dx.rop.annotation;
18 
19 import com.android.dx.util.FixedSizeList;
20 
21 /**
22  * List of {@link Annotations} instances.
23  */
24 public final class AnnotationsList
25         extends FixedSizeList {
26     /** {@code non-null;} immutable empty instance */
27     public static final AnnotationsList EMPTY = new AnnotationsList(0);
28 
29     /**
30      * Constructs an immutable instance which is the combination of
31      * the two given instances. The two instances must each have the
32      * same number of elements, and each pair of elements must contain
33      * disjoint sets of types.
34      *
35      * @param list1 {@code non-null;} an instance
36      * @param list2 {@code non-null;} the other instance
37      * @return {@code non-null;} the combination
38      */
combine(AnnotationsList list1, AnnotationsList list2)39     public static AnnotationsList combine(AnnotationsList list1,
40             AnnotationsList list2) {
41         int size = list1.size();
42 
43         if (size != list2.size()) {
44             throw new IllegalArgumentException("list1.size() != list2.size()");
45         }
46 
47         AnnotationsList result = new AnnotationsList(size);
48 
49         for (int i = 0; i < size; i++) {
50             Annotations a1 = list1.get(i);
51             Annotations a2 = list2.get(i);
52             result.set(i, Annotations.combine(a1, a2));
53         }
54 
55         result.setImmutable();
56         return result;
57     }
58 
59     /**
60      * Constructs an instance. All indices initially contain {@code null}.
61      *
62      * @param size the size of the list
63      */
AnnotationsList(int size)64     public AnnotationsList(int size) {
65         super(size);
66     }
67 
68     /**
69      * Gets the element at the given index. It is an error to call
70      * this with the index for an element which was never set; if you
71      * do that, this will throw {@code NullPointerException}.
72      *
73      * @param n {@code >= 0, < size();} which index
74      * @return {@code non-null;} element at that index
75      */
get(int n)76     public Annotations get(int n) {
77         return (Annotations) get0(n);
78     }
79 
80     /**
81      * Sets the element at the given index. The given element must be
82      * immutable.
83      *
84      * @param n {@code >= 0, < size();} which index
85      * @param a {@code null-ok;} the element to set at {@code n}
86      */
set(int n, Annotations a)87     public void set(int n, Annotations a) {
88         a.throwIfMutable();
89         set0(n, a);
90     }
91 }
92