X-Git-Url: https://arthur.barton.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=include%2Fatalk%2Futil.h;h=1a428bda88de08f5166f3bfe9c8c1176e92aaf4c;hb=6d60f95c388da5f8f901d67e0018cf4896e6c6dc;hp=080b13408a216f153d18120bf3f3a075f7d7c9f3;hpb=1de0a6cb5db14c36f1d20258de5ebf64bfe4bdb8;p=netatalk.git diff --git a/include/atalk/util.h b/include/atalk/util.h index 080b1340..1a428bda 100644 --- a/include/atalk/util.h +++ b/include/atalk/util.h @@ -1,7 +1,3 @@ -/* - * $Id: util.h,v 1.21 2010/02/28 22:29:16 didg Exp $ - */ - /*! * @file * Netatalk utility functions @@ -15,32 +11,50 @@ #ifndef _ATALK_UTIL_H #define _ATALK_UTIL_H 1 -#include #include -#ifdef HAVE_UNISTD_H +#include #include -#endif /* HAVE_UNISTD_H */ -#include +#include + #include +#include /* exit error codes */ #define EXITERR_CLNT 1 /* client related error */ #define EXITERR_CONF 2 /* error in config files/cmd line parameters */ #define EXITERR_SYS 3 /* local system error */ +/* Print a SBT and exit */ +#define AFP_PANIC(why) \ + do { \ + netatalk_panic(why); \ + abort(); \ + } while(0); + /* LOG assert errors */ #ifndef NDEBUG #define AFP_ASSERT(b) \ do { \ if (!(b)) { \ - LOG(log_error, logtype_default, "PANIC, assert failed: %s", #b); \ - abort(); \ + AFP_PANIC(#b); \ } \ } while(0); #else #define AFP_ASSERT(b) #endif /* NDEBUG */ +#ifndef MIN +#define MIN(a, b) ((a) < (b) ? (a) : (b)) +#endif + +#ifndef MAX +#define MAX(a, b) ((a) > (b) ? (a) : (b)) +#endif + +#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)) + #ifdef WITH_SENDFILE extern ssize_t sys_sendfile (int __out_fd, int __in_fd, off_t *__offset,size_t __count); #endif @@ -52,28 +66,14 @@ extern void freeifacelist(char **); #define diatolower(x) _dialowermap[(unsigned char) (x)] #define diatoupper(x) _diacasemap[(unsigned char) (x)] -extern int atalk_aton (char *, struct at_addr *); 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 pid_t server_lock (char * /*program*/, char * /*file*/, int /*debug*/); extern void fault_setup (void (*fn)(void *)); +extern void netatalk_panic(const char *why); #define server_unlock(x) (unlink(x)) -/* strlcpy and strlcat are used by pam modules */ -#ifndef UAM_MODULE_EXPORT -#define UAM_MODULE_EXPORT -#endif - -#ifndef HAVE_STRLCPY -UAM_MODULE_EXPORT size_t strlcpy (char *, const char *, size_t); -#endif - -#ifndef HAVE_STRLCAT -UAM_MODULE_EXPORT size_t strlcat (char *, const char *, size_t); -#endif - #ifndef HAVE_DLFCN_H extern void *mod_open (const char *); extern void *mod_symbol (void *, const char *); @@ -123,16 +123,49 @@ extern int lock_reg(int fd, int cmd, int type, off_t offest, int whence, off_t l ******************************************************************/ extern int setnonblock(int fd, int cmd); +extern ssize_t readt(int socket, void *data, const size_t length, int setnonblocking, int timeout); +extern ssize_t writet(int socket, void *data, const size_t length, int setnonblocking, int timeout); extern const char *getip_string(const struct sockaddr *sa); extern unsigned int getip_port(const struct sockaddr *sa); 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}; +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, + struct polldata **polldatap, + int *fdset_usedp, + int *fdset_sizep, + int fd, + enum fdtype fdtype, + void *data); +extern void fdset_del_fd(struct pollfd **fdsetp, + struct polldata **polldatap, + int *fdset_usedp, + int *fdset_sizep, + int fd); +extern int send_fd(int socket, int fd); +extern int recv_fd(int fd, int nonblocking); + /****************************************************************** * unix.c *****************************************************************/ +extern const char *abspath(const char *name); extern const char *getcwdpath(void); +extern char *stripped_slashes_basename(char *p); extern int lchdir(const char *dir); - +extern void randombytes(void *buf, int n); #endif /* _ATALK_UTIL_H */ + +/****************************************************************** + * cnid.c + *****************************************************************/ + +extern bstring rel_path_in_vol(const char *path, const char *volpath);