#ifndef _LIST_H
#define _LIST_H
#ifdef __cplusplus
extern "C" {
#endif
#define MAXNAME 256
#define TYPESIZE 32
#define FOLLOW_LINK 1
#define NO_FOLLOW_LINK 0
#define PROTOLIST_LIST 1
#define PROTODIR_LIST 2
#define EXCEPTION_LIST 3
#define CHAR_DEV_T 'c'
#define BLOCK_DEV_T 'b'
#define DIR_T 'd'
#define FILE_T 'f'
#define EDIT_T 'e'
#define VOLATILE_T 'v'
#define SYM_LINK_T 's'
#define LINK_T 'l'
#define P_SPARC 1
#define P_SUN4 2
#define P_SUN4c 3
#define P_SUN4d 4
#define P_SUN4e 5
#define P_SUN4m 6
#define P_SUN4u 7
#define P_SUN4v 8
#define P_I386 101
#define P_I86PC 102
#define P_PPC 201
#define P_PREP 202
#if defined(sparc)
#define P_ISA P_SPARC
#elif defined(i386)
#define P_ISA P_I386
#elif defined(__ppc)
#define P_ISA P_PPC
#else
#error "Unknown instruction set"
#endif
#define P_ALL P_ISA
typedef struct pkg_list {
char pkg_name[MAXNAME];
struct pkg_list *next;
} pkg_list;
typedef struct elem {
int inode;
short perm;
int ref_cnt;
short flag;
short major;
short minor;
short arch;
struct elem *next;
struct elem *link_parent;
struct elem *link_sib;
pkg_list *pkgs;
char *symsrc;
char name[MAXNAME];
char owner[TYPESIZE];
char group[TYPESIZE];
char file_type;
} elem;
typedef struct {
int num_of_buckets;
elem **list;
short type;
} elem_list;
#define HASH_SIZE 4093
extern void add_elem(elem_list*, elem *);
extern pkg_list *add_pkg(pkg_list *, const char *);
extern elem *find_elem(elem_list *, elem *, int);
extern elem *find_elem_mach(elem_list *, elem *, int);
extern elem *find_elem_isa(elem_list *, elem *, int);
extern void init_list(elem_list *, int);
extern unsigned int hash(const char *str);
extern int processed_package(const char *pkgname);
extern void mark_processed(const char *pkgname);
#ifdef DEBUG
extern void examine_list(elem_list *list);
extern void print_list(elem_list *);
extern void print_type_list(elem_list *list, char file_type);
#endif
extern int max_list_depth;
#ifdef __cplusplus
}
#endif
#endif