X-Git-Url: https://arthur.barton.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=etc%2Fafpd%2Fdirectory.h;h=82daa86c5b5bf5f7bc11e3afdc88baf3851ed593;hb=b0bcb8f6b0571592a50ce039882c9319e012a270;hp=0fe65e7000af0f02fe5a7e3e7049e013d4c96e16;hpb=f9199e184eec86132d172506962fc17f691aa6b7;p=netatalk.git diff --git a/etc/afpd/directory.h b/etc/afpd/directory.h index 0fe65e70..82daa86c 100644 --- a/etc/afpd/directory.h +++ b/etc/afpd/directory.h @@ -1,6 +1,4 @@ /* - * $Id: directory.h,v 1.34 2010/03/12 15:16:49 franklahm Exp $ - * * Copyright (c) 1990,1991 Regents of The University of Michigan. * All Rights Reserved. * @@ -26,10 +24,8 @@ #ifndef AFPD_DIRECTORY_H #define AFPD_DIRECTORY_H 1 -#include #include -/*#include */ /* including it here causes some confusion */ -#include +#include #include /* sys/types.h usually snarfs in major/minor macros. if they don't @@ -39,21 +35,10 @@ #endif #include +#include -#include "globals.h" #include "volume.h" -#define DIRF_FSMASK (3<<0) -#define DIRF_NOFS (0<<0) -#define DIRF_AFS (1<<0) -#define DIRF_UFS (2<<0) - -#define DIRF_OFFCNT (1<<4) /* offsprings count is valid */ -#define DIRF_CNID (1<<5) /* renumerate id */ -#define DIRF_CACHELOCK (1<<6) /* lock in cache, don't remove in dircache_eviction, for catsearch */ - -#define AFPDIR_READ (1<<0) - /* directory bits */ #define DIRPBIT_ATTR 0 #define DIRPBIT_PDID 1 @@ -106,16 +91,21 @@ struct maccess { #define AR_UWRITE (1<<2) #define AR_UOWN (1<<7) +q_t *invalid_dircache_entries; + typedef int (*dir_loop)(struct dirent *, char *, void *); -extern struct dir *dir_new(const char *mname, const char *uname, const struct vol *, - cnid_t pdid, cnid_t did, bstring fullpath); /* volume.c needs it once */ +extern void dir_free_invalid_q(void); +extern struct dir *dir_new(const char *mname, const char *uname, const struct vol *, + cnid_t pdid, cnid_t did, bstring fullpath, struct stat *); extern void dir_free (struct dir *); -extern struct dir *dir_add(const struct vol *, const struct dir *, struct path *, int); +extern struct dir *dir_add(struct vol *, const struct dir *, struct path *, int); extern int dir_modify(const struct vol *vol, struct dir *dir, cnid_t pdid, cnid_t did, const char *new_mname, const char *new_uname, bstring pdir_fullpath); extern int dir_remove(const struct vol *vol, struct dir *dir); extern struct dir *dirlookup (const struct vol *, cnid_t); +extern struct dir *dirlookup_bypath(const struct vol *vol, const char *path); + extern int movecwd (const struct vol *, struct dir *); extern struct path *cname (struct vol *, struct dir *, char **);