File:  [parser3project] / parser3 / src / include / pa_stack.h
Revision 1.7: download - view: text, annotated - select for diffs - revision graph
Mon Mar 19 15:29:38 2001 UTC (25 years, 3 months ago) by paf
Branches: MAIN
CVS tags: HEAD
doxygen include/, Value

/** @file
	Parser
	Copyright (c) 2001 ArtLebedev Group (http://www.artlebedev.com)
	Author: Alexander Petrosyan <paf@design.ru> (http://design.ru/paf)

	$Id: pa_stack.h,v 1.7 2001/03/19 15:29:38 paf Exp $
*/

#ifndef PA_STACK_H
#define PA_STACK_H

#include "pa_array.h"

/// simple stack based on Array
class Stack : public Array {
public:

	Stack(Pool& apool) : Array(apool), ftop(0) {
	}

	void push(Item *item) {
		if(ftop<size()) // cell is already allocated?
			put(ftop, item); // use it
		else
			*this+=item; // append it
		ftop++;
	}
	Item *pop() {
		return get(--ftop);
	}

	int top_index() { return ftop-1; }
	Item *top_value() { return get(top_index()); }

private:

	// deepest used index
	int ftop;

};

#endif

E-mail: