X-Git-Url: http://www.privoxy.org/gitweb/?p=privoxy.git;a=blobdiff_plain;f=jcc.h;h=3e08911d732ca044742274da00021f50e27e8c5c;hp=d229e3d25f074d060dda9ee35096f62e282458b5;hb=7bfb6887ab00db9e025508bff29c122f05a63ace;hpb=72081f829de368392d04076728f8c991178c0080 diff --git a/jcc.h b/jcc.h index d229e3d2..3e08911d 100644 --- a/jcc.h +++ b/jcc.h @@ -1,14 +1,14 @@ #ifndef JCC_H_INCLUDED #define JCC_H_INCLUDED -#define JCC_H_VERSION "$Id: jcc.h,v 1.12.2.3 2006/01/21 16:16:08 david__schmidt Exp $" +#define JCC_H_VERSION "$Id: jcc.h,v 1.19 2006/12/06 19:41:39 fabiankeil Exp $" /********************************************************************* * - * File : $Source: /cvsroot/ijbswa/current/Attic/jcc.h,v $ + * File : $Source: /cvsroot/ijbswa/current/jcc.h,v $ * * Purpose : Main file. Contains main() method, main loop, and * the main connection-handling function. * - * Copyright : Written by and Copyright (C) 2001 the SourceForge + * Copyright : Written by and Copyright (C) 2001-2006 the SourceForge * Privoxy team. http://www.privoxy.org/ * * Based on the Internet Junkbuster originally written @@ -35,6 +35,46 @@ * * Revisions : * $Log: jcc.h,v $ + * Revision 1.19 2006/12/06 19:41:39 fabiankeil + * Privoxy is now able to run as intercepting + * proxy in combination with any packet filter + * that does the port redirection. The destination + * is extracted from the "Host:" header which + * should be available for nearly all requests. + * + * Moved HTTP snipplets into jcc.c. + * Added error message for gopher proxy requests. + * + * Revision 1.18 2006/11/13 19:05:51 fabiankeil + * Make pthread mutex locking more generic. Instead of + * checking for OSX and OpenBSD, check for FEATURE_PTHREAD + * and use mutex locking unless there is an _r function + * available. Better safe than sorry. + * + * Fixes "./configure --disable-pthread" and should result + * in less threading-related problems on pthread-using platforms, + * but it still doesn't fix BR#1122404. + * + * Revision 1.17 2006/11/06 19:58:23 fabiankeil + * Move pthread.h inclusion from jcc.c to jcc.h. + * Fixes build on x86-freebsd1 (FreeBSD 5.4-RELEASE). + * + * Revision 1.16 2006/09/02 15:36:42 fabiankeil + * Follow the OpenBSD port's lead and protect the resolve + * functions on OpenBSD as well. + * + * Revision 1.15 2006/09/02 10:24:30 fabiankeil + * Include pthread.h for OpenBSD to make Privoxy build again. + * + * Tested shortly on OpenBSD 3.9 without problems, but the OpenBSD + * port has additional patches to use the mutexes OSX_DARWIN needs, + * and it should be investigated if they are still required for + * reliable operation. + * + * Revision 1.14 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.12.2.3 2006/01/21 16:16:08 david__schmidt * Thanks to Edward Carrel for his patch to modernize OSX's pthreads support. See bug #1409623. * @@ -131,17 +171,31 @@ extern int no_daemon; extern int g_terminate; #endif -#ifdef OSX_DARWIN +#ifdef FEATURE_PTHREAD #include +extern pthread_mutex_t log_mutex; +extern pthread_mutex_t log_init_mutex; + +#ifndef HAVE_GMTIME_R extern pthread_mutex_t gmtime_mutex; +#endif /* ndef HAVE_GMTIME_R */ + +#ifndef HAVE_LOCALTIME_R extern pthread_mutex_t localtime_mutex; +#endif /* ndef HAVE_GMTIME_R */ + +#ifndef HAVE_GETHOSTBYADDR_R extern pthread_mutex_t gethostbyaddr_mutex; +#endif /* ndef HAVE_GETHOSTBYADDR_R */ + +#ifndef HAVE_GETHOSTBYNAME_R extern pthread_mutex_t gethostbyname_mutex; -#endif /* def OSX_DARWIN */ +#endif /* ndef HAVE_GETHOSTBYNAME_R */ + +#ifndef HAVE_RANDOM +extern pthread_mutex_t rand_mutex; +#endif /* ndef HAVE_RANDOM */ -#ifdef FEATURE_PTHREAD -extern pthread_mutex_t log_mutex; -extern pthread_mutex_t log_init_mutex; #endif /* FEATURE_PTHREAD */ /* Functions */ @@ -156,6 +210,14 @@ int main(int argc, const char *argv[]); extern const char jcc_rcs[]; extern const char jcc_h_rcs[]; +/* HTTP snippets */ +extern const char CSUCCEED[]; +extern const char CHEADER[]; +extern const char CFORBIDDEN[]; +extern const char FTP_RESPONSE[]; +extern const char GOPHER_RESPONSE[]; +extern const char MISSING_DESTINATION_RESPONSE[]; + #ifdef __cplusplus } /* extern "C" */ #endif