flow_print.c

来自「snort-2.1.0入侵检测」· C语言 代码 · 共 120 行

C
120
字号
#ifdef HAVE_CONFIG_H#include "config.h"#endif#include "flow_print.h"#include "flow_error.h"#include <unistd.h>#include <syslog.h>#include <stdio.h>#include <stdlib.h>#include <stdarg.h>static int s_daemon = 0;  /* what mode is this library running in */#define BUFSIZE 1024/**  * Make this library print to syslog *  *  * @return FLOW_SUCCESS */int flow_set_daemon(void){    s_daemon = 1;        return FLOW_SUCCESS;}/**  * flow's printf *  * @param format format to print in * @param  ... args *  * @return FLOW_SUCCESS on sucess */int flow_printf(const char *format, ...){    char buf[BUFSIZE + 1];    va_list ap;        va_start(ap,format);    vsnprintf(buf, BUFSIZE, format, ap);    va_end(ap);    buf[BUFSIZE] = '\0';    if(s_daemon)    {        syslog(LOG_CONS | LOG_DAEMON | LOG_ERR, "%s", buf);    }    else    {        fprintf(stderr, "%s", buf);            }        return FLOW_SUCCESS;}int flow_fatalerror(const char *format, ...){    char buf[BUFSIZE + 1];    char fmt[BUFSIZE + 1];        va_list ap;    snprintf(fmt, BUFSIZE, "FatalError: %s", format);    fmt[BUFSIZE] = '\0';        va_start(ap,format);    vsnprintf(buf, BUFSIZE, format, ap);    va_end(ap);    buf[BUFSIZE] = '\0';    if(s_daemon)    {        syslog(LOG_CONS | LOG_DAEMON | LOG_ERR, "%s", buf);    }    else    {        fprintf(stderr, "%s", buf);            }    exit(1);    /* not reached */    return FLOW_SUCCESS;}int flow_errormsg(const char *format, ...){    char buf[BUFSIZE + 1];    char fmt[BUFSIZE + 1];        va_list ap;    snprintf(fmt, BUFSIZE, "ERROR: %s", format);    fmt[BUFSIZE] = '\0';        va_start(ap,format);    vsnprintf(buf, BUFSIZE, format, ap);    va_end(ap);    buf[BUFSIZE] = '\0';    if(s_daemon)    {        syslog(LOG_CONS | LOG_DAEMON | LOG_ERR, "%s", buf);    }    else    {        fprintf(stderr, "%s", buf);            }    exit(1);    return FLOW_SUCCESS;}

⌨️ 快捷键说明

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