| /* |
| * Copyright 2007 Google Inc. |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); you may not |
| * use this file except in compliance with the License. You may obtain a copy of |
| * the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT |
| * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the |
| * License for the specific language governing permissions and limitations under |
| * the License. |
| */ |
| package java.util; |
| |
| /** |
| * Maintains a last-in, first-out collection of objects. <a |
| * href="http://java.sun.com/j2se/1.5.0/docs/api/java/util/Stack.html">[Sun |
| * docs]</a> |
| * |
| * @param <E> element type. |
| */ |
| public class Stack<E> extends Vector<E> { |
| |
| @Override |
| public Object clone() { |
| Stack<E> s = new Stack<E>(); |
| s.addAll(this); |
| return s; |
| } |
| |
| public boolean empty() { |
| return isEmpty(); |
| } |
| |
| public E peek() { |
| int sz = size(); |
| if (sz > 0) { |
| return get(sz - 1); |
| } else { |
| throw new EmptyStackException(); |
| } |
| } |
| |
| public E pop() { |
| int sz = size(); |
| if (sz > 0) { |
| return remove(sz - 1); |
| } else { |
| throw new EmptyStackException(); |
| } |
| } |
| |
| public E push(E o) { |
| add(o); |
| return o; |
| } |
| |
| public int search(Object o) { |
| int pos = lastIndexOf(o); |
| if (pos >= 0) { |
| return size() - pos; |
| } |
| return -1; |
| } |
| |
| } |