This repository has been archived on 2024-12-16. You can view files and clone it, but cannot push or open issues or pull requests.
CodeBlocksPortable/WATCOM/h/wcstack.h

86 lines
2 KiB
C
Raw Permalink Normal View History

//
// wcstack.h Defines the WATCOM Stack Container Class
//
// =========================================================================
//
// Open Watcom Project
//
// Copyright (c) 2002-2010 Open Watcom Contributors. All Rights Reserved.
// Portions Copyright (c) 1983-2002 Sybase, Inc. All Rights Reserved.
//
// This file is automatically generated. Do not edit directly.
//
// =========================================================================
//
#ifndef _WCSTACK_H_INCLUDED
#define _WCSTACK_H_INCLUDED
#ifndef _ENABLE_AUTODEPEND
#pragma read_only_file;
#endif
#ifndef __cplusplus
#error This header file requires C++
#endif
#ifndef _WCDEFS_H_INCLUDED
#include <wcdefs.h>
#endif
#ifndef _WCLIST_H_INCLUDED
#include <wclist.h>
#endif
//
// The WCStack template class defines a stack. The template supplies
// the type of the data maintained in the stack, and the methods for
// manipulating the stack.
//
// The class 'Type' should be properly defined for copy and assignment
// operations.
//
template<class Type, class FType>
class WCStack : private FType {
public:
inline WCStack() {};
inline WCStack( void * (*user_alloc)( size_t )
, void (*user_dealloc)( void *, size_t )
) : FType( user_alloc, user_dealloc ) {};
inline ~WCStack() {};
inline WCbool push( const Type & data ) {
return( FType::insert( data ) );
};
inline Type pop() {
return( FType::get() );
};
inline Type top() const {
return( FType::find( 0 ) );
};
inline WCbool isEmpty() const {
return( FType::isEmpty() );
};
inline int entries() const {
return( FType::entries() );
};
inline void clear() {
FType::clear();
};
inline wc_state exceptions() const {
return( FType::exceptions() );
};
inline wc_state exceptions( wc_state const set_flags ) {
return( FType::exceptions( set_flags ) );
};
};
#endif