2001-01-25 10:37:55 +01:00
|
|
|
/* vi: set ts=2:
|
|
|
|
*
|
2001-04-14 13:39:14 +02:00
|
|
|
*
|
2003-07-29 11:48:03 +02:00
|
|
|
* Eressea PB(E)M host Copyright (C) 1998-2003
|
2001-01-25 10:37:55 +01:00
|
|
|
* Christian Schlittchen (corwin@amber.kn-bremen.de)
|
|
|
|
* Katja Zedel (katze@felidae.kn-bremen.de)
|
|
|
|
* Henning Peters (faroul@beyond.kn-bremen.de)
|
|
|
|
* Enno Rehling (enno@eressea-pbem.de)
|
|
|
|
* Ingo Wilken (Ingo.Wilken@informatik.uni-oldenburg.de)
|
|
|
|
*
|
|
|
|
* This program may not be used, modified or distributed without
|
|
|
|
* prior permission by the authors of Eressea.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef ATTRIB_H
|
|
|
|
#define ATTRIB_H
|
2003-07-29 11:48:03 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
2001-01-25 10:37:55 +01:00
|
|
|
|
|
|
|
typedef void (*afun)(void);
|
|
|
|
|
|
|
|
typedef struct attrib {
|
|
|
|
const struct attrib_type * type;
|
|
|
|
union {
|
|
|
|
afun f;
|
|
|
|
void * v;
|
|
|
|
int i;
|
2002-01-01 21:51:18 +01:00
|
|
|
float flt;
|
2001-01-25 10:37:55 +01:00
|
|
|
char c;
|
|
|
|
short s;
|
|
|
|
short sa[2];
|
|
|
|
char ca[4];
|
|
|
|
} data;
|
|
|
|
/* internal data, do not modify: */
|
2003-07-29 11:48:03 +02:00
|
|
|
struct attrib * next; /* next attribute in the list */
|
|
|
|
struct attrib * nexttype; /* next attribute of same type */
|
2001-01-25 10:37:55 +01:00
|
|
|
} attrib;
|
|
|
|
|
|
|
|
#define ATF_UNIQUE (1<<0) /* only one per attribute-list */
|
|
|
|
#define ATF_PRESERVE (1<<1) /* preserve order in list. append to back */
|
|
|
|
#define ATF_USER_DEFINED (1<<2) /* use this to make udf */
|
|
|
|
|
|
|
|
typedef struct attrib_type {
|
|
|
|
const char* name;
|
|
|
|
void (*initialize)(struct attrib *);
|
|
|
|
void (*finalize)(struct attrib *);
|
|
|
|
int (*age)(struct attrib *);
|
|
|
|
/* age returns 0 if the attribute needs to be removed, !=0 otherwise */
|
|
|
|
void (*write)(const struct attrib *, FILE*);
|
2003-07-29 11:48:03 +02:00
|
|
|
int (*read)(struct attrib *, FILE*); /* return AT_READ_OK on success, AT_READ_FAIL if attrib needs removal */
|
2001-01-25 10:37:55 +01:00
|
|
|
unsigned int flags;
|
|
|
|
/* ---- internal data, do not modify: ---- */
|
|
|
|
struct attrib_type * nexthash;
|
|
|
|
unsigned int hashkey;
|
|
|
|
} attrib_type;
|
|
|
|
|
|
|
|
extern int a_readdefault(attrib * a, FILE * f);
|
|
|
|
extern void a_writedefault(const attrib * a, FILE * f);
|
|
|
|
|
|
|
|
extern int a_readstring(attrib * a, FILE * f);
|
|
|
|
extern void a_writestring(const attrib * a, FILE * f);
|
|
|
|
extern void a_finalizestring(attrib * a);
|
|
|
|
|
|
|
|
extern void at_register(attrib_type * at);
|
|
|
|
|
2001-12-10 01:13:39 +01:00
|
|
|
extern attrib * a_select(attrib * a, const void * data, boolean(*compare)(const attrib *, const void *));
|
2001-01-25 10:37:55 +01:00
|
|
|
extern attrib * a_find(attrib * a, const attrib_type * at);
|
2003-07-29 11:48:03 +02:00
|
|
|
extern const attrib * a_findc(const attrib * a, const attrib_type * at);
|
2001-01-25 10:37:55 +01:00
|
|
|
extern attrib * a_add(attrib ** pa, attrib * at);
|
|
|
|
extern int a_remove(attrib ** pa, attrib * at);
|
|
|
|
extern void a_removeall(attrib ** a, const attrib_type * at);
|
|
|
|
extern attrib * a_new(const attrib_type * at);
|
|
|
|
extern void a_free(attrib * a);
|
|
|
|
|
|
|
|
extern int a_age(attrib ** attribs);
|
2006-02-05 16:48:52 +01:00
|
|
|
extern int a_read(FILE * f, attrib ** attribs);
|
2001-01-25 10:37:55 +01:00
|
|
|
extern void a_write(FILE * f, const attrib * attribs);
|
|
|
|
|
|
|
|
#define DEFAULT_AGE NULL
|
|
|
|
#define DEFAULT_INIT NULL
|
|
|
|
#define DEFAULT_FINALIZE NULL
|
|
|
|
#define DEFAULT_WRITE a_writedefault
|
|
|
|
#define DEFAULT_READ a_readdefault
|
|
|
|
#define NO_WRITE NULL
|
|
|
|
#define NO_READ NULL
|
|
|
|
|
2002-04-07 02:44:01 +02:00
|
|
|
#define AT_READ_OK 4711
|
|
|
|
#define AT_READ_FAIL -4711
|
|
|
|
|
2003-07-29 11:48:03 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
2001-01-25 10:37:55 +01:00
|
|
|
#endif
|