X-Git-Url: http://git.indexdata.com/?p=idzebra-moved-to-github.git;a=blobdiff_plain;f=bfile%2Fcfile.h;h=a658987fc667fe69b18e90cbc425e519e9ea7d45;hp=43d69a96ac1fb7ca7e7617f2e8231f1c0d32a978;hb=HEAD;hpb=896c0427df9d8eff5de6a1735dcd992e067df844 diff --git a/bfile/cfile.h b/bfile/cfile.h index 43d69a9..a658987 100644 --- a/bfile/cfile.h +++ b/bfile/cfile.h @@ -1,8 +1,5 @@ -/* $Id: cfile.h,v 1.14 2002-08-02 19:26:55 adam Exp $ - Copyright (C) 1995,1996,1997,1998,1999,2000,2001,2002 - Index Data Aps - -This file is part of the Zebra server. +/* This file is part of the Zebra server. + Copyright (C) Index Data Zebra 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 @@ -15,9 +12,9 @@ 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 Zebra; see the file LICENSE.zebra. If not, write to the -Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA -02111-1307, USA. +along with this program; if not, write to the Free Software +Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ @@ -29,15 +26,18 @@ Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA YAZ_BEGIN_CDECL +/** \brief number of blocks in hash bucket */ #define HASH_BUCKET 15 -struct CFile_ph_bucket { /* structure on disc */ - int no[HASH_BUCKET]; /* block number in original file */ - int vno[HASH_BUCKET]; /* block number in shadow file */ - int this_bucket; /* this bucket number */ - int next_bucket; /* next bucket number */ +/** \brief CFile hash structure on disc */ +struct CFile_ph_bucket { + zint no[HASH_BUCKET]; /**< block number in original file */ + zint vno[HASH_BUCKET];/**< block number in shadow file */ + zint this_bucket; /**< this bucket number */ + zint next_bucket; /**< next bucket number */ }; +/** \brief CFile hash structure info in memory */ struct CFile_hash_bucket { struct CFile_ph_bucket ph; int dirty; @@ -47,42 +47,61 @@ struct CFile_hash_bucket { #define HASH_BSIZE sizeof(struct CFile_ph_bucket) -#define CFILE_FLAT 1 +/** \brief state of CFile is a hash structure */ +#define CFILE_STATE_HASH 1 + +/** \brief state of CFile is a flat file file */ +#define CFILE_STATE_FLAT 2 + +/** \brief CFile file header */ +struct CFile_head { + int state; /**< CFILE_STATE_HASH, CFILE_STATE_FLAT, .. */ + zint next_block; /**< next free block / last block */ + int block_size; /**< mfile/bfile block size */ + int hash_size; /**< no of chains in hash table */ + zint first_bucket; /**< first hash bucket */ + zint next_bucket; /**< last hash bucket + 1 = first flat bucket */ + zint flat_bucket; /**< last flat bucket + 1 */ +}; +/** \brief All in-memory information per CFile */ typedef struct CFile_struct { - struct CFile_head { - int state; /* 1 = hash, 2 = flat */ - int next_block; /* next free block / last block */ - int block_size; /* mfile/bfile block size */ - int hash_size; /* no of chains in hash table */ - int first_bucket; /* first hash bucket */ - int next_bucket; /* last hash bucket + 1 = first flat bucket */ - int flat_bucket; /* last flat bucket + 1 */ - } head; - MFile block_mf; - MFile hash_mf; - int *array; - struct CFile_hash_bucket **parray; - struct CFile_hash_bucket *bucket_lru_front, *bucket_lru_back; - int dirty; - int bucket_in_memory; - int max_bucket_in_memory; - char *iobuf; - MFile rmf; - int no_hits; - int no_miss; + struct CFile_head head; + + MFile block_mf; /**< block meta file */ + MFile hash_mf; /**< hash or index file (depending on state) */ + zint *array; /**< array for hash */ + struct CFile_hash_bucket **parray; /**< holds all hash bucket in memory */ + struct CFile_hash_bucket *bucket_lru_front; /**< LRU front for hash */ + struct CFile_hash_bucket *bucket_lru_back; /**< LRU back for hash */ + int dirty; /**< whether CFile is dirty / header must be rewritten */ + zint bucket_in_memory; /**< number of buckets in memory */ + zint max_bucket_in_memory; /**< max number of buckets in memory */ + char *iobuf; /**< data block .. of size block size */ + MFile rmf; /**< read meta file (original data / not dirty) */ + int no_hits; /**< number of bucket cache hits */ + int no_miss; /**< number of bucket cache misses */ Zebra_mutex mutex; } *CFile; int cf_close (CFile cf); + CFile cf_open (MFile mf, MFile_area area, const char *fname, int block_size, int wflag, int *firstp); -int cf_read (CFile cf, int no, int offset, int nbytes, void *buf); -int cf_write (CFile cf, int no, int offset, int nbytes, const void *buf); -void cf_unlink (CFile cf); -void cf_commit (CFile cf); +int cf_read (CFile cf, zint no, int offset, int nbytes, void *buf); +int cf_write (CFile cf, zint no, int offset, int nbytes, const void *buf); +int cf_commit (CFile cf) ZEBRA_GCC_ATTR((warn_unused_result)); YAZ_END_CDECL #endif +/* + * Local variables: + * c-basic-offset: 4 + * c-file-style: "Stroustrup" + * indent-tabs-mode: nil + * End: + * vim: shiftwidth=4 tabstop=8 expandtab + */ +