⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 wrapunix.c

📁 让你了解Unix进程间的通信是如何实现的
💻 C
字号:
/* * Socket wrapper functions. * These could all go into separate files, so only the ones needed cause * the corresponding function to be added to the executable.  If sockets * are a library (SVR4) this might make a difference (?), but if sockets * are in the kernel (BSD) it doesn't matter. * * These wrapper functions also use the same prototypes as POSIX.1g, * which might differ from many implementations (i.e., POSIX.1g specifies * the fourth argument to getsockopt() as "void *", not "char *"). * * If your system's headers are not correct [i.e., the Solaris 2.5 * <sys/socket.h> omits the "const" from the second argument to both * bind() and connect()], you'll get warnings of the form: *warning: passing arg 2 of `bind' discards `const' from pointer target type *warning: passing arg 2 of `connect' discards `const' from pointer target type */#include	"unpipc.h"#include	<stdarg.h>		/* for variable arg lists */void *Calloc(size_t n, size_t size){	void	*ptr;	if ( (ptr = calloc(n, size)) == NULL)		err_sys("calloc error");	return(ptr);}/* include Close */voidClose(int fd){	if (close(fd) == -1)		err_sys("close error");}/* end Close */voidDup2(int fd1, int fd2){	if (dup2(fd1, fd2) == -1)		err_sys("dup2 error");}#ifdef	HAVE_FATTACHvoidFattach(int fd, const char *path){	if (fattach(fd, path) == -1)		err_sys("fattach error");}#endifintFcntl(int fd, int cmd, void *arg){	int	n;	if ( (n = fcntl(fd, cmd, arg)) == -1)		err_sys("fcntl error");	return(n);}pid_tFork(void){	pid_t	pid;	if ( (pid = fork()) == -1)		err_sys("fork error");	return(pid);}longFpathconf(int fd, int name){	long	val;	errno = 0;		/* in case fpathconf() does not change this */	if ( (val = fpathconf(fd, name)) == -1) {		if (errno != 0)			err_sys("fpathconf error");		else			err_sys("fpathconf: %d not defined", name);	}	return(val);}voidFstat(int fd, struct stat *ptr){	if (fstat(fd, ptr) == -1)		err_sys("fstat error");}#ifdef	HAVE_SYS_IPC_Hkey_tFtok(const char *pathname, int id){	key_t	key;	if ( (key = ftok(pathname, id)) == -1)		err_sys("ftok error for pathname \"%s\" and id %d", pathname, id);	return(key);}#endif	/* HAVE_SYS_IPC_H */voidFtruncate(int fd, off_t length){	if (ftruncate(fd, length) == -1)		err_sys("ftruncate error");}intGetopt(int argc, char *const *argv, const char *str){	int		opt;	if ( ( opt = getopt(argc, argv, str)) == '?')		exit(1);		/* getopt() has already written to stderr */	return(opt);}voidGettimeofday(struct timeval *tv, void *foo){	if (gettimeofday(tv, foo) == -1)		err_sys("gettimeofday error");	return;}intIoctl(int fd, int request, void *arg){	int		n;	if ( (n = ioctl(fd, request, arg)) == -1)		err_sys("ioctl error");	return(n);	/* streamio of I_LIST returns value */}voidKill(pid_t pid, int signo){	if (kill(pid, signo) == -1)		err_sys("kill error");}off_tLseek(int fd, off_t offset, int whence){	off_t	pos;	if ( (pos = lseek(fd, offset, whence)) == (off_t) -1)		err_sys("lseek error");	return(pos);}void *Malloc(size_t size){	void	*ptr;	if ( (ptr = malloc(size)) == NULL)		err_sys("malloc error");	return(ptr);}voidMkfifo(const char *pathname, mode_t mode){	if (mkfifo(pathname, mode) == -1)		err_sys("mkfifo error for %s", pathname);}voidMktemp(char *template){	if (mktemp(template) == NULL || template[0] == 0)		err_quit("mktemp error");}#ifdef	HAVE_SYS_MMAN_Hvoid *Mmap(void *addr, size_t len, int prot, int flags, int fd, off_t offset){	void	*ptr;	if ( (ptr = mmap(addr, len, prot, flags, fd, offset)) == MAP_FAILED)		err_sys("mmap error");	return(ptr);}voidMunmap(void *addr, size_t len){	if (munmap(addr, len) == -1)		err_sys("munmap error");}#endif	/* HAVE_SYS_MMAN_H */#ifdef	HAVE_MQUEUE_Hmqd_tMq_open(const char *pathname, int oflag, ...){	mqd_t	mqd;	va_list	ap;	mode_t	mode;	struct mq_attr	*attr;	if (oflag & O_CREAT) {		va_start(ap, oflag);		/* init ap to final named argument */		mode = va_arg(ap, va_mode_t);		attr = va_arg(ap, struct mq_attr *);		if ( (mqd = mq_open(pathname, oflag, mode, attr)) == (mqd_t) -1)			err_sys("mq_open error for %s", pathname);		va_end(ap);	} else {		if ( (mqd = mq_open(pathname, oflag)) == (mqd_t) -1)			err_sys("mq_open error for %s", pathname);	}	return(mqd);}voidMq_close(mqd_t mqd){	if (mq_close(mqd) == -1)		err_sys("mq_close error");}voidMq_unlink(const char *pathname){	if (mq_unlink(pathname) == -1)		err_sys("mq_unlink error");}voidMq_send(mqd_t mqd, const char *ptr, size_t len, unsigned int prio){	if (mq_send(mqd, ptr, len, prio) == -1)		err_sys("mq_send error");}ssize_tMq_receive(mqd_t mqd, char *ptr, size_t len, unsigned int *prio){	ssize_t	n;	if ( (n = mq_receive(mqd, ptr, len, prio)) == -1)		err_sys("mq_receive error");	return(n);}voidMq_notify(mqd_t mqd, const struct sigevent *notification){	if (mq_notify(mqd, notification) == -1)		err_sys("mq_notify error");}voidMq_getattr(mqd_t mqd, struct mq_attr *mqstat){	if (mq_getattr(mqd, mqstat) == -1)		err_sys("mq_getattr error");}voidMq_setattr(mqd_t mqd, const struct mq_attr *mqstat, struct mq_attr *omqstat){	if (mq_setattr(mqd, mqstat, omqstat) == -1)		err_sys("mq_setattr error");}#endif	/* HAVE_SYS_MSG_H */#ifdef	HAVE_SYS_MSG_HintMsgget(key_t key, int flag){	int		rc;	if ( (rc = msgget(key, flag)) == -1)		err_sys("msgget error");	return(rc);}voidMsgctl(int id, int cmd, struct msqid_ds *buf){	if (msgctl(id, cmd, buf) == -1)		err_sys("msgctl error");}voidMsgsnd(int id, const void *ptr, size_t len, int flag){	if (msgsnd(id, ptr, len, flag) == -1)		err_sys("msgsnd error");}ssize_tMsgrcv(int id, void *ptr, size_t len, int type, int flag){	ssize_t	rc;	if ( (rc = msgrcv(id, ptr, len, type, flag)) == -1)		err_sys("msgrcv error");	return(rc);}#endif	/* HAVE_SYS_MSG_H */intOpen(const char *pathname, int oflag, ...){	int		fd;	va_list	ap;	mode_t	mode;	if (oflag & O_CREAT) {		va_start(ap, oflag);		/* init ap to final named argument */		mode = va_arg(ap, va_mode_t);		if ( (fd = open(pathname, oflag, mode)) == -1)			err_sys("open error for %s", pathname);		va_end(ap);	} else {		if ( (fd = open(pathname, oflag)) == -1)			err_sys("open error for %s", pathname);	}	return(fd);}longPathconf(const char *pathname, int name){	long	val;	errno = 0;		/* in case pathconf() does not change this */	if ( (val = pathconf(pathname, name)) == -1) {		if (errno != 0)			err_sys("pathconf error");		else			err_sys("pathconf: %d not defined", name);	}	return(val);}voidPipe(int *fds){	if (pipe(fds) < 0)		err_sys("pipe error");}ssize_tRead(int fd, void *ptr, size_t nbytes){	ssize_t		n;	if ( (n = read(fd, ptr, nbytes)) == -1)		err_sys("read error");	return(n);}/* include Select */intSelect(int nfds, fd_set *readfds, fd_set *writefds, fd_set *exceptfds,       struct timeval *timeout){	int		n;again:	if ( (n = select(nfds, readfds, writefds, exceptfds, timeout)) < 0) {		if (errno == EINTR)			goto again;		else			err_sys("select error");	} else if (n == 0 && timeout == NULL)		err_quit("select returned 0 with no timeout");	return(n);		/* can return 0 on timeout */}/* end Select */#ifdef	HAVE_SEMAPHORE_Hsem_t *Sem_open(const char *pathname, int oflag, ...){	sem_t	*sem;	va_list	ap;	mode_t	mode;	unsigned int	value;	if (oflag & O_CREAT) {		va_start(ap, oflag);		/* init ap to final named argument */		mode = va_arg(ap, va_mode_t);		value = va_arg(ap, unsigned int);		if ( (sem = sem_open(pathname, oflag, mode, value)) == SEM_FAILED)			err_sys("sem_open error for %s", pathname);		va_end(ap);	} else {		if ( (sem = sem_open(pathname, oflag)) == SEM_FAILED)			err_sys("sem_open error for %s", pathname);	}	return(sem);}voidSem_close(sem_t *sem){	if (sem_close(sem) == -1)		err_sys("sem_close error");}voidSem_unlink(const char *pathname){	if (sem_unlink(pathname) == -1)		err_sys("sem_unlink error");}voidSem_init(sem_t *sem, int pshared, unsigned int value){	if (sem_init(sem, pshared, value) == -1)		err_sys("sem_init error");}voidSem_destroy(sem_t *sem){	if (sem_destroy(sem) == -1)		err_sys("sem_destroy error");}voidSem_wait(sem_t *sem){	if (sem_wait(sem) == -1)		err_sys("sem_wait error");}intSem_trywait(sem_t *sem){	int		rc;	if ( (rc = sem_trywait(sem)) == -1 && errno != EAGAIN)		err_sys("sem_trywait error");	return(rc);}/* include Sem_post */voidSem_post(sem_t *sem){	if (sem_post(sem) == -1)		err_sys("sem_post error");}/* end Sem_post */voidSem_getvalue(sem_t *sem, int *valp){	if (sem_getvalue(sem, valp) == -1)		err_sys("sem_getvalue error");}#endif	/* HAVE_SEMAPHORE_H */#ifdef	HAVE_SYS_SEM_HintSemget(key_t key, int nsems, int flag){	int		rc;	if ( (rc = semget(key, nsems, flag)) == -1)		err_sys("semget error");	return(rc);}voidSemop(int id, struct sembuf *opsptr, size_t nops){	if (semop(id, opsptr, nops) == -1)		err_sys("semctl error");}intSemctl(int id, int semnum, int cmd, ...){	int		rc;	va_list	ap;	union semun	arg;	if (cmd == GETALL || cmd == SETALL || cmd == SETVAL ||		cmd == IPC_STAT || cmd == IPC_SET) {		va_start(ap, cmd);		/* init ap to final named argument */		arg = va_arg(ap, union semun);		if ( (rc = semctl(id, semnum, cmd, arg)) == -1)			err_sys("semctl error");		va_end(ap);	} else {		if ( (rc = semctl(id, semnum, cmd)) == -1)			err_sys("semctl error");	}	return(rc);}#endif	/* HAVE_SYS_SEM_H */#ifdef	HAVE_SHM_OPEN_PROTOintShm_open(const char *pathname, int oflag, mode_t mode){	int		fd;	if ( (fd = shm_open(pathname, oflag, mode)) == -1)		err_sys("shm_open error for %s", pathname);	return(fd);}voidShm_unlink(const char *pathname){	if (shm_unlink(pathname) == -1)		err_sys("shm_unlink error");}#endif	/* HAVE_SHM_OPEN_PROTO */#ifdef	HAVE_SYS_SHM_HintShmget(key_t key, size_t size, int flags){	int		rc;	if ( (rc = shmget(key, size, flags)) == -1)		err_sys("shmget error");	return(rc);}void *Shmat(int id, const void *shmaddr, int flags){	void	*ptr;	if ( (ptr = shmat(id, shmaddr, flags)) == (void *) -1)		err_sys("shmat error");	return(ptr);}voidShmdt(const void *shmaddr){	if (shmdt(shmaddr) == -1)		err_sys("shmdt error");}voidShmctl(int id, int cmd, struct shmid_ds *buff){	if (shmctl(id, cmd, buff) == -1)		err_sys("shmctl error");}#endif	/* HAVE_SYS_SHM_H */voidSigaddset(sigset_t *set, int signo){	if (sigaddset(set, signo) == -1)		err_sys("sigaddset error");}voidSigdelset(sigset_t *set, int signo){	if (sigdelset(set, signo) == -1)		err_sys("sigdelset error");}voidSigemptyset(sigset_t *set){	if (sigemptyset(set) == -1)		err_sys("sigemptyset error");}voidSigfillset(sigset_t *set){	if (sigfillset(set) == -1)		err_sys("sigfillset error");}intSigismember(const sigset_t *set, int signo){	int		n;	if ( (n = sigismember(set, signo)) == -1)		err_sys("sigismember error");	return(n);}voidSigpending(sigset_t *set){	if (sigpending(set) == -1)		err_sys("sigpending error");}voidSigprocmask(int how, const sigset_t *set, sigset_t *oset){	if (sigprocmask(how, set, oset) == -1)		err_sys("sigprocmask error");}#ifdef	HAVE_SIGINFO_T_STRUCTvoidSigqueue(pid_t pid, int signo, const union sigval val){	if (sigqueue(pid, signo, val) == -1)		err_sys("sigqueue error");}#endif#ifdef	HAVE_SIGWAITvoidSigwait(const sigset_t *set, int *signo){	int		n;	if ( (n = sigwait(set, signo)) == 0)		return;	errno = n;	err_sys("sigwait error");}#endifvoidStat(const char *pathname, struct stat *ptr){	if (stat(pathname, ptr) == -1)		err_sys("stat error");}char *Strdup(const char *str){	char	*ptr;	if ( (ptr = strdup(str)) == NULL)		err_sys("strdup error");	return(ptr);}longSysconf(int name){	long	val;	errno = 0;		/* in case sysconf() does not change this */	if ( (val = sysconf(name)) == -1) {		if (errno != 0)			err_sys("sysconf error");		else			err_sys("sysconf: %d not defined", name);	}	return(val);}#ifdef	HAVE_SYS_SYSCTL_H#include	<sys/param.h>#include	<sys/sysctl.h>voidSysctl(int *name, u_int namelen, void *oldp, size_t *oldlenp,	   void *newp, size_t newlen){	if (sysctl(name, namelen, oldp, oldlenp, newp, newlen) == -1)		err_sys("sysctl error");}#endifvoidUnlink(const char *pathname){	if (unlink(pathname) == -1)		err_sys("unlink error for %s", pathname);}void *Valloc(size_t size){	void	*ptr;#ifdef	HAVE_VALLOC	if ( (ptr = valloc(size)) == NULL)		err_sys("valloc error");#else	if ( (ptr = malloc(size)) == NULL)		err_sys("malloc error (Valloc)");#endif	return(ptr);}pid_tWait(int *iptr){	pid_t	pid;	if ( (pid = wait(iptr)) == -1)		err_sys("wait error");	return(pid);}pid_tWaitpid(pid_t pid, int *iptr, int options){	pid_t	retpid;	if ( (retpid = waitpid(pid, iptr, options)) == -1)		err_sys("waitpid error");	return(retpid);}voidWrite(int fd, void *ptr, size_t nbytes){	if (write(fd, ptr, nbytes) != nbytes)		err_sys("write error");}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -