/Users/maurits/Documents/studie/afstuderen/biosphere/common/stack.h

Go to the documentation of this file.
00001 /*
00002  * Author: MA Hartman
00003  * Date: feb 28, 2007
00004  * 
00005  * Function:
00006  * A general purpose stack implementation.
00007  * 
00008  * License information:
00009  * 
00010  * Copyright (c) 2006 Maurits Hartman
00011  *
00012  * Permission is hereby granted, free of charge, to any person
00013  * obtaining a copy of this software and associated documentation
00014  * files (the "Software"), to deal in the Software without
00015  * restriction, including without limitation the rights to use,
00016  * copy, modify, merge, publish, distribute, sublicense, and/or sell
00017  * copies of the Software, and to permit persons to whom the
00018  * Software is furnished to do so, subject to the following
00019  * conditions:
00020  * 
00021  * The above copyright notice and this permission notice shall be
00022  * included in all copies or substantial portions of the Software.
00023  * 
00024  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
00025  * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
00026  * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
00027  * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
00028  * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
00029  * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
00030  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
00031  * OTHER DEALINGS IN THE SOFTWARE.
00032  * 
00033  */
00034 
00035 #ifndef STACK_H
00036 #define STACK_H
00037 
00038 #include <apr_pools.h>
00039 
00040 typedef struct bs_stack
00041 {
00042     unsigned    size, allocated;
00043     apr_pool_t  *pool;
00044     void                **data;
00045 } bs_stack;
00046 
00052 bs_stack *new_stack(apr_pool_t *mp);
00053 
00058 void delete_stack(bs_stack *stack);
00059 
00063 void stack_push(bs_stack *stack, void *data);
00064 
00070 void *stack_pop(bs_stack *stack);
00071 
00077 void *stack_top(const bs_stack *stack);
00078 
00084 int stack_empty(const bs_stack *stack);
00085 
00092 void *stack_index(const bs_stack *stack, unsigned index);
00093 
00099 inline unsigned stack_size(const bs_stack *stack);
00100 
00101 #endif /*STACK_H_*/

Generated on Tue Jul 17 09:50:52 2007 for Bio-SPHERE by  doxygen 1.5.1