1579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson/*
2579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson * Copyright (C) 2008 The Android Open Source Project
3579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson *
4579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson * Licensed under the Apache License, Version 2.0 (the "License");
5579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson * you may not use this file except in compliance with the License.
6579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson * You may obtain a copy of the License at
7579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson *
8579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson *      http://www.apache.org/licenses/LICENSE-2.0
9579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson *
10579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson * Unless required by applicable law or agreed to in writing, software
11579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson * distributed under the License is distributed on an "AS IS" BASIS,
12579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson * See the License for the specific language governing permissions and
14579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson * limitations under the License.
15579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson */
16579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
17579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilsonpackage com.android.dx.dex.code;
18579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
19579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilsonimport com.android.dx.rop.cst.CstType;
20579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilsonimport com.android.dx.util.FixedSizeList;
21579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilsonimport com.android.dx.util.Hex;
22579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
23579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson/**
24579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson * Ordered list of (exception type, handler address) entries.
25579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson */
26579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilsonpublic final class CatchHandlerList extends FixedSizeList
27579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        implements Comparable<CatchHandlerList> {
28579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    /** {@code non-null;} empty instance */
29579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    public static final CatchHandlerList EMPTY = new CatchHandlerList(0);
30579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
31579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    /**
32579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * Constructs an instance. All indices initially contain {@code null}.
33579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     *
34579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * @param size {@code >= 0;} the size of the list
35579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     */
36579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    public CatchHandlerList(int size) {
37579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        super(size);
38579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    }
39579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
40579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    /**
41579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * Gets the element at the given index. It is an error to call
42579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * this with the index for an element which was never set; if you
43579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * do that, this will throw {@code NullPointerException}.
44579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     *
45579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * @param n {@code >= 0, < size();} which index
46579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * @return {@code non-null;} element at that index
47579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     */
48579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    public Entry get(int n) {
49579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        return (Entry) get0(n);
50579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    }
51579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
52579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    /** {@inheritDoc} */
53579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    public String toHuman() {
54579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        return toHuman("", "");
55579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    }
56579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
57579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    /**
58579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * Get the human form of this instance, prefixed on each line
59579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * with the string.
60579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     *
61579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * @param prefix {@code non-null;} the prefix for every line
62579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * @param header {@code non-null;} the header for the first line (after the
63579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * first prefix)
64579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * @return {@code non-null;} the human form
65579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     */
66579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    public String toHuman(String prefix, String header) {
67579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        StringBuilder sb = new StringBuilder(100);
68579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        int size = size();
69579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
70579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        sb.append(prefix);
71579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        sb.append(header);
72579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        sb.append("catch ");
73579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
74579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        for (int i = 0; i < size; i++) {
75579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            Entry entry = get(i);
76579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
77579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            if (i != 0) {
78579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson                sb.append(",\n");
79579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson                sb.append(prefix);
80579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson                sb.append("  ");
81579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            }
82579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
83579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            if ((i == (size - 1)) && catchesAll()) {
84579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson                sb.append("<any>");
85579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            } else {
86579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson                sb.append(entry.getExceptionType().toHuman());
87579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            }
88579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
89579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            sb.append(" -> ");
90579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            sb.append(Hex.u2or4(entry.getHandler()));
91579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        }
92579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
93579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        return sb.toString();
94579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    }
95579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
96579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    /**
97579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * Returns whether or not this instance ends with a "catch-all"
98579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * handler.
99579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     *
100579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * @return {@code true} if this instance ends with a "catch-all"
101579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * handler or {@code false} if not
102579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     */
103579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    public boolean catchesAll() {
104579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        int size = size();
105579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
106579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        if (size == 0) {
107579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            return false;
108579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        }
109579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
110579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        Entry last = get(size - 1);
111579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        return last.getExceptionType().equals(CstType.OBJECT);
112579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    }
113579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
114579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    /**
115579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * Sets the entry at the given index.
116579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     *
117579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * @param n {@code >= 0, < size();} which index
118579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * @param exceptionType {@code non-null;} type of exception handled
119579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * @param handler {@code >= 0;} exception handler address
120579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     */
121579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    public void set(int n, CstType exceptionType, int handler) {
122579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        set0(n, new Entry(exceptionType, handler));
123579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    }
124579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
125579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    /**
126579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * Sets the entry at the given index.
127579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     *
128579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * @param n {@code >= 0, < size();} which index
129579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * @param entry {@code non-null;} the entry to set at {@code n}
130579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     */
131579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    public void set(int n, Entry entry) {
132579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        set0(n, entry);
133579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    }
134579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
135579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    /** {@inheritDoc} */
136579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    public int compareTo(CatchHandlerList other) {
137579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        if (this == other) {
138579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            // Easy out.
139579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            return 0;
140579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        }
141579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
142579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        int thisSize = size();
143579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        int otherSize = other.size();
144579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        int checkSize = Math.min(thisSize, otherSize);
145579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
146579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        for (int i = 0; i < checkSize; i++) {
147579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            Entry thisEntry = get(i);
148579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            Entry otherEntry = other.get(i);
149579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            int compare = thisEntry.compareTo(otherEntry);
150579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            if (compare != 0) {
151579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson                return compare;
152579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            }
153579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        }
154579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
155579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        if (thisSize < otherSize) {
156579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            return -1;
157579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        } else if (thisSize > otherSize) {
158579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            return 1;
159579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        }
160579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
161579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        return 0;
162579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    }
163579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
164579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    /**
165579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     * Entry in the list.
166579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson     */
167579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    public static class Entry implements Comparable<Entry> {
168579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        /** {@code non-null;} type of exception handled */
169579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        private final CstType exceptionType;
170579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
171579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        /** {@code >= 0;} exception handler address */
172579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        private final int handler;
173579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
174579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        /**
175579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson         * Constructs an instance.
176579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson         *
177579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson         * @param exceptionType {@code non-null;} type of exception handled
178579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson         * @param handler {@code >= 0;} exception handler address
179579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson         */
180579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        public Entry(CstType exceptionType, int handler) {
181579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            if (handler < 0) {
182579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson                throw new IllegalArgumentException("handler < 0");
183579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            }
184579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
185579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            if (exceptionType == null) {
186579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson                throw new NullPointerException("exceptionType == null");
187579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            }
188579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
189579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            this.handler = handler;
190579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            this.exceptionType = exceptionType;
191579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        }
192579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
193579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        /** {@inheritDoc} */
194579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        @Override
195579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        public int hashCode() {
196579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            return (handler * 31) + exceptionType.hashCode();
197579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        }
198579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
199579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        /** {@inheritDoc} */
200579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        @Override
201579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        public boolean equals(Object other) {
202579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            if (other instanceof Entry) {
203579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson                return (compareTo((Entry) other) == 0);
204579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            }
205579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
206579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            return false;
207579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        }
208579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
209579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        /** {@inheritDoc} */
210579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        public int compareTo(Entry other) {
211579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            if (handler < other.handler) {
212579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson                return -1;
213579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            } else if (handler > other.handler) {
214579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson                return 1;
215579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            }
216579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
217579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            return exceptionType.compareTo(other.exceptionType);
218579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        }
219579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
220579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        /**
221579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson         * Gets the exception type handled.
222579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson         *
223579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson         * @return {@code non-null;} the exception type
224579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson         */
225579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        public CstType getExceptionType() {
226579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            return exceptionType;
227579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        }
228579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson
229579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        /**
230579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson         * Gets the handler address.
231579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson         *
232579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson         * @return {@code >= 0;} the handler address
233579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson         */
234579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        public int getHandler() {
235579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson            return handler;
236579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson        }
237579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson    }
238579d7739c53a2707ad711a2d2cae46d7d782f06Jesse Wilson}
239