OW_Stack.hpp

Go to the documentation of this file.
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

Generated on Thu Feb 9 08:48:16 2006 for openwbem by  doxygen 1.4.6