X-Git-Url: http://www.privoxy.org/gitweb/?a=blobdiff_plain;f=jcc.h;h=03482e8929dd707b4254c5dfe0b248e0741235b7;hb=d90684bd0e048383d4b5d4cb5475b69e497b72b7;hp=9da00cf1316abd025c2fbad8314e2a79f4ac7cb6;hpb=3fb1f03ddb3407a710371dcfed1494363aace957;p=privoxy.git diff --git a/jcc.h b/jcc.h index 9da00cf1..03482e89 100644 --- a/jcc.h +++ b/jcc.h @@ -1,6 +1,6 @@ #ifndef JCC_H_INCLUDED #define JCC_H_INCLUDED -#define JCC_H_VERSION "$Id: jcc.h,v 1.18 2006/11/13 19:05:51 fabiankeil Exp $" +#define JCC_H_VERSION "$Id: jcc.h,v 1.22 2007/06/01 18:16:36 fabiankeil Exp $" /********************************************************************* * * File : $Source: /cvsroot/ijbswa/current/jcc.h,v $ @@ -35,6 +35,31 @@ * * Revisions : * $Log: jcc.h,v $ + * Revision 1.22 2007/06/01 18:16:36 fabiankeil + * Use the same mutex for gethostbyname() and gethostbyaddr() to prevent + * deadlocks and crashes on OpenBSD and possibly other OS with neither + * gethostbyname_r() nor gethostaddr_r(). Closes BR#1729174. + * Thanks to Ralf Horstmann for report and solution. + * + * Revision 1.21 2007/04/22 13:18:06 fabiankeil + * Keep the HTTP snippets local. + * + * Revision 1.20 2006/12/26 17:31:41 fabiankeil + * Mutex protect rand() if POSIX threading + * is used, warn the user if that's not possible + * and stop using it on _WIN32 where it could + * cause crashes. + * + * 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 @@ -163,24 +188,31 @@ extern int g_terminate; #ifdef FEATURE_PTHREAD #include -extern pthread_mutex_t log_mutex; -extern pthread_mutex_t log_init_mutex; + +typedef pthread_mutex_t privoxy_mutex_t; + +extern void privoxy_mutex_lock(privoxy_mutex_t *mutex); +extern void privoxy_mutex_unlock(privoxy_mutex_t *mutex); + +extern privoxy_mutex_t log_mutex; +extern privoxy_mutex_t log_init_mutex; #ifndef HAVE_GMTIME_R -extern pthread_mutex_t gmtime_mutex; +extern privoxy_mutex_t gmtime_mutex; #endif /* ndef HAVE_GMTIME_R */ #ifndef HAVE_LOCALTIME_R -extern pthread_mutex_t localtime_mutex; +extern privoxy_mutex_t localtime_mutex; #endif /* ndef HAVE_GMTIME_R */ -#ifndef HAVE_GETHOSTBYADDR_R -extern pthread_mutex_t gethostbyaddr_mutex; -#endif /* ndef HAVE_GETHOSTBYADDR_R */ +#if !defined(HAVE_GETHOSTBYADDR_R) || !defined(HAVE_GETHOSTBYNAME_R) +extern privoxy_mutex_t resolver_mutex; +#endif /* !defined(HAVE_GETHOSTBYADDR_R) || !defined(HAVE_GETHOSTBYNAME_R) */ + +#ifndef HAVE_RANDOM +extern privoxy_mutex_t rand_mutex; +#endif /* ndef HAVE_RANDOM */ -#ifndef HAVE_GETHOSTBYNAME_R -extern pthread_mutex_t gethostbyname_mutex; -#endif /* ndef HAVE_GETHOSTBYNAME_R */ #endif /* FEATURE_PTHREAD */ /* Functions */ @@ -195,14 +227,6 @@ 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