datafiles.h

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