// -*- C++ -*- /*************************************************************************** * * - definition of the C++ Standard Library stack class template * * $Id$ * *************************************************************************** * * Copyright (c) 1994 * Hewlett-Packard Company * * Permission to use, copy, modify, distribute and sell this software * and its documentation for any purpose is hereby granted without fee, * provided that the above copyright notice appear in all copies and * that both that copyright notice and this permission notice appear * in supporting documentation. Hewlett-Packard Company makes no * representations about the suitability of this software for any * purpose. It is provided "as is" without express or implied warranty. * *************************************************************************** * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed * with this work for additional information regarding copyright * ownership. The ASF licenses this file to you 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. * * Copyright 1994-2006 Rogue Wave Software. * **************************************************************************/ #ifndef _RWSTD_STACK_INCLUDED #define _RWSTD_STACK_INCLUDED #include #include _RWSTD_NAMESPACE (std) { template > class stack; template inline bool operator==(const stack<_TypeT, _Container>&, const stack<_TypeT, _Container>&); template inline bool operator<(const stack<_TypeT, _Container>&, const stack<_TypeT, _Container>&); template class stack { friend bool _RWSTD_SPECIALIZED_FRIEND (operator==) (const stack&, const stack&); friend bool _RWSTD_SPECIALIZED_FRIEND (operator<) (const stack&, const stack&); public: typedef _Container container_type; typedef typename container_type::value_type value_type; typedef typename container_type::size_type size_type; // lwg issue 307: additional typedefs typedef typename container_type::reference reference; typedef typename container_type::const_reference const_reference; protected: container_type c; public: explicit stack (const container_type &__c = container_type ()) : c (__c) { } bool empty () const { return c.empty (); } size_type size () const { return c.size (); } reference top () { return c.back (); } const_reference top () const { return c.back (); } void push (const value_type &__x) { c.push_back (__x); } void pop () { c.pop_back (); } }; template inline bool operator== (const stack<_TypeT, _Container> &__x, const stack<_TypeT, _Container> &__y) { return __x.c == __y.c; } template inline bool operator< (const stack<_TypeT, _Container> &__x, const stack<_TypeT, _Container> &__y) { return __x.c < __y.c; } template inline bool operator!= (const stack<_TypeT, _Container> &__x, const stack<_TypeT, _Container> &__y) { return !(__x == __y); } template inline bool operator> (const stack<_TypeT, _Container> &__x, const stack<_TypeT, _Container> &__y) { return __y < __x; } template inline bool operator>= (const stack<_TypeT, _Container> &__x, const stack<_TypeT, _Container> &__y) { return !(__x < __y); } template inline bool operator<= (const stack<_TypeT, _Container> &__x, const stack<_TypeT, _Container> &__y) { return !(__y < __x); } } // namespace std #endif // _RWSTD_STACK_INCLUDED