1282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski/*
2282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski * Copyright (C) 2010 The Android Open Source Project
3282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski *
4282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski * Licensed under the Apache License, Version 2.0 (the "License");
5282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski * you may not use this file except in compliance with the License.
6282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski * You may obtain a copy of the License at
7282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski *
8282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski *      http://www.apache.org/licenses/LICENSE-2.0
9282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski *
10282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski * Unless required by applicable law or agreed to in writing, software
11282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski * distributed under the License is distributed on an "AS IS" BASIS,
12282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski * See the License for the specific language governing permissions and
14282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski * limitations under the License.
15282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski */
16282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski
17282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinskipackage com.android.layoutlib.bridge.impl;
18282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski
19282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinskiimport java.util.ArrayList;
20282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski
21282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski/**
22282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski * Custom Stack implementation on top of an {@link ArrayList} instead of
23282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski * using {@link java.util.Stack} which is on top of a vector.
24282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski *
25282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski * @param <T>
26282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski */
27282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinskipublic class Stack<T> extends ArrayList<T> {
28282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski
29282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski    private static final long serialVersionUID = 1L;
30282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski
31282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski    public Stack() {
32282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski        super();
33282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski    }
34282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski
35282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski    public Stack(int size) {
36282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski        super(size);
37282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski    }
38282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski
39282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski    /**
40282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski     * Pushes the given object to the stack
41282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski     * @param object the object to push
42282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski     */
43282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski    public void push(T object) {
44282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski        add(object);
45282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski    }
46282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski
47282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski    /**
48282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski     * Remove the object at the top of the stack and returns it.
49282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski     * @return the removed object or null if the stack was empty.
50282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski     */
51282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski    public T pop() {
52282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski        if (size() > 0) {
53282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski            return remove(size() - 1);
54282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski        }
55282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski
56282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski        return null;
57282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski    }
58282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski
59282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski    /**
60282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski     * Returns the object at the top of the stack.
61282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski     * @return the object at the top or null if the stack is empty.
62282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski     */
63282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski    public T peek() {
64282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski        if (size() > 0) {
65282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski            return get(size() - 1);
66282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski        }
67282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski
68282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski        return null;
69282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski    }
70282e181b58cf72b6ca770dc7ca5f91f135444502Adam Lesinski}
71