Newer
Older
/**
* @file lldepthstack.h
* @brief Declaration of the LLDepthStack class
*
* $LicenseInfo:firstyear=2001&license=viewerlgpl$
* Copyright (C) 2010, Linden Research, Inc.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation;
* version 2.1 of the License only.
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
* Linden Research, Inc., 945 Battery Street, San Francisco, CA 94111 USA
*/
#ifndef LL_LLDEPTHSTACK_H
#define LL_LLDEPTHSTACK_H
Richard Linden
committed
#include "llstl.h"
template <class DATA_TYPE> class LLDepthStack
{
private:
Richard Linden
committed
std::deque<DATA_TYPE*> mStack;
Richard Linden
committed
LLDepthStack()
: mCurrentDepth(0), mMaxDepth(0)
{}
void setDepth(U32 depth)
{
mMaxDepth = depth;
}
U32 getDepth(void) const
{
return mCurrentDepth;
}
void push(DATA_TYPE *data)
{
if (mCurrentDepth < mMaxDepth)
{
Richard Linden
committed
mStack.push_back(data);
mCurrentDepth++;
}
else
{
// the last item falls off stack and is deleted
Richard Linden
committed
if (!mStack.empty())
{
mStack.pop_front();
}
mStack.push_back(data);
Richard Linden
committed
DATA_TYPE *tempp = NULL;
if (!mStack.empty())
Richard Linden
committed
tempp = mStack.back();
mStack.pop_back();
mCurrentDepth--;
}
return tempp;
}
DATA_TYPE *check()
{
Richard Linden
committed
return mStack.empty() ? NULL : mStack.back();
Richard Linden
committed
Richard Linden
committed
mStack.clear();