/*
- * $Id: adouble.h,v 1.21.6.3 2003-11-25 05:05:43 didg Exp $
+ * $Id: adouble.h,v 1.21.6.16 2004-04-21 18:45:45 bfernhomberg Exp $
* Copyright (c) 1990,1991 Regents of The University of Michigan.
* All Rights Reserved.
*
#endif
#ifdef HAVE_PWRITE
-
#ifndef HAVE_PREAD
#undef HAVE_PWRITE
#endif
-
#endif
-#ifdef HAVE_PREAD
+/*
+ Still have to figure out which platforms really
+ need _XOPEN_SOURCE defined for pread.
+ */
+#if defined(HAVE_PREAD) && !defined(SOLARIS) && !defined(__OpenBSD__)
+#ifdef _XOPEN_SOURCE
+#undef _XOPEN_SOURCE
+#endif
#define _XOPEN_SOURCE 500
#endif
+#include <sys/types.h>
+#include <sys/stat.h>
+
#ifdef HAVE_UNISTD_H
#undef __USE_MISC
#define __USE_MISC
#include <unistd.h>
#endif
+#include <sys/cdefs.h>
+
#ifdef HAVE_FCNTL_H
#include <fcntl.h>
#endif
-#include <sys/cdefs.h>
-#include <sys/types.h>
-#include <sys/stat.h>
#include <sys/mman.h>
+#ifdef HAVE_SYS_TIME_H
+#include <sys/time.h>
+#endif
#include <netatalk/endian.h>
/* version info */
#define AD_VERSION1 0x00010000
#define AD_VERSION2 0x00020000
+#define AD_VERSION2_OSX 0x00020001
#define AD_VERSION AD_VERSION2
/*
#define ADEID_PRIVDEV 16
#define ADEID_PRIVINO 17
#define ADEID_PRIVSYN 18 /* in synch with database */
+#define ADEID_PRIVID 19
#define AD_DEV 0x80444556
#define AD_INO 0x80494E4F
#define AD_SYN 0x8053594E
-#define ADEID_MAX 19
+#define AD_ID 0x8053567E
+#define ADEID_MAX 20
#endif
/* magic */
#define ADEDLEN_PRIVDEV 8
#define ADEDLEN_PRIVINO 8
#define ADEDLEN_PRIVSYN 8
+#define ADEDLEN_PRIVID 4
-#define ADEID_NUM_V1 5
-#define ADEID_NUM_V2 12
+#define ADEID_NUM_V1 5
+#define ADEID_NUM_V2 13
/* 589 */
#define AD_DATASZ1 (AD_HEADER_LEN + ADEDLEN_NAME + ADEDLEN_COMMENT +ADEDLEN_FILEI +ADEDLEN_FINDERI+\
#endif
#define AD_NEWSZ2 (ADEDLEN_DID + ADEDLEN_AFPFILEI +ADEDLEN_SHORTNAME +ADEDLEN_PRODOSFILEI \
-+ADEDLEN_PRIVDEV +ADEDLEN_PRIVINO +ADEDLEN_PRIVSYN)
++ADEDLEN_PRIVDEV +ADEDLEN_PRIVINO +ADEDLEN_PRIVSYN+ ADEDLEN_PRIVID)
/* 725 */
-/*
-#define AD_DATASZ2 (AD_DATASZ1 + (ADEID_NUM_V2 -ADEID_NUM_V1)*AD_ENTRY_LEN)
-FIXME I give up,
-for our adouble version 2 size *is* 725
-*/
-#define AD_DATASZ2 725
+#define AD_DATASZ2 (AD_DATASZ1 + AD_NEWSZ2 + (ADEID_NUM_V2 -ADEID_NUM_V1)*AD_ENTRY_LEN)
-#if AD_DATASZ2 != 725
+#if AD_DATASZ2 != 741
#error bad size for AD_DATASZ2
#endif
off_t ad_rlen; /* ressource fork len with AFP 3.0
the header parameter size is too small.
*/
+ char *(*ad_path)(const char *, int);
+
#ifdef USE_MMAPPED_HEADERS
char *ad_data;
#else
#define ad_unlock ad_fcntl_unlock
/* ad_open.c */
-extern int ad_setfuid __P((const uid_t ));
-extern uid_t ad_getfuid __P((void ));
+extern int ad_setfuid __P((const uid_t ));
+extern uid_t ad_getfuid __P((void ));
-extern char *ad_dir __P((const char *));
-extern char *ad_path __P((const char *, int));
-extern int ad_mode __P((const char *, int));
-extern int ad_mkdir __P((const char *, int));
-extern void ad_init __P((struct adouble *, int ));
+extern char *ad_dir __P((const char *));
+extern char *ad_path __P((const char *, int));
+extern char *ad_path_osx __P((const char *, int));
-extern int ad_open __P((const char *, int, int, int, struct adouble *));
-extern int ad_refresh __P((struct adouble *));
-extern int ad_stat __P((const char *, struct stat *));
+extern int ad_mode __P((const char *, int));
+extern int ad_mkdir __P((const char *, int));
+extern void ad_init __P((struct adouble *, int ));
+
+extern int ad_open __P((const char *, int, int, int, struct adouble *));
+extern int ad_refresh __P((struct adouble *));
+extern int ad_stat __P((const char *, struct stat *));
/* extend header to RW if R or W (W if R for locking),
*/
#ifndef ATACC
+#ifndef __inline__
+#define __inline__
+#endif
static __inline__ mode_t ad_hf_mode (mode_t mode)
{
/* fnctl lock need write access */
extern int ad_setattr __P((const struct adouble *, const u_int16_t));
extern int ad_getattr __P((const struct adouble *, u_int16_t *));
+extern int ad_setname __P((struct adouble *, const char *));
#if AD_VERSION == AD_VERSION2
-extern int ad_setid __P((struct adouble *, const struct stat *, const u_int32_t, const void *));
+extern int ad_setid __P((struct adouble *, const dev_t dev,const ino_t ino, const u_int32_t, const u_int32_t, const void *));
#else
-#define ad_setid(a, b, c, d)
+#define ad_setid(a, b, c)
#endif
#ifdef WITH_SENDFILE