APUE函数笔记: 附录

附录:

#include <stdio.h>
#include <errno.h>
#include <string.h>
#include <stdlib.h>
#include <stdarg.h>
#include <syslog.h>

#define MAXLINE  4096  /* max line length */


/*
 * default file access permissions for new files
 */
#define FILE_MODE  (S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH)

/*
 * default permissions for new directories
 */
#define DIR_MODE   (FILE_MODE | S_IXUSR | S_IXGRP | S_IXOTH)


/*
 * print a message and return to caller
 * caller specifies "errnoflag"
 */
void 
err_doit(int errnoflag, int error, const char * fmt, va_list ap)
{
    int   len;
    char  buf[MAXLINE];

    vsnprintf(buf, MAXLINE, fmt, ap);
    if (errnoflag) {
        len = strlen(buf);
        snprintf(buf + len, MAXLINE - len, ": %s", strerror(error));
    }
    strcat(buf, "\n");
    fflush(stdout);    /* in case stdout and stderr are the same */
    fputs(buf, stderr);
    fflush(NULL);      /* flushes all stdio output streams */
}

/*
 * nonfatal error related to a system call
 * print a message and return
 */
void 
err_ret(const char * fmt, ...)
{
    va_list  ap;

    va_start(ap, fmt);
    err_doit(1, errno, fmt, ap);
    va_end(ap);
}

/*
 * fatal error related to a system call
 * print a message and terminate
 */
void 
err_sys(const char * fmt, ...)
{
    va_list  ap;

    va_start(ap, fmt);
    err_doit(1, errno, fmt, ap);
    va_end(ap);
    exit(1);
}

/*
 * fatal error unrelated to a system call
 * error code passed as explict parameter
 * print a message and terminate
 */
void 
err_exit(int error, const char * fmt, ...)
{
    va_list  ap;

    va_start(ap, fmt);
    err_doit(1, error, fmt, ap);
    va_end(ap);
    exit(1);
}

/*
 * fatal error related to a system call
 * print a message, dump core, and terminate
 */
void 
err_dump(const char * fmt, ...)
{
    va_list  ap;

    va_start(ap, fmt);
    err_doit(1, errno, fmt, ap);
    va_end(ap);
    abort();    /* dump core and terminate */
    exit(1);    /* shouldn't get here */
}

/*
 * nonfatal error unrelated to a system call
 * print a message and return
 */
void 
err_msg(const char * fmt, ...)
{
    va_list  ap;

    va_start(ap, fmt);
    err_doit(0, 0, fmt, ap);
    va_end(ap);
}

/*
 * fatal error unrelated to a system call
 * print a message and terminate
 */
void 
err_quit(const char * fmt, ...)
{
    va_list  ap;

    va_start(ap, fmt);
    err_doit(0, 0, fmt, ap);
    va_end(ap);
    exit(1);
}


/*
 * caller must define and set this: nonzero if
 * interactive, zero if daemon
 */
int  log_to_stderr;

/*
 * print a message and return to caller
 * caller specifies "errnoflag" and "priority"
 */
void 
log_doit(int errnoflag, int priority, const char * fmt, va_list ap)
{
    int   len;
    int   errno_save;
    char  buf[MAXLINE];

    errno_save = errno;  /* value caller might want printed */
    vsnprintf(buf, MAXLINE, fmt, ap);
    if (errnoflag) {
        len = strlen(buf);
        snprintf(buf + len, MAXLINE - len, ": %s", strerror(errno_save));
    }
    strcat(buf, "\n");
    if (log_to_stderr) {
        fflush(stdout);
        fputs(buf, stderr);
        fflush(stderr);
    }
    else {
        syslog(priority, "%s", buf);
    }
}

/*
 * initialize syslog(), if running as daemon
 */
void 
log_open(const char * ident, int option, int facility)
{
    if (log_to_stderr == 0) {
        openlog(ident, option, facility);
    }
}

/*
 * nonfatal error related to a system call
 * print a message with the system's errno value and return
 */
void 
log_ret(const char * fmt, ...)
{
    va_list  ap;

    va_start(ap, fmt);
    log_doit(1, LOG_ERR, fmt, ap);
    va_end(ap);
}

/*
 * fatal error related to a system call
 * print a message and terminate
 */
void 
log_sys(const char * fmt, ...)
{
    va_list  ap;

    va_start(ap, fmt);
    log_doit(1, LOG_ERR, fmt, ap);
    va_end(ap);
    exit(2);
}

/*
 * nonfatal error unrelated to a system call
 * print a message and return
 */
void 
log_msg(const char * fmt, ...)
{
    va_list  ap;

    va_start(ap, fmt);
    log_doit(0, LOG_ERR, fmt, ap);
    va_end(ap);
}

/*
 * fatal error unrelated to a system call
 * print a message and terminate
 */
void 
log_quit(const char * fmt, ...)
{
    va_list  ap;

    va_start(ap, fmt);
    log_doit(0, LOG_ERR, fmt, ap);
    va_end(ap);
    exit(2);
}


评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值