데 몬 을 위 한 오류 처리 함수

6722 단어 함수.
/*

* Error routines for programs that can run as a daemon.

*/



#include "apue.h"

#include <errno.h>    /* for definition of errno */

#include <stdarg.h>    /* ISO C variable arguments */

#include <syslog.h>



static void log_doit(int, int, const char *, va_list ap);



/*

* Caller must define and set this: nonzero if

* interactive, zero if daemon

*/

extern int log_to_stderr;;



/*

* Initialize syslog(), is 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 realted 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);

}



/*

* Print a message and return to caller.

* Caller specifies "errnoflag" and "priority". 

*/

static void

log_doit(int errnoflag, int priority, const char *fmt, va_list ap)

{

    int     errno_save;

    char     buf[MAXLINE];



    errno_save = errno;    /* value caller might want printed */

    vsnprintf(buf, MAXLINE, fmt, ap);

    if(errnoflag)

        snprintf(buf+strlen(buf), MAXLINE-strlen(buf), ": %s", strerror(errno_save));

    strcat(buf, "
"); if(log_to_stderr) { fflush(stdout); fputs(buf, stderr); fflush(stderr); } else { syslog(priority, buf); } }

이 박문 의 내용 은 '유 닉 스 환경 고급 프로 그래 밍' (2 판) 에서 발췌 한 것 으로 개인 학습 기록 에 만 사용 된다.이 책 에 대하 여 참고 할 수 있 습 니 다.

좋은 웹페이지 즐겨찾기