/* $Id$ This file is part of Swish-e. Swish-e is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. Swish-e 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 General Public License for more details. You should have received a copy of the GNU General Public License along with Swish-e; if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA See the COPYING file that accompanies the Swish-e distribution for details of the GNU GPL and the special exception available for linking against the Swish-e library. ** Mon May 9 18:19:34 CDT 2005 ** added GPL */ typedef struct ARRAY_Page { sw_off_t next; /* Next Page */ sw_off_t page_number; int modified; int in_use; struct ARRAY_Page *next_cache; /* unsigned char data[0]; */ /* Page data */ unsigned char * data; /* ISO C forbids zero-size array 'data' */ } ARRAY_Page; #define ARRAY_CACHE_SIZE 97 typedef struct ARRAY { sw_off_t root_page; int page_size; struct ARRAY_Page *cache[ARRAY_CACHE_SIZE]; int levels; FILE *fp; } ARRAY; ARRAY *ARRAY_Create(FILE *fp); ARRAY *ARRAY_Open(FILE *fp, sw_off_t root_page); sw_off_t ARRAY_Close(ARRAY *bt); int ARRAY_Put(ARRAY *b, int index, SWUINT_T value); SWUINT_T ARRAY_Get(ARRAY *b, int index);