X-Git-Url: https://arthur.barton.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=include%2Fatalk%2Futil.h;h=5f584a945a45c7e8bb1768abea1efce504240461;hb=dc0f3a5d97e0878f6f0e85ae3ae74ad68be6c037;hp=2ca7e2759d10e3dfad1c27d67fb045f64619a3ca;hpb=ad220cd96d55445846d30b951a188ec5f9b849b2;p=netatalk.git diff --git a/include/atalk/util.h b/include/atalk/util.h index 2ca7e275..5f584a94 100644 --- a/include/atalk/util.h +++ b/include/atalk/util.h @@ -15,10 +15,10 @@ #include #include #include -#ifndef NO_DDP -#include -#endif + #include +#include +#include /* exit error codes */ #define EXITERR_CLNT 1 /* client related error */ @@ -55,6 +55,21 @@ #define STRCMP(a,b,c) (strcmp(a,c) b 0) #define ZERO_STRUCT(a) memset(&(a), 0, sizeof(a)) #define ZERO_STRUCTP(a) memset((a), 0, sizeof(a)) +#ifndef MAX +#define MAX(a,b) ((a) > (b) ? a : b) +#endif +#ifndef MIN +#define MIN(a,b) ((a) < (b) ? a : b) +#endif + +#ifdef WORDS_BIGENDIAN +#define hton64(x) (x) +#define ntoh64(x) (x) +#else +#define hton64(x) ((uint64_t) (htonl(((x) >> 32) & 0xffffffffLL)) | \ + (uint64_t) ((htonl(x) & 0xffffffffLL) << 32)) +#define ntoh64(x) (hton64(x)) +#endif #ifdef WITH_SENDFILE extern ssize_t sys_sendfile (int __out_fd, int __in_fd, off_t *__offset,size_t __count); @@ -67,13 +82,12 @@ extern void freeifacelist(char **); #define diatolower(x) _dialowermap[(unsigned char) (x)] #define diatoupper(x) _diacasemap[(unsigned char) (x)] -#ifndef NO_DDP -extern int atalk_aton (char *, struct at_addr *); -#endif extern void bprint (char *, int); extern int strdiacasecmp (const char *, const char *); extern int strndiacasecmp (const char *, const char *, size_t); extern pid_t server_lock (char * /*program*/, char * /*file*/, int /*debug*/); +extern int check_lockfile (const char *program, const char *pidfile); +extern int create_lockfile(const char *program, const char *pidfile); extern void fault_setup (void (*fn)(void *)); extern void netatalk_panic(const char *why); #define server_unlock(x) (unlink(x)) @@ -135,14 +149,15 @@ extern void apply_ip_mask(struct sockaddr *ai, int maskbits); extern int compare_ip(const struct sockaddr *sa1, const struct sockaddr *sa2); /* Structures and functions dealing with dynamic pollfd arrays */ -enum fdtype {IPC_FD, LISTEN_FD}; +enum fdtype {IPC_FD, LISTEN_FD, DISASOCIATED_IPC_FD}; struct polldata { enum fdtype fdtype; /* IPC fd or listening socket fd */ void *data; /* pointer to AFPconfig for listening socket and * * pointer to afp_child_t for IPC fd */ }; -extern void fdset_add_fd(struct pollfd **fdsetp, +extern void fdset_add_fd(int maxconns, + struct pollfd **fdsetp, struct polldata **polldatap, int *fdset_usedp, int *fdset_sizep, @@ -161,9 +176,28 @@ extern int recv_fd(int fd, int nonblocking); * unix.c *****************************************************************/ -extern const char *abspath(const char *name); extern const char *getcwdpath(void); +extern const char *fullpathname(const char *); extern char *stripped_slashes_basename(char *p); extern int lchdir(const char *dir); extern void randombytes(void *buf, int n); +extern int daemonize(int nochdir, int noclose); +extern int run_cmd(const char *cmd, char **cmd_argv); +extern char *realpath_safe(const char *path); +extern const char *basename_safe(const char *path); + +/****************************************************************** + * cnid.c + *****************************************************************/ + +extern bstring rel_path_in_vol(const char *path, const char *volpath); +extern cnid_t cnid_for_path(struct _cnid_db *cdb, const char *volpath, const char *path, cnid_t *did); + +/****************************************************************** + * cnid.c + *****************************************************************/ + +extern void initline (int, char *); +extern int parseline (int, char *); + #endif /* _ATALK_UTIL_H */