com.google.gwt.emul.java.util.Stack Maven / Gradle / Ivy
/*
* 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. [Sun
* docs]
*
* @param element type.
*/
public class Stack extends Vector {
@Override
public Object clone() {
Stack s = new Stack();
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;
}
}