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_*/