datafiles.h

Go to the documentation of this file.
00001 /* Database file descriptor structure and file handling routine prototypes.
00002  *
00003  * (C) 2003-2007 Anope Team
00004  * Contact us at info@anope.org
00005  *
00006  * Please read COPYING and README for furhter details.
00007  *
00008  * Based on the original code of Epona by Lara.
00009  * Based on the original code of Services by Andy Church. 
00010  * 
00011  * $Id: datafiles.h 1265 2007-08-26 15:33:06Z geniusdex $ 
00012  *
00013  */
00014 
00015 #ifndef DATAFILES_H
00016 #define DATAFILES_H
00017 
00018 #ifndef _WIN32
00019 #include <sys/param.h>
00020 #endif
00021 
00022 /*************************************************************************/
00023 
00024 typedef struct dbFILE_ dbFILE;
00025 struct dbFILE_ {
00026     int mode;           /* 'r' for reading, 'w' for writing */
00027     FILE *fp;           /* The normal file descriptor */
00028     FILE *backupfp;     /* Open file pointer to a backup copy of
00029                  *    the database file (if non-NULL) */
00030     char filename[MAXPATHLEN];  /* Name of the database file */
00031     char backupname[MAXPATHLEN];    /* Name of the backup file */
00032 };
00033 
00034 /*************************************************************************/
00035 
00036 /* Prototypes and macros: */
00037 
00038 E void check_file_version(dbFILE *f);
00039 E int get_file_version(dbFILE *f);
00040 E int write_file_version(dbFILE *f, uint32 version);
00041 
00042 E dbFILE *open_db(const char *service, const char *filename, const char *mode, uint32 version);
00043 E void restore_db(dbFILE *f);   /* Restore to state before open_db() */
00044 E void close_db(dbFILE *f);
00045 E void backup_databases(void); 
00046 
00047 #define read_db(f,buf,len)  (fread((buf),1,(len),(f)->fp))
00048 #define write_db(f,buf,len) (fwrite((buf),1,(len),(f)->fp))
00049 #define getc_db(f)      (fgetc((f)->fp))
00050 
00051 E int read_int16(uint16 *ret, dbFILE *f);
00052 E int write_int16(uint16 val, dbFILE *f);
00053 E int read_int32(uint32 *ret, dbFILE *f);
00054 E int write_int32(uint32 val, dbFILE *f);
00055 E int read_ptr(void **ret, dbFILE *f);
00056 E int write_ptr(const void *ptr, dbFILE *f);
00057 E int read_string(char **ret, dbFILE *f);
00058 E int write_string(const char *s, dbFILE *f);
00059 
00060 #define read_int8(ret,f)    ((*(ret)=fgetc((f)->fp))==EOF ? -1 : 0)
00061 #define write_int8(val,f)   (fputc((val),(f)->fp)==EOF ? -1 : 0)
00062 #define read_buffer(buf,f)  (read_db((f),(buf),sizeof(buf)) == sizeof(buf))
00063 #define write_buffer(buf,f) (write_db((f),(buf),sizeof(buf)) == sizeof(buf))
00064 #define read_buflen(buf,len,f)  (read_db((f),(buf),(len)) == (len))
00065 #define write_buflen(buf,len,f) (write_db((f),(buf),(len)) == (len))
00066 #define read_variable(var,f)    (read_db((f),&(var),sizeof(var)) == sizeof(var))
00067 #define write_variable(var,f)   (write_db((f),&(var),sizeof(var)) == sizeof(var))
00068 
00069 /*************************************************************************/
00070 
00071 #endif  /* DATAFILES_H */

Generated on Sun Dec 30 09:26:45 2007 for Anope by  doxygen 1.5.1-20070107