00001 /******************************************************************************* 00002 * Copyright (C) 2003-2004 Vintela, Inc. All rights reserved. 00003 * 00004 * Redistribution and use in source and binary forms, with or without 00005 * modification, are permitted provided that the following conditions are met: 00006 * 00007 * - Redistributions of source code must retain the above copyright notice, 00008 * this list of conditions and the following disclaimer. 00009 * 00010 * - Redistributions in binary form must reproduce the above copyright notice, 00011 * this list of conditions and the following disclaimer in the documentation 00012 * and/or other materials provided with the distribution. 00013 * 00014 * - Neither the name of Vintela, Inc. nor the names of its 00015 * contributors may be used to endorse or promote products derived from this 00016 * software without specific prior written permission. 00017 * 00018 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ``AS IS'' 00019 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00020 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00021 * ARE DISCLAIMED. IN NO EVENT SHALL Vintela, Inc. OR THE CONTRIBUTORS 00022 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 00023 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 00024 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 00025 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 00026 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 00027 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00028 * POSSIBILITY OF SUCH DAMAGE. 00029 *******************************************************************************/ 00030 00036 #ifndef OW_STACK_HPP_INCLUDE_GUARD_ 00037 #define OW_STACK_HPP_INCLUDE_GUARD_ 00038 #include "OW_config.h" 00039 #include "OW_Types.hpp" 00040 #include "OW_Array.hpp" 00041 00042 namespace OW_NAMESPACE 00043 { 00044 00045 template<class T> 00046 class Stack : private Array<T> 00047 { 00048 public: 00049 typedef typename Array<T>::size_type size_type; 00050 typedef typename Array<T>::reference reference; 00051 typedef typename Array<T>::const_reference const_reference; 00052 Stack() : Array<T>() { } 00053 bool empty() const { return (size() == 0); } 00054 reference top() { return this->back(); } 00055 const_reference top() const { return this->back(); } 00056 void pop() { this->pop_back(); } 00057 void push(const T& x) { push_back(x); } 00058 int search(const T& x) const 00059 { 00060 int i = find(x); 00061 return (i >= 0) ? static_cast<int>(size()) - i : -1; 00062 } 00063 size_type size() const 00064 { 00065 return Array<T>::size(); 00066 } 00067 }; 00068 00069 } // end namespace OW_NAMESPACE 00070 00071 #endif