#ifndef ERRLOG_H_INCLUDED #define ERRLOG_H_INCLUDED #define ERRLOG_H_VERSION "$Id: errlog.h,v 1.18 2007/07/14 07:28:47 fabiankeil Exp $" /********************************************************************* * * File : $Source: /cvsroot/ijbswa/current/errlog.h,v $ * * Purpose : Log errors to a designated destination in an elegant, * printf-like fashion. * * Copyright : Written by and Copyright (C) 2001-2007 the SourceForge * Privoxy team. http://www.privoxy.org/ * * Based on the Internet Junkbuster originally written * by and Copyright (C) 1997 Anonymous Coders and * Junkbusters Corporation. http://www.junkbusters.com * * This program is free software; you can redistribute it * and/or modify it under the terms of the GNU General * Public License as published by the Free Software * Foundation; either version 2 of the License, or (at * your option) any later version. * * This program is distributed in the hope that it will * be useful, but WITHOUT ANY WARRANTY; without even the * implied warranty of MERCHANTABILITY or FITNESS FOR A * PARTICULAR PURPOSE. See the GNU General Public * License for more details. * * The GNU General Public License should be included with * this file. If not, you can view it at * http://www.gnu.org/copyleft/gpl.html * or write to the Free Software Foundation, Inc., 59 * Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * Revisions : * $Log: errlog.h,v $ * Revision 1.18 2007/07/14 07:28:47 fabiankeil * Add translation function for JB_ERR_FOO codes. * * Revision 1.17 2007/03/31 13:33:28 fabiankeil * Add alternative log_error() with timestamps * that contain milliseconds and without using * strcpy(), strcat() or sprintf(). * * Revision 1.16 2006/11/28 15:29:50 fabiankeil * Define LOG_LEVEL_REDIRECTS independently of * FEATURE_FAST_REDIRECTS. It is used by redirect{} * as well. * * Revision 1.15 2006/07/18 14:48:46 david__schmidt * Reorganizing the repository: swapping out what was HEAD (the old 3.1 branch) * with what was really the latest development (the v_3_0_branch branch) * * Revision 1.13.2.1 2002/08/05 17:57:06 oes * Cosmetic change * * Revision 1.13 2002/03/26 22:29:54 swa * we have a new homepage! * * Revision 1.12 2002/03/24 13:25:43 swa * name change related issues * * Revision 1.11 2002/03/06 23:02:57 jongfoster * Removing tabs * * Revision 1.10 2001/09/13 20:08:06 jongfoster * Adding support for LOG_LEVEL_CGI * * Revision 1.9 2001/07/30 22:08:36 jongfoster * Tidying up #defines: * - All feature #defines are now of the form FEATURE_xxx * - Permanently turned off WIN_GUI_EDIT * - Permanently turned on WEBDAV and SPLIT_PROXY_ARGS * * Revision 1.8 2001/07/29 18:43:08 jongfoster * Changing #ifdef _FILENAME_H to FILENAME_H_INCLUDED, to conform to * ANSI C rules. * * Revision 1.7 2001/07/19 19:02:53 haroon * Added define for LOG_LEVEL_POPUPS * * Revision 1.6 2001/07/13 13:59:22 oes * - Added LOG_LEVEL_DEANIMATE * - Changed LOG_LEVEL_CLF * - Removed all #ifdef PCRS * * Revision 1.5 2001/05/26 17:25:14 jongfoster * Added support for CLF (Common Log Format) and fixed LOG_LEVEL_LOG * * Revision 1.4 2001/05/25 21:56:06 jongfoster * Added FIXME comment to (broken) LOG_LEVEL_LOG * * Revision 1.3 2001/05/22 18:46:04 oes * * - Enabled filtering banners by size rather than URL * by adding patterns that replace all standard banner * sizes with the "Junkbuster" gif to the re_filterfile * * - Enabled filtering WebBugs by providing a pattern * which kills all 1x1 images * * - Added support for PCRE_UNGREEDY behaviour to pcrs, * which is selected by the (nonstandard and therefore * capital) letter 'U' in the option string. * It causes the quantifiers to be ungreedy by default. * Appending a ? turns back to greedy (!). * * - Added a new interceptor ijb-send-banner, which * sends back the "Junkbuster" gif. Without imagelist or * MSIE detection support, or if tinygif = 1, or the * URL isn't recognized as an imageurl, a lame HTML * explanation is sent instead. * * - Added new feature, which permits blocking remote * script redirects and firing back a local redirect * to the browser. * The feature is conditionally compiled, i.e. it * can be disabled with --disable-fast-redirects, * plus it must be activated by a "fast-redirects" * line in the config file, has its own log level * and of course wants to be displayed by show-proxy-args * Note: Boy, all the #ifdefs in 1001 locations and * all the fumbling with configure.in and acconfig.h * were *way* more work than the feature itself :-( * * - Because a generic redirect template was needed for * this, tinygif = 3 now uses the same. * * - Moved GIFs, and other static HTTP response templates * to project.h * * - Some minor fixes * * - Removed some >400 CRs again (Jon, you really worked * a lot! ;-) * * Revision 1.2 2001/05/20 01:11:40 jongfoster * Added support for LOG_LEVEL_FATAL * Renamed LOG_LEVEL_FRC to LOG_LEVEL_FORCE, * and LOG_LEVEL_REF to LOG_LEVEL_RE_FILTER * * Revision 1.1.1.1 2001/05/15 13:58:51 oes * Initial import of version 2.9.3 source tree * * *********************************************************************/ #ifdef __cplusplus extern "C" { #endif /* Debug level for errors */ #define LOG_LEVEL_GPC 0x0001 #define LOG_LEVEL_CONNECT 0x0002 #define LOG_LEVEL_IO 0x0004 #define LOG_LEVEL_HEADER 0x0008 #define LOG_LEVEL_LOG 0x0010 #ifdef FEATURE_FORCE_LOAD #define LOG_LEVEL_FORCE 0x0020 #endif /* def FEATURE_FORCE_LOAD */ #define LOG_LEVEL_RE_FILTER 0x0040 #define LOG_LEVEL_REDIRECTS 0x0080 #define LOG_LEVEL_DEANIMATE 0x0100 #define LOG_LEVEL_CLF 0x0200 /* Common Log File format */ #ifdef FEATURE_KILL_POPUPS #define LOG_LEVEL_POPUPS 0x0400 /* Kill Popups */ #endif /* def FEATURE_KILL_POPUPS */ #define LOG_LEVEL_CGI 0x0800 /* CGI / templates */ /* Following are always on: */ #define LOG_LEVEL_INFO 0x1000 #define LOG_LEVEL_ERROR 0x2000 #define LOG_LEVEL_FATAL 0x4000 /* Exits after writing log */ extern void init_error_log(const char *prog_name, const char *logfname); extern void set_debug_level(int debuglevel); void disable_logging(void); void init_log_module(const char *prog_name); extern void log_error(int loglevel, const char *fmt, ...); extern const char *jb_err_to_string(int error); /* Revision control strings from this header and associated .c file */ extern const char errlog_rcs[]; extern const char errlog_h_rcs[]; #ifdef __cplusplus } /* extern "C" */ #endif #endif /* ndef ERRLOG_H_INCLUDED */ /* Local Variables: tab-width: 3 end: */