2 * Copyright (C) 1994-1999, Index Data
4 * Sebastian Hammer, Adam Dickmeiss
7 * Revision 1.14 1999-02-02 14:50:34 adam
8 * Updated WIN32 code specific sections. Changed header.
10 * Revision 1.13 1997/09/17 12:19:09 adam
11 * Zebra version corresponds to YAZ version 1.4.
12 * Changed Zebra server so that it doesn't depend on global common_resource.
14 * Revision 1.12 1997/09/05 15:30:00 adam
15 * Changed prototype for chr_map_input - added const.
16 * Added support for C++, headers uses extern "C" for public definitions.
18 * Revision 1.11 1996/10/29 13:43:44 adam
19 * Removed definition of SYSNO.
21 * Revision 1.10 1995/09/06 16:10:57 adam
22 * More work on boolean sets.
24 * Revision 1.9 1994/09/28 16:58:26 quinn
27 * Revision 1.8 1994/09/28 12:56:09 quinn
28 * Added access functions (ISPT)
30 * Revision 1.7 1994/09/28 11:56:13 quinn
31 * Removed const from input to is_merge
33 * Revision 1.6 1994/09/28 11:29:28 quinn
34 * Added cmp parameter.
36 * Revision 1.5 1994/09/27 20:03:36 quinn
37 * Seems relatively bug-free.
39 * Revision 1.4 1994/09/26 17:05:54 quinn
42 * Revision 1.3 1994/09/26 16:08:42 quinn
43 * Most of the functionality in place.
45 * Revision 1.2 1994/09/14 13:10:35 quinn
48 * Revision 1.1 1994/09/12 08:02:07 quinn
59 #include "../isam/memory.h"
60 #include "../isam/physical.h"
66 #define IS_MAX_BLOCKTYPES 4
67 #define IS_MAX_RECORD 512
68 #define IS_DEF_REPACK_PERCENT "30" /* how much relative change before repack */
71 * Description of a blocktype (part of an isam file)
73 typedef struct isam_blocktype
75 BFile bf; /* blocked file */
77 int first_block; /* position of first data block */
78 int max_keys_block; /* max num of keys per block */
79 int max_keys_block0; /* max num of keys in first block */
80 int nice_keys_block; /* nice number of keys per block */
81 int max_keys; /* max number of keys per table */
82 int freelist; /* first free block */
83 int top; /* first unused block */
84 int index; /* placeholder. Always 0. */
85 char *dbuf; /* buffer for use in I/O operations */
89 * Handle to an open isam complex.
91 typedef struct isam_struct
93 isam_blocktype types[IS_MAX_BLOCKTYPES]; /* block_types used in this file */
94 int num_types; /* number of block types used */
96 int keysize; /* size of the keys (records) used */
97 int repack; /* how many percent to grow before repack */
98 int (*cmp)(const void *k1, const void *k2); /* compare function */
101 typedef struct ispt_struct
103 struct is_mtable tab;
104 struct ispt_struct *next; /* freelist */
105 } ispt_struct, *ISPT;
107 #define is_type(x) ((x) & 3) /* type part of position */
108 #define is_block(x) ((x) >> 2) /* block # part of position */
110 #define is_keysize(is) ((is)->keysize)
114 *******************************************************************
120 ISAM is_open(BFiles bfs, const char *name,
121 int (*cmp)(const void *p1, const void *p2),
122 int writeflag, int keysize, Res res);
127 int is_close(ISAM is);
130 * Locate a table of keys in an isam file. The ISPT is an individual
131 * position marker for that table.
133 ISPT is_position(ISAM is, ISAM_P pos);
138 void is_pt_free(ISPT ip);
141 * Read a key from a table.
143 int is_readkey(ISPT ip, void *buf);
145 int is_writekey(ISPT ip, const void *buf);
147 int is_numkeys(ISPT ip);
149 void is_rewind(ISPT ip);
151 ISAM_P is_merge(ISAM is, ISAM_P pos, int num, char *data);