From 8ca92f3d0d9227cf1068ab3c1434a4bf78ed6897 Mon Sep 17 00:00:00 2001 From: cytopia Date: Mon, 21 Mar 2022 00:17:22 +0100 Subject: [PATCH] Ensure PHP extension directory exists --- Dockerfiles/Dockerfile.jessie | 16 +- Dockerfiles/Dockerfile.stretch | 16 +- Dockerfiles/data/php-5.1.6-curl.patch | 51 - Dockerfiles/data/php-5.1.6-fpm.patch | 33857 ---------------- Dockerfiles/data/php-5.1.6-libxml2.patch | 54 - Dockerfiles/data/php-5.1.6-openssl.patch | 48 - .../data/{ => php}/php-5.2.17-curl.patch | 0 .../data/{ => php}/php-5.2.17-fpm.patch | 0 .../data/{ => php}/php-5.2.17-libxml2.patch | 0 .../data/{ => php}/php-5.2.17-openssl.patch | 0 Dockerfiles/data/php/php-5.2.17.tar.xz | Bin 0 -> 7450444 bytes 11 files changed, 16 insertions(+), 34026 deletions(-) delete mode 100644 Dockerfiles/data/php-5.1.6-curl.patch delete mode 100644 Dockerfiles/data/php-5.1.6-fpm.patch delete mode 100644 Dockerfiles/data/php-5.1.6-libxml2.patch delete mode 100644 Dockerfiles/data/php-5.1.6-openssl.patch rename Dockerfiles/data/{ => php}/php-5.2.17-curl.patch (100%) rename Dockerfiles/data/{ => php}/php-5.2.17-fpm.patch (100%) rename Dockerfiles/data/{ => php}/php-5.2.17-libxml2.patch (100%) rename Dockerfiles/data/{ => php}/php-5.2.17-openssl.patch (100%) create mode 100644 Dockerfiles/data/php/php-5.2.17.tar.xz diff --git a/Dockerfiles/Dockerfile.jessie b/Dockerfiles/Dockerfile.jessie index bab3879..a7cb761 100644 --- a/Dockerfiles/Dockerfile.jessie +++ b/Dockerfiles/Dockerfile.jessie @@ -124,7 +124,8 @@ RUN set -eux \ ### Copy PHP scripts and patches ### COPY data/docker-php-source /usr/local/bin/ -COPY data/php-${PHP_VERSION}*.patch /tmp/ +COPY data/php/php-${PHP_VERSION}.tar.xz /usr/src/php.tar.xz +COPY data/php/php-${PHP_VERSION}*.patch /tmp/ ### @@ -140,17 +141,14 @@ RUN set -eux \ apt-get install -y --no-install-recommends --no-install-suggests \ ${BUILD_TOOLS_32}; \ fi \ -# Fetch PHP - && curl -sS -k -L --fail "http://museum.php.net/php5/php-${PHP_VERSION}.tar.gz" -o /usr/src/php.tar.gz \ -# Extract artifacts - && tar -xf /usr/src/php.tar.gz -C /usr/src/php --strip-components=1 \ -# Apply patches +# Extract and apply patches + && docker-php-source extract \ && cd /usr/src/php \ && patch -p1 < /tmp/php-${PHP_VERSION}-libxml2.patch \ && patch -p1 < /tmp/php-${PHP_VERSION}-openssl.patch \ && patch -p1 < /tmp/php-${PHP_VERSION}-fpm.patch \ && (patch -p0 < /tmp/php-${PHP_VERSION}-curl.patch || true) \ -# Create php.tar.xz +# Create new php.tar.xz && cd /usr/src \ && tar -cJf php.tar.xz php \ && rm -rf php php.tar.gz \ @@ -212,7 +210,9 @@ RUN set -eux \ ${PHP_RUNTIME_DEPS} \ ${RUNTIME_TOOLS} \ && apt-get clean \ - && rm -rf /var/lib/apt/lists/* + && rm -rf /var/lib/apt/lists/* \ +# Setup extension dir + && mkdir -p "$(php -r 'echo ini_get("extension_dir");')" COPY data/docker-php-* /usr/local/bin/ diff --git a/Dockerfiles/Dockerfile.stretch b/Dockerfiles/Dockerfile.stretch index 92fed03..13dccf7 100644 --- a/Dockerfiles/Dockerfile.stretch +++ b/Dockerfiles/Dockerfile.stretch @@ -126,7 +126,8 @@ RUN set -eux \ ### Copy PHP scripts and patches ### COPY data/docker-php-source /usr/local/bin/ -COPY data/php-${PHP_VERSION}*.patch /tmp/ +COPY data/php/php-${PHP_VERSION}.tar.xz /usr/src/php.tar.xz +COPY data/php/php-${PHP_VERSION}*.patch /tmp/ ### @@ -142,17 +143,14 @@ RUN set -eux \ apt-get install -y --no-install-recommends --no-install-suggests \ ${BUILD_TOOLS_32}; \ fi \ -# Fetch PHP - && curl -sS -k -L --fail "http://museum.php.net/php5/php-${PHP_VERSION}.tar.gz" -o /usr/src/php.tar.gz \ -# Extract artifacts - && tar -xf /usr/src/php.tar.gz -C /usr/src/php --strip-components=1 \ -# Apply patches +# Extract and apply patches + && docker-php-source extract \ && cd /usr/src/php \ && patch -p1 < /tmp/php-${PHP_VERSION}-libxml2.patch \ && patch -p1 < /tmp/php-${PHP_VERSION}-openssl.patch \ && patch -p1 < /tmp/php-${PHP_VERSION}-fpm.patch \ && (patch -p0 < /tmp/php-${PHP_VERSION}-curl.patch || true) \ -# Create php.tar.xz +# Create new php.tar.xz && cd /usr/src \ && tar -cJf php.tar.xz php \ && rm -rf php php.tar.gz \ @@ -217,7 +215,9 @@ RUN set -eux \ ${PHP_RUNTIME_DEPS} \ ${RUNTIME_TOOLS} \ && apt-get clean \ - && rm -rf /var/lib/apt/lists/* + && rm -rf /var/lib/apt/lists/* \ +# Setup extension dir + && mkdir -p "$(php -r 'echo ini_get("extension_dir");')" COPY data/docker-php-* /usr/local/bin/ diff --git a/Dockerfiles/data/php-5.1.6-curl.patch b/Dockerfiles/data/php-5.1.6-curl.patch deleted file mode 100644 index e5dbab7..0000000 --- a/Dockerfiles/data/php-5.1.6-curl.patch +++ /dev/null @@ -1,51 +0,0 @@ ---- ext/dom/node.c 2012-08-06 17:49:48.826716692 +0800 -+++ ext/dom/node.c 2012-08-06 17:52:47.633484660 +0800 -@@ -1895,9 +1895,17 @@ static void dom_canonicalization(INTERNA - RETVAL_FALSE; - } else { - if (mode == 0) { -+#ifdef LIBXML2_NEW_BUFFER -+ ret = xmlOutputBufferGetSize(buf); -+#else - ret = buf->buffer->use; -+#endif - if (ret > 0) { -+#ifdef LIBXML2_NEW_BUFFER -+ RETVAL_STRINGL((char *) xmlOutputBufferGetContent(buf), ret, 1); -+#else - RETVAL_STRINGL((char *) buf->buffer->content, ret, 1); -+#endif - } else { - RETVAL_EMPTY_STRING(); - } ---- ext/dom/documenttype.c 2012-08-06 18:02:16.019640870 +0800 -+++ ext/dom/documenttype.c 2012-08-06 18:06:16.612228905 +0800 -@@ -205,7 +205,13 @@ int dom_documenttype_internal_subset_rea - if (buff != NULL) { - xmlNodeDumpOutput (buff, NULL, (xmlNodePtr) intsubset, 0, 0, NULL); - xmlOutputBufferFlush(buff); -+ -+#ifdef LIBXML2_NEW_BUFFER -+ ZVAL_STRINGL(*retval, xmlOutputBufferGetContent(buff), -+ xmlOutputBufferGetSize(buff), 1); -+#else - ZVAL_STRINGL(*retval, buff->buffer->content, buff->buffer->use, 1); -+#endif - (void)xmlOutputBufferClose(buff); - return SUCCESS; - } ---- ext/simplexml/simplexml.c 2012-08-06 18:10:44.621017026 +0800 -+++ ext/simplexml/simplexml.c 2012-08-06 18:12:48.016270419 +0800 -@@ -1417,7 +1417,12 @@ SXE_METHOD(asXML) - - xmlNodeDumpOutput(outbuf, (xmlDocPtr) sxe->document->ptr, node, 0, 0, ((xmlDocPtr) sxe->document->ptr)->encoding); - xmlOutputBufferFlush(outbuf); -+#ifdef LIBXML2_NEW_BUFFER -+ RETVAL_STRINGL((char *)xmlOutputBufferGetContent(outbuf), -+ xmlOutputBufferGetSize(outbuf), 1); -+#else - RETVAL_STRINGL((char *)outbuf->buffer->content, outbuf->buffer->use, 1); -+#endif - xmlOutputBufferClose(outbuf); - } - } else { diff --git a/Dockerfiles/data/php-5.1.6-fpm.patch b/Dockerfiles/data/php-5.1.6-fpm.patch deleted file mode 100644 index affc39f..0000000 --- a/Dockerfiles/data/php-5.1.6-fpm.patch +++ /dev/null @@ -1,33857 +0,0 @@ -diff --git a/configure b/configure -index 2d88ed7..c490abf 100755 ---- a/configure -+++ b/configure -@@ -773,6 +773,17 @@ ac_help="$ac_help - --disable-path-info-check CGI: If this is disabled, paths such as - /info.php/test?a=b will fail to work" - ac_help="$ac_help -+ --enable-fpm FastCGI: If this is enabled, the fastcgi support -+ will include experimental process manager code" -+ac_help="$ac_help -+ --with-fpm-conf=PATH Set the path for php-fpm configuration file [PREFIX/etc/php-fpm.conf]" -+ac_help="$ac_help -+ --with-fpm-log=PATH Set the path for php-fpm log file [PREFIX/logs/php-fpm.log]" -+ac_help="$ac_help -+ --with-fpm-pid=PATH Set the path for php-fpm pid file [PREFIX/logs/php-fpm.pid]" -+ac_help="$ac_help -+ --with-xml-config=PATH FPM: use xml-config in PATH to find libxml" -+ac_help="$ac_help - - General settings: - " -@@ -12153,11 +12164,30 @@ ext_output=$PHP_PATH_INFO_CHECK - - - -+php_enable_fpm=no -+ -+ -+# Check whether --enable-fpm or --disable-fpm was given. -+if test "${enable_fpm+set}" = set; then -+ enableval="$enable_fpm" -+ PHP_FPM=$enableval -+else -+ -+ PHP_FPM=no -+ -+ if test "$PHP_ENABLE_ALL" && test "no" = "yes"; then -+ PHP_FPM=$PHP_ENABLE_ALL -+ fi -+ -+fi -+ -+ -+ext_output=$PHP_FPM - - - if test "$PHP_SAPI" = "default"; then - echo $ac_n "checking whether to build CGI binary""... $ac_c" 1>&6 --echo "configure:12161: checking whether to build CGI binary" >&5 -+echo "configure:12435: checking whether to build CGI binary" >&5 - if test "$PHP_CGI" != "no"; then - echo "$ac_t""yes" 1>&6 - -@@ -12194,8 +12224,25 @@ EOF - - echo "$ac_t""$PHP_FASTCGI" 1>&6 - -+ if test "$PHP_FASTCGI" = "yes"; then -+ echo $ac_n "checking whether to enable FastCGI Process Manager""... $ac_c" 1>&6 -+echo "configure:12474: checking whether to enable FastCGI Process Manager" >&5 -+ if test "$PHP_FPM" = "yes"; then -+ PHP_FASTCGI_PM=1 -+ else -+ PHP_FASTCGI_PM=0 -+ fi -+ echo "$ac_t""$PHP_FPM" 1>&6 -+ else -+ PHP_FASTCGI_PM=0 -+ fi -+ cat >> confdefs.h <&6 --echo "configure:12199: checking whether to force Apache CGI redirect" >&5 -+echo "configure:12490: checking whether to force Apache CGI redirect" >&5 - if test "$PHP_FORCE_CGI_REDIRECT" = "yes"; then - CGI_REDIRECT=1 - else -@@ -12410,10 +12457,10 @@ EOF - BUILD_CGI="echo '\#! .' > php.sym && echo >>php.sym && nm -BCpg \`echo \$(PHP_GLOBAL_OBJS) \$(PHP_SAPI_OBJS) | sed 's/\([A-Za-z0-9_]*\)\.lo/\1.o/g'\` | \$(AWK) '{ if (((\$\$2 == \"T\") || (\$\$2 == \"D\") || (\$\$2 == \"B\")) && (substr(\$\$3,1,1) != \".\")) { print \$\$3 } }' | sort -u >> php.sym && \$(LIBTOOL) --mode=link \$(CC) -export-dynamic \$(CFLAGS_CLEAN) \$(EXTRA_CFLAGS) \$(EXTRA_LDFLAGS_PROGRAM) \$(LDFLAGS) -Wl,-brtl -Wl,-bE:php.sym \$(PHP_RPATHS) \$(PHP_GLOBAL_OBJS) \$(PHP_SAPI_OBJS) \$(EXTRA_LIBS) \$(ZEND_EXTRA_LIBS) -o \$(SAPI_CGI_PATH)" - ;; - *darwin*) -- BUILD_CGI="\$(CC) \$(CFLAGS_CLEAN) \$(EXTRA_CFLAGS) \$(EXTRA_LDFLAGS_PROGRAM) \$(LDFLAGS) \$(NATIVE_RPATHS) \$(PHP_GLOBAL_OBJS:.lo=.o) \$(PHP_SAPI_OBJS:.lo=.o) \$(PHP_FRAMEWORKS) \$(EXTRA_LIBS) \$(ZEND_EXTRA_LIBS) -o \$(SAPI_CGI_PATH)" -+ BUILD_CGI="\$(CC) \$(CFLAGS_CLEAN) \$(EXTRA_CFLAGS) \$(EXTRA_LDFLAGS_PROGRAM) \$(LDFLAGS) \$(NATIVE_RPATHS) \$(PHP_GLOBAL_OBJS:.lo=.o) \$(PHP_SAPI_OBJS:.lo=.o) \$(PHP_FRAMEWORKS) \$(EXTRA_LIBS) \$(SAPI_EXTRA_LIBS) \$(ZEND_EXTRA_LIBS) -o \$(SAPI_CGI_PATH)" - ;; - *) -- BUILD_CGI="\$(LIBTOOL) --mode=link \$(CC) -export-dynamic \$(CFLAGS_CLEAN) \$(EXTRA_CFLAGS) \$(EXTRA_LDFLAGS_PROGRAM) \$(LDFLAGS) \$(PHP_RPATHS) \$(PHP_GLOBAL_OBJS) \$(PHP_SAPI_OBJS) \$(EXTRA_LIBS) \$(ZEND_EXTRA_LIBS) -o \$(SAPI_CGI_PATH)" -+ BUILD_CGI="\$(LIBTOOL) --mode=link \$(CC) -export-dynamic \$(CFLAGS_CLEAN) \$(EXTRA_CFLAGS) \$(EXTRA_LDFLAGS_PROGRAM) \$(LDFLAGS) \$(PHP_RPATHS) \$(PHP_GLOBAL_OBJS) \$(PHP_SAPI_OBJS) \$(EXTRA_LIBS) \$(SAPI_EXTRA_LIBS) \$(ZEND_EXTRA_LIBS) -o \$(SAPI_CGI_PATH)" - ;; - esac - -@@ -12476,6 +12523,875 @@ fi - - fi - -+if test "$PHP_FASTCGI" = "yes" -a "$PHP_FPM" = "yes"; then -+ -+ echo "$ac_t""" 1>&6 -+ echo "$ac_t""${T_MD}Running FastCGI Process Manager checks${T_ME}" 1>&6 -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+FPM_VERSION="0.5.14" -+ -+ -+php_with_fpm_conf=\$prefix/etc/php-fpm.conf -+ -+echo $ac_n "checking for php-fpm config file path""... $ac_c" 1>&6 -+echo "configure:12798: checking for php-fpm config file path" >&5 -+# Check whether --with-fpm-conf or --without-fpm-conf was given. -+if test "${with_fpm_conf+set}" = set; then -+ withval="$with_fpm_conf" -+ PHP_FPM_CONF=$withval -+else -+ -+ PHP_FPM_CONF=\$prefix/etc/php-fpm.conf -+ -+ if test "$PHP_ENABLE_ALL" && test "no" = "yes"; then -+ PHP_FPM_CONF=$PHP_ENABLE_ALL -+ fi -+ -+fi -+ -+ -+ext_output=$PHP_FPM_CONF -+echo "$ac_t""$ext_output" 1>&6 -+ -+ -+ -+ -+ -+php_with_fpm_log=\$prefix/logs/php-fpm.log -+ -+echo $ac_n "checking for php-fpm log file path""... $ac_c" 1>&6 -+echo "configure:12824: checking for php-fpm log file path" >&5 -+# Check whether --with-fpm-log or --without-fpm-log was given. -+if test "${with_fpm_log+set}" = set; then -+ withval="$with_fpm_log" -+ PHP_FPM_LOG=$withval -+else -+ -+ PHP_FPM_LOG=\$prefix/logs/php-fpm.log -+ -+ if test "$PHP_ENABLE_ALL" && test "no" = "yes"; then -+ PHP_FPM_LOG=$PHP_ENABLE_ALL -+ fi -+ -+fi -+ -+ -+ext_output=$PHP_FPM_LOG -+echo "$ac_t""$ext_output" 1>&6 -+ -+ -+ -+ -+ -+php_with_fpm_pid=\$prefix/logs/php-fpm.pid -+ -+echo $ac_n "checking for php-fpm pid file path""... $ac_c" 1>&6 -+echo "configure:12850: checking for php-fpm pid file path" >&5 -+# Check whether --with-fpm-pid or --without-fpm-pid was given. -+if test "${with_fpm_pid+set}" = set; then -+ withval="$with_fpm_pid" -+ PHP_FPM_PID=$withval -+else -+ -+ PHP_FPM_PID=\$prefix/logs/php-fpm.pid -+ -+ if test "$PHP_ENABLE_ALL" && test "no" = "yes"; then -+ PHP_FPM_PID=$PHP_ENABLE_ALL -+ fi -+ -+fi -+ -+ -+ext_output=$PHP_FPM_PID -+echo "$ac_t""$ext_output" 1>&6 -+ -+ -+ -+ -+FPM_SOURCES="fpm.c \ -+ fpm_conf.c \ -+ fpm_signals.c \ -+ fpm_children.c \ -+ fpm_worker_pool.c \ -+ fpm_unix.c \ -+ fpm_cleanup.c \ -+ fpm_sockets.c \ -+ fpm_stdio.c \ -+ fpm_env.c \ -+ fpm_events.c \ -+ fpm_php.c \ -+ fpm_php_trace.c \ -+ fpm_process_ctl.c \ -+ fpm_request.c \ -+ fpm_clock.c \ -+ fpm_shm.c \ -+ fpm_shm_slots.c \ -+ xml_config.c \ -+ zlog.c" -+ -+ -+ echo "$ac_t""checking for XML configuration" 1>&6 -+ -+ # Check whether --with-xml-config or --without-xml-config was given. -+if test "${with_xml_config+set}" = set; then -+ withval="$with_xml_config" -+ XMLCONFIG="$withval" -+else -+ for ac_prog in xml2-config xml-config -+do -+# Extract the first word of "$ac_prog", so it can be a program name with args. -+set dummy $ac_prog; ac_word=$2 -+echo $ac_n "checking for $ac_word""... $ac_c" 1>&6 -+echo "configure:12906: checking for $ac_word" >&5 -+if eval "test \"`echo '$''{'ac_cv_path_XMLCONFIG'+set}'`\" = set"; then -+ echo $ac_n "(cached) $ac_c" 1>&6 -+else -+ case "$XMLCONFIG" in -+ /*) -+ ac_cv_path_XMLCONFIG="$XMLCONFIG" # Let the user override the test with a path. -+ ;; -+ ?:/*) -+ ac_cv_path_XMLCONFIG="$XMLCONFIG" # Let the user override the test with a dos path. -+ ;; -+ *) -+ IFS="${IFS= }"; ac_save_ifs="$IFS"; IFS=":" -+ ac_dummy="$PATH" -+ for ac_dir in $ac_dummy; do -+ test -z "$ac_dir" && ac_dir=. -+ if test -f $ac_dir/$ac_word; then -+ ac_cv_path_XMLCONFIG="$ac_dir/$ac_word" -+ break -+ fi -+ done -+ IFS="$ac_save_ifs" -+ ;; -+esac -+fi -+XMLCONFIG="$ac_cv_path_XMLCONFIG" -+if test -n "$XMLCONFIG"; then -+ echo "$ac_t""$XMLCONFIG" 1>&6 -+else -+ echo "$ac_t""no" 1>&6 -+fi -+ -+test -n "$XMLCONFIG" && break -+done -+test -n "$XMLCONFIG" || XMLCONFIG="""" -+ -+ -+fi -+ -+ -+ if test "x$XMLCONFIG" = "x"; then -+ { echo "configure: error: XML configuration could not be found" 1>&2; exit 1; } -+ else -+ echo $ac_n "checking for libxml library""... $ac_c" 1>&6 -+echo "configure:12950: checking for libxml library" >&5 -+ -+ if test ! -x "$XMLCONFIG"; then -+ { echo "configure: error: $XMLCONFIG cannot be executed" 1>&2; exit 1; } -+ fi -+ -+ LIBXML_LIBS="`$XMLCONFIG --libs`" -+ LIBXML_CFLAGS="`$XMLCONFIG --cflags`" -+ LIBXML_VERSION="`$XMLCONFIG --version`" -+ -+ echo "$ac_t""yes, $LIBXML_VERSION" 1>&6 -+ -+ -+ SAVED_CFLAGS="$CFLAGS" -+ CFLAGS="$CFLAGS $LIBXML_CFLAGS" -+ SAVED_LIBS="$LIBS" -+ LIBS="$LIBS $LIBXML_LIBS" -+ -+ echo $ac_n "checking for xmlParseFile""... $ac_c" 1>&6 -+echo "configure:12969: checking for xmlParseFile" >&5 -+if eval "test \"`echo '$''{'ac_cv_func_xmlParseFile'+set}'`\" = set"; then -+ echo $ac_n "(cached) $ac_c" 1>&6 -+else -+ cat > conftest.$ac_ext < -+/* Override any gcc2 internal prototype to avoid an error. */ -+/* We use char because int might match the return type of a gcc2 -+ builtin and then its argument prototype would still apply. */ -+char xmlParseFile(); -+ -+int main() { -+ -+/* The GNU C library defines this for functions which it implements -+ to always fail with ENOSYS. Some functions are actually named -+ something starting with __ and the normal name is an alias. */ -+#if defined (__stub_xmlParseFile) || defined (__stub___xmlParseFile) -+choke me -+#else -+xmlParseFile(); -+#endif -+ -+; return 0; } -+EOF -+if { (eval echo configure:12997: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then -+ rm -rf conftest* -+ eval "ac_cv_func_xmlParseFile=yes" -+else -+ echo "configure: failed program was:" >&5 -+ cat conftest.$ac_ext >&5 -+ rm -rf conftest* -+ eval "ac_cv_func_xmlParseFile=no" -+fi -+rm -f conftest* -+fi -+ -+if eval "test \"`echo '$ac_cv_func_'xmlParseFile`\" = yes"; then -+ echo "$ac_t""yes" 1>&6 -+ : -+else -+ echo "$ac_t""no" 1>&6 -+{ echo "configure: error: Failed to link with libxml" 1>&2; exit 1; } -+fi -+ -+ -+ CFLAGS="$SAVED_CFLAGS" -+ LIBS="$SAVED_LIBS" -+ -+ -+ cat >> confdefs.h <<\EOF -+#define HAVE_LIBXML 1 -+EOF -+ -+ fi -+ -+ -+ echo $ac_n "checking for prctl""... $ac_c" 1>&6 -+echo "configure:13030: checking for prctl" >&5 -+ -+ cat > conftest.$ac_ext < -+int main() { -+prctl(0, 0, 0, 0, 0); -+; return 0; } -+EOF -+if { (eval echo configure:13040: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then -+ rm -rf conftest* -+ -+ cat >> confdefs.h <<\EOF -+#define HAVE_PRCTL 1 -+EOF -+ -+ echo "$ac_t""yes" 1>&6 -+ -+else -+ echo "configure: failed program was:" >&5 -+ cat conftest.$ac_ext >&5 -+ rm -rf conftest* -+ -+ echo "$ac_t""no" 1>&6 -+ -+fi -+rm -f conftest* -+ -+ -+ have_clock_gettime=no -+ -+ echo $ac_n "checking for clock_gettime""... $ac_c" 1>&6 -+echo "configure:13063: checking for clock_gettime" >&5 -+ -+ cat > conftest.$ac_ext < -+int main() { -+struct timespec ts; clock_gettime(CLOCK_MONOTONIC, &ts); -+; return 0; } -+EOF -+if { (eval echo configure:13073: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then -+ rm -rf conftest* -+ -+ have_clock_gettime=yes -+ echo "$ac_t""yes" 1>&6 -+ -+else -+ echo "configure: failed program was:" >&5 -+ cat conftest.$ac_ext >&5 -+ rm -rf conftest* -+ -+ echo "$ac_t""no" 1>&6 -+ -+fi -+rm -f conftest* -+ -+ if test "$have_clock_gettime" = "no"; then -+ echo $ac_n "checking for clock_gettime in -lrt""... $ac_c" 1>&6 -+echo "configure:13091: checking for clock_gettime in -lrt" >&5 -+ -+ SAVED_LIBS="$LIBS" -+ LIBS="$LIBS -lrt" -+ -+ cat > conftest.$ac_ext < -+int main() { -+struct timespec ts; clock_gettime(CLOCK_MONOTONIC, &ts); -+; return 0; } -+EOF -+if { (eval echo configure:13104: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then -+ rm -rf conftest* -+ -+ have_clock_gettime=yes -+ echo "$ac_t""yes" 1>&6 -+ -+else -+ echo "configure: failed program was:" >&5 -+ cat conftest.$ac_ext >&5 -+ rm -rf conftest* -+ -+ LIBS="$SAVED_LIBS" -+ echo "$ac_t""no" 1>&6 -+ -+fi -+rm -f conftest* -+ fi -+ -+ if test "$have_clock_gettime" = "yes"; then -+ cat >> confdefs.h <<\EOF -+#define HAVE_CLOCK_GETTIME 1 -+EOF -+ -+ fi -+ -+ have_clock_get_time=no -+ -+ if test "$have_clock_gettime" = "no"; then -+ echo $ac_n "checking for clock_get_time""... $ac_c" 1>&6 -+echo "configure:13133: checking for clock_get_time" >&5 -+ -+ if test "$cross_compiling" = yes; then -+ { echo "configure: error: can not run test program while cross compiling" 1>&2; exit 1; } -+else -+ cat > conftest.$ac_ext < -+ #include -+ #include -+ -+ int main() -+ { -+ kern_return_t ret; clock_serv_t aClock; mach_timespec_t aTime; -+ ret = host_get_clock_service(mach_host_self(), REALTIME_CLOCK, &aClock); -+ -+ if (ret != KERN_SUCCESS) { -+ return 1; -+ } -+ -+ ret = clock_get_time(aClock, &aTime); -+ if (ret != KERN_SUCCESS) { -+ return 2; -+ } -+ -+ return 0; -+ } -+ -+EOF -+if { (eval echo configure:13163: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext} && (./conftest; exit) 2>/dev/null -+then -+ -+ have_clock_get_time=yes -+ echo "$ac_t""yes" 1>&6 -+ -+else -+ echo "configure: failed program was:" >&5 -+ cat conftest.$ac_ext >&5 -+ rm -fr conftest* -+ -+ echo "$ac_t""no" 1>&6 -+ -+fi -+rm -fr conftest* -+fi -+ -+ fi -+ -+ if test "$have_clock_get_time" = "yes"; then -+ cat >> confdefs.h <<\EOF -+#define HAVE_CLOCK_GET_TIME 1 -+EOF -+ -+ fi -+ -+ -+ have_ptrace=no -+ have_broken_ptrace=no -+ -+ echo $ac_n "checking for ptrace""... $ac_c" 1>&6 -+echo "configure:13194: checking for ptrace" >&5 -+ -+ cat > conftest.$ac_ext < -+ #include -+int main() { -+ptrace(0, 0, (void *) 0, 0); -+; return 0; } -+EOF -+if { (eval echo configure:13206: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then -+ rm -rf conftest* -+ -+ have_ptrace=yes -+ echo "$ac_t""yes" 1>&6 -+ -+else -+ echo "configure: failed program was:" >&5 -+ cat conftest.$ac_ext >&5 -+ rm -rf conftest* -+ -+ echo "$ac_t""no" 1>&6 -+ -+fi -+rm -f conftest* -+ -+ if test "$have_ptrace" = "yes"; then -+ echo $ac_n "checking whether ptrace works""... $ac_c" 1>&6 -+echo "configure:13224: checking whether ptrace works" >&5 -+ -+ if test "$cross_compiling" = yes; then -+ { echo "configure: error: can not run test program while cross compiling" 1>&2; exit 1; } -+else -+ cat > conftest.$ac_ext < -+ #include -+ #include -+ #include -+ #include -+ #include -+ -+ #if !defined(PTRACE_ATTACH) && defined(PT_ATTACH) -+ #define PTRACE_ATTACH PT_ATTACH -+ #endif -+ -+ #if !defined(PTRACE_DETACH) && defined(PT_DETACH) -+ #define PTRACE_DETACH PT_DETACH -+ #endif -+ -+ #if !defined(PTRACE_PEEKDATA) && defined(PT_READ_D) -+ #define PTRACE_PEEKDATA PT_READ_D -+ #endif -+ -+ int main() -+ { -+ long v1 = (unsigned int) -1; /* copy will fail if sizeof(long) == 8 and we've got "int ptrace()" */ -+ long v2; -+ pid_t child; -+ int status; -+ -+ if ( (child = fork()) ) { /* parent */ -+ int ret = 0; -+ -+ if (0 > ptrace(PTRACE_ATTACH, child, 0, 0)) { -+ return 1; -+ } -+ -+ waitpid(child, &status, 0); -+ -+ #ifdef PT_IO -+ struct ptrace_io_desc ptio = { -+ .piod_op = PIOD_READ_D, -+ .piod_offs = &v1, -+ .piod_addr = &v2, -+ .piod_len = sizeof(v1) -+ }; -+ -+ if (0 > ptrace(PT_IO, child, (void *) &ptio, 0)) { -+ ret = 1; -+ } -+ #else -+ errno = 0; -+ -+ v2 = ptrace(PTRACE_PEEKDATA, child, (void *) &v1, 0); -+ -+ if (errno) { -+ ret = 1; -+ } -+ #endif -+ ptrace(PTRACE_DETACH, child, (void *) 1, 0); -+ -+ kill(child, SIGKILL); -+ -+ return ret ? ret : (v1 != v2); -+ } -+ else { /* child */ -+ sleep(10); -+ return 0; -+ } -+ } -+ -+EOF -+if { (eval echo configure:13301: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext} && (./conftest; exit) 2>/dev/null -+then -+ -+ echo "$ac_t""yes" 1>&6 -+ -+else -+ echo "configure: failed program was:" >&5 -+ cat conftest.$ac_ext >&5 -+ rm -fr conftest* -+ -+ have_ptrace=no -+ have_broken_ptrace=yes -+ echo "$ac_t""no" 1>&6 -+ -+fi -+rm -fr conftest* -+fi -+ -+ fi -+ -+ if test "$have_ptrace" = "yes"; then -+ cat >> confdefs.h <<\EOF -+#define HAVE_PTRACE 1 -+EOF -+ -+ fi -+ -+ have_mach_vm_read=no -+ -+ if test "$have_broken_ptrace" = "yes"; then -+ echo $ac_n "checking for mach_vm_read""... $ac_c" 1>&6 -+echo "configure:13332: checking for mach_vm_read" >&5 -+ -+ cat > conftest.$ac_ext < -+ #include -+ -+int main() { -+ -+ mach_vm_read((vm_map_t)0, (mach_vm_address_t)0, (mach_vm_size_t)0, (vm_offset_t *)0, (mach_msg_type_number_t*)0); -+ -+; return 0; } -+EOF -+if { (eval echo configure:13346: \"$ac_compile\") 1>&5; (eval $ac_compile) 2>&5; }; then -+ rm -rf conftest* -+ -+ have_mach_vm_read=yes -+ echo "$ac_t""yes" 1>&6 -+ -+else -+ echo "configure: failed program was:" >&5 -+ cat conftest.$ac_ext >&5 -+ rm -rf conftest* -+ -+ echo "$ac_t""no" 1>&6 -+ -+fi -+rm -f conftest* -+ fi -+ -+ if test "$have_mach_vm_read" = "yes"; then -+ cat >> confdefs.h <<\EOF -+#define HAVE_MACH_VM_READ 1 -+EOF -+ -+ fi -+ -+ proc_mem_file="" -+ -+ if test -r /proc/$$/mem ; then -+ proc_mem_file="mem" -+ else -+ if test -r /proc/$$/as ; then -+ proc_mem_file="as" -+ fi -+ fi -+ -+ if test -n "$proc_mem_file" ; then -+ echo $ac_n "checking for proc mem file""... $ac_c" 1>&6 -+echo "configure:13382: checking for proc mem file" >&5 -+ -+ if test "$cross_compiling" = yes; then -+ { echo "configure: error: can not run test program while cross compiling" 1>&2; exit 1; } -+else -+ cat > conftest.$ac_ext < -+ #include -+ #include -+ #include -+ #include -+ #include -+ int main() -+ { -+ long v1 = (unsigned int) -1, v2 = 0; -+ char buf[128]; -+ int fd; -+ sprintf(buf, "/proc/%d/$proc_mem_file", getpid()); -+ fd = open(buf, O_RDONLY); -+ if (0 > fd) { -+ return 1; -+ } -+ if (sizeof(long) != pread(fd, &v2, sizeof(long), (uintptr_t) &v1)) { -+ close(fd); -+ return 1; -+ } -+ close(fd); -+ return v1 != v2; -+ } -+ -+EOF -+if { (eval echo configure:13418: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext} && (./conftest; exit) 2>/dev/null -+then -+ -+ echo "$ac_t""$proc_mem_file" 1>&6 -+ -+else -+ echo "configure: failed program was:" >&5 -+ cat conftest.$ac_ext >&5 -+ rm -fr conftest* -+ -+ proc_mem_file="" -+ echo "$ac_t""no" 1>&6 -+ -+fi -+rm -fr conftest* -+fi -+ -+ fi -+ -+ if test -n "$proc_mem_file"; then -+ cat >> confdefs.h <> Makefile.fragments -+ -+ -+ -+ -+ case sapi/cgi/fpm in -+ "") ac_srcdir="$abs_srcdir/"; unset ac_bdir; ac_inc="-I. -I$abs_srcdir" ;; -+ /*) ac_srcdir=`echo "sapi/cgi/fpm"|cut -c 2-`"/"; ac_bdir=$ac_srcdir; ac_inc="-I$ac_bdir -I$abs_srcdir/$ac_bdir" ;; -+ *) ac_srcdir="$abs_srcdir/sapi/cgi/fpm/"; ac_bdir="sapi/cgi/fpm/"; ac_inc="-I$ac_bdir -I$ac_srcdir" ;; -+ esac -+ -+ -+ -+ b_c_pre=$php_c_pre -+ b_cxx_pre=$php_cxx_pre -+ b_c_meta=$php_c_meta -+ b_cxx_meta=$php_cxx_meta -+ b_c_post=$php_c_post -+ b_cxx_post=$php_cxx_post -+ b_lo=$php_lo -+ -+ -+ old_IFS=$IFS -+ for ac_src in $FPM_SOURCES; do -+ -+ IFS=. -+ set $ac_src -+ ac_obj=$1 -+ IFS=$old_IFS -+ -+ PHP_SAPI_OBJS="$PHP_SAPI_OBJS $ac_bdir$ac_obj.lo" -+ -+ case $ac_src in -+ *.c) ac_comp="$b_c_pre $FPM_CFLAGS $ac_inc $b_c_meta -c $ac_srcdir$ac_src -o $ac_bdir$ac_obj.$b_lo $b_c_post" ;; -+ *.s) ac_comp="$b_c_pre $FPM_CFLAGS $ac_inc $b_c_meta -c $ac_srcdir$ac_src -o $ac_bdir$ac_obj.$b_lo $b_c_post" ;; -+ *.S) ac_comp="$b_c_pre $FPM_CFLAGS $ac_inc $b_c_meta -c $ac_srcdir$ac_src -o $ac_bdir$ac_obj.$b_lo $b_c_post" ;; -+ *.cpp|*.cc|*.cxx) ac_comp="$b_cxx_pre $FPM_CFLAGS $ac_inc $b_cxx_meta -c $ac_srcdir$ac_src -o $ac_bdir$ac_obj.$b_lo $b_cxx_post" ;; -+ esac -+ -+ cat >>Makefile.objects<&6 -+ echo "$ac_t""${T_MD}Configuring libevent${T_ME}" 1>&6 -+ -+ -+test -d "$abs_builddir/libevent" || mkdir -p $abs_builddir/libevent -+ -+ -+chmod +x "$abs_srcdir/libevent/configure" \ -+ "$abs_srcdir/libevent/depcomp" \ -+ "$abs_srcdir/libevent/install-sh" \ -+ "$abs_srcdir/libevent/missing" -+ -+libevent_configure="cd $abs_builddir/libevent ; CFLAGS=\"$CFLAGS $GCC_CFLAGS\" $abs_srcdir/libevent/configure --disable-shared" -+ -+(eval $libevent_configure) -+ -+if test ! -f "$abs_builddir/libevent/Makefile" ; then -+ echo "Failed to configure libevent" >&2 -+ exit 1 -+fi -+ -+ -+LIBEVENT_LIBS="$LIBEVENT_LIBS `echo "@LIBS@" | $abs_builddir/libevent/config.status --file=-:-`" -+ -+SAPI_EXTRA_LIBS="$LIBEVENT_LIBS $LIBXML_LIBS $JUDY_LIBS" -+ -+ -+if test "$prefix" = "NONE" ; then -+ fpm_prefix=/usr/local -+else -+ fpm_prefix="$prefix" -+fi -+ -+if test "$PHP_FPM_CONF" = "\$prefix/etc/php-fpm.conf" ; then -+ php_fpm_conf_path="$fpm_prefix/etc/php-fpm.conf" -+else -+ php_fpm_conf_path="$PHP_FPM_CONF" -+fi -+ -+if test "$PHP_FPM_LOG" = "\$prefix/logs/php-fpm.log" ; then -+ php_fpm_log_path="$fpm_prefix/logs/php-fpm.log" -+else -+ php_fpm_log_path="$PHP_FPM_LOG" -+fi -+ -+if test "$PHP_FPM_PID" = "\$prefix/logs/php-fpm.pid" ; then -+ php_fpm_pid_path="$fpm_prefix/logs/php-fpm.pid" -+else -+ php_fpm_pid_path="$PHP_FPM_PID" -+fi -+ -+ -+if grep nobody /etc/group >/dev/null 2>&1; then -+ php_fpm_group=nobody -+else -+ if grep nogroup /etc/group >/dev/null 2>&1; then -+ php_fpm_group=nogroup -+ else -+ php_fpm_group=nobody -+ fi -+fi -+ -+ -+ -+ PHP_VAR_SUBST="$PHP_VAR_SUBST php_fpm_conf_path" -+ -+ -+ -+ -+ -+ PHP_VAR_SUBST="$PHP_VAR_SUBST php_fpm_log_path" -+ -+ -+ -+ -+ -+ PHP_VAR_SUBST="$PHP_VAR_SUBST php_fpm_pid_path" -+ -+ -+ -+ -+ -+ PHP_VAR_SUBST="$PHP_VAR_SUBST php_fpm_group" -+ -+ -+ -+ -+ -+ PHP_VAR_SUBST="$PHP_VAR_SUBST FPM_VERSION" -+ -+ -+ -+ -+ -+ PHP_OUTPUT_FILES="$PHP_OUTPUT_FILES sapi/cgi/fpm/fpm_autoconf.h" -+ -+ -+ PHP_OUTPUT_FILES="$PHP_OUTPUT_FILES sapi/cgi/fpm/php-fpm.conf:sapi/cgi/fpm/conf/php-fpm.conf.in" -+ -+ -+ PHP_OUTPUT_FILES="$PHP_OUTPUT_FILES sapi/cgi/fpm/php-fpm:sapi/cgi/fpm/init.d/php-fpm.in" -+ -+ -+fi -+ - - - -@@ -17779,6 +18695,7 @@ fi - for ac_func in alphasort \ - asctime_r \ - chroot \ -+clearenv \ - ctime_r \ - cuserid \ - crypt \ -@@ -108404,6 +109321,18 @@ fi - - - -+ PHP_VAR_SUBST="$PHP_VAR_SUBST SAPI_EXTRA_LIBS" -+ -+ -+ -+ -+ -+ PHP_VAR_SUBST="$PHP_VAR_SUBST SAPI_EXTRA_DEPS" -+ -+ -+ -+ -+ - PHP_VAR_SUBST="$PHP_VAR_SUBST ZEND_EXTRA_LIBS" - - -@@ -116677,7 +117606,7 @@ case $PHP_SAPI in - install_targets="$PHP_INSTALL_CLI_TARGET $install_targets" - ;; - *) -- install_targets="install-sapi $PHP_INSTALL_CLI_TARGET $install_targets" -+ install_targets="install-sapi $install_fpm $PHP_INSTALL_CLI_TARGET $install_targets" - ;; - esac - -@@ -117381,6 +118310,12 @@ s%@LEX_OUTPUT_ROOT@%$LEX_OUTPUT_ROOT%g - s%@RE2C@%$RE2C%g - s%@SHLIB_SUFFIX_NAME@%$SHLIB_SUFFIX_NAME%g - s%@SHLIB_DL_SUFFIX_NAME@%$SHLIB_DL_SUFFIX_NAME%g -+s%@XMLCONFIG@%$XMLCONFIG%g -+s%@php_fpm_conf_path@%$php_fpm_conf_path%g -+s%@php_fpm_log_path@%$php_fpm_log_path%g -+s%@php_fpm_pid_path@%$php_fpm_pid_path%g -+s%@php_fpm_group@%$php_fpm_group%g -+s%@FPM_VERSION@%$FPM_VERSION%g - s%@PROG_SENDMAIL@%$PROG_SENDMAIL%g - s%@LIBOBJS@%$LIBOBJS%g - s%@ALLOCA@%$ALLOCA%g -@@ -117430,6 +118365,8 @@ s%@EXTENSION_DIR@%$EXTENSION_DIR%g - s%@EXTRA_LDFLAGS@%$EXTRA_LDFLAGS%g - s%@EXTRA_LDFLAGS_PROGRAM@%$EXTRA_LDFLAGS_PROGRAM%g - s%@EXTRA_LIBS@%$EXTRA_LIBS%g -+s%@SAPI_EXTRA_LIBS@%$SAPI_EXTRA_LIBS%g -+s%@SAPI_EXTRA_DEPS@%$SAPI_EXTRA_DEPS%g - s%@ZEND_EXTRA_LIBS@%$ZEND_EXTRA_LIBS%g - s%@INCLUDES@%$INCLUDES%g - s%@EXTRA_INCLUDES@%$EXTRA_INCLUDES%g -diff --git a/configure.in b/configure.in -index e181ac9..4424930 100644 ---- a/configure.in -+++ b/configure.in -@@ -295,6 +295,12 @@ if test "$enable_maintainer_zts" = "yes"; then - PTHREADS_FLAGS - fi - -+if test "$PHP_FASTCGI" = "yes" -a "$PHP_FPM" = "yes"; then -+ PHP_CONFIGURE_PART(Running FastCGI Process Manager checks) -+ sinclude(sapi/cgi/fpm/acinclude.m4) -+ sinclude(sapi/cgi/fpm/config.m4) -+fi -+ - divert(3) - - dnl ## In diversion 3 we check for compile-time options to the PHP -@@ -511,6 +517,7 @@ AC_CHECK_FUNCS( - alphasort \ - asctime_r \ - chroot \ -+clearenv \ - ctime_r \ - cuserid \ - crypt \ -@@ -1253,6 +1260,8 @@ PHP_SUBST_OLD(EXTENSION_DIR) - PHP_SUBST_OLD(EXTRA_LDFLAGS) - PHP_SUBST_OLD(EXTRA_LDFLAGS_PROGRAM) - PHP_SUBST_OLD(EXTRA_LIBS) -+PHP_SUBST_OLD(SAPI_EXTRA_LIBS) -+PHP_SUBST_OLD(SAPI_EXTRA_DEPS) - PHP_SUBST_OLD(ZEND_EXTRA_LIBS) - PHP_SUBST_OLD(INCLUDES) - PHP_SUBST_OLD(EXTRA_INCLUDES) -@@ -1364,7 +1373,7 @@ case $PHP_SAPI in - install_targets="$PHP_INSTALL_CLI_TARGET $install_targets" - ;; - *) -- install_targets="install-sapi $PHP_INSTALL_CLI_TARGET $install_targets" -+ install_targets="install-sapi $install_fpm $PHP_INSTALL_CLI_TARGET $install_targets" - ;; - esac - -diff --git a/libevent/ChangeLog b/libevent/ChangeLog -new file mode 100644 -index 0000000..c592139 ---- /dev/null -+++ b/libevent/ChangeLog -@@ -0,0 +1,154 @@ -+Changes in 1.4.8-stable: -+ o Match the query in DNS replies to the query in the request; from Vsevolod Stakhov. -+ o Fix a merge problem in which name_from_addr returned pointers to the stack; found by Jiang Hong. -+ o Do not remove Accept-Encoding header -+ -+Changes in 1.4.7-stable: -+ o Fix a bug where headers arriving in multiple packets were not parsed; fix from Jiang Hong; test by me. -+ -+Changes in 1.4.6-stable: -+ o evutil.h now includes directly -+ o switch all uses of [v]snprintf over to evutil -+ o Correct handling of trailing headers in chunked replies; from Scott Lamb. -+ o Support multi-line HTTP headers; based on a patch from Moshe Litvin -+ o Reject negative Content-Length headers; anonymous bug report -+ o Detect CLOCK_MONOTONIC at runtime for evdns; anonymous bug report -+ o Fix a bug where deleting signals with the kqueue backend would cause subsequent adds to fail -+ o Support multiple events listening on the same signal; make signals regular events that go on the same event queue; problem report by Alexander Drozdov. -+ o Deal with evbuffer_read() returning -1 on EINTR|EAGAIN; from Adam Langley. -+ o Fix a bug in which the DNS server would incorrectly set the type of a cname reply to a. -+ o Fix a bug where setting the timeout on a bufferevent would take not effect if the event was already pending. -+ o Fix a memory leak when using signals for some event bases; reported by Alexander Drozdov. -+ o Add libevent.vcproj file to distribution to help with Windows build. -+ o Fix a problem with epoll() and reinit; problem report by Alexander Drozdov. -+ o Fix off-by-one errors in devpoll; from Ian Bell -+ o Make event_add not change any state if it fails; reported by Ian Bell. -+ o Do not warn on accept when errno is either EAGAIN or EINTR -+ -+Changes in 1.4.5-stable: -+ o Fix connection keep-alive behavior for HTTP/1.0 -+ o Fix use of freed memory in event_reinit; pointed out by Peter Postma -+ o Constify struct timeval * where possible; pointed out by Forest Wilkinson -+ o allow min_heap_erase to be called on removed members; from liusifan. -+ o Rename INPUT and OUTPUT to EVRPC_INPUT and EVRPC_OUTPUT. Retain INPUT/OUTPUT aliases on on-win32 platforms for backwards compatibility. -+ o Do not use SO_REUSEADDR when connecting -+ o Fix Windows build -+ o Fix a bug in event_rpcgen when generated fixed-sized entries -+ -+Changes in 1.4.4-stable: -+ o Correct the documentation on buffer printf functions. -+ o Don't warn on unimplemented epoll_create(): this isn't a problem, just a reason to fall back to poll or select. -+ o Correctly handle timeouts larger than 35 minutes on Linux with epoll.c. This is probably a kernel defect, but we'll have to support old kernels anyway even if it gets fixed. -+ o Fix a potential stack corruption bug in tagging on 64-bit CPUs. -+ o expose bufferevent_setwatermark via header files and fix high watermark on read -+ o fix a bug in bufferevent read water marks and add a test for them -+ o introduce bufferevent_setcb and bufferevent_setfd to allow better manipulation of bufferevents -+ o use libevent's internal timercmp on all platforms, to avoid bugs on old platforms where timercmp(a,b,<=) is buggy. -+ o reduce system calls for getting current time by caching it. -+ o fix evhttp_bind_socket() so that multiple sockets can be bound by the same http server. -+ o Build test directory correctly with CPPFLAGS set. -+ o Fix build under Visual C++ 2005. -+ o Expose evhttp_accept_socket() API. -+ o Merge windows gettimeofday() replacement into a new evutil_gettimeofday() function. -+ o Fix autoconf script behavior on IRIX. -+ o Make sure winsock2.h include always comes before windows.h include. -+ -+ -+Changes in 1.4.3-stable: -+ o include Content-Length in reply for HTTP/1.0 requests with keep-alive -+ o Patch from Tani Hosokawa: make some functions in http.c threadsafe. -+ o Do not free the kqop file descriptor in other processes, also allow it to be 0; from Andrei Nigmatulin -+ o make event_rpcgen.py generate code include event-config.h; reported by Sam Banks. -+ o make event methods static so that they are not exported; from Andrei Nigmatulin -+ o make RPC replies use application/octet-stream as mime type -+ o do not delete uninitialized timeout event in evdns -+ -+Changes in 1.4.2-rc: -+ o remove pending timeouts on event_base_free() -+ o also check EAGAIN for Solaris' event ports; from W.C.A. Wijngaards -+ o devpoll and evport need reinit; tested by W.C.A Wijngaards -+ o event_base_get_method; from Springande Ulv -+ o Send CRLF after each chunk in HTTP output, for compliance with RFC2626. Patch from "propanbutan". Fixes bug 1894184. -+ o Add a int64_t parsing function, with unit tests, so we can apply Scott Lamb's fix to allow large HTTP values. -+ o Use a 64-bit field to hold HTTP content-lengths. Patch from Scott Lamb. -+ o Allow regression code to build even without Python installed -+ o remove NDEBUG ifdefs from evdns.c -+ o update documentation of event_loop and event_base_loop; from Tani Hosokawa. -+ o detect integer types properly on platforms without stdint.h -+ o Remove "AM_MAINTAINER_MODE" declaration in configure.in: now makefiles and configure should get re-generated automatically when Makefile.am or configure.in chanes. -+ o do not insert event into list when evsel->add fails -+ -+Changes in 1.4.1-beta: -+ o free minheap on event_base_free(); from Christopher Layne -+ o debug cleanups in signal.c; from Christopher Layne -+ o provide event_base_new() that does not set the current_base global -+ o bufferevent_write now uses a const source argument; report from Charles Kerr -+ o better documentation for event_base_loopexit; from Scott Lamb. -+ o Make kqueue have the same behavior as other backends when a signal is caught between event_add() and event_loop(). Previously, it would catch and ignore such signals. -+ o Make kqueue restore signal handlers correctly when event_del() is called. -+ o provide event_reinit() to reintialize an event_base after fork -+ o small improvements to evhttp documentation -+ o always generate Date and Content-Length headers for HTTP/1.1 replies -+ o set the correct event base for HTTP close events -+ o New function, event_{base_}loopbreak. Like event_loopexit, it makes an event loop stop executing and return. Unlike event_loopexit, it keeps subsequent pending events from getting executed. Patch from Scott Lamb -+ o Removed obsoleted recalc code -+ o pull setters/getters out of RPC structures into a base class to which we just need to store a pointer; this reduces the memory footprint of these structures. -+ o fix a bug with event_rpcgen for integers -+ o move EV_PERSIST handling out of the event backends -+ o support for 32-bit tag numbers in rpc structures; this is wire compatible, but changes the API slightly. -+ o prefix {encode,decode}_tag functions with evtag to avoid collisions -+ o Correctly handle DNS replies with no answers set (Fixes bug 1846282) -+ o The configure script now takes an --enable-gcc-warnigns option that turns on many optional gcc warnings. (Nick has been building with these for a while, but they might be useful to other developers.) -+ o When building with GCC, use the "format" attribute to verify type correctness of calls to printf-like functions. -+ o removed linger from http server socket; reported by Ilya Martynov -+ o allow \r or \n individually to separate HTTP headers instead of the standard "\r\n"; from Charles Kerr. -+ o demote most http warnings to debug messages -+ o Fix Solaris compilation; from Magne Mahre -+ o Add a "Date" header to HTTP responses, as required by HTTP 1.1. -+ o Support specifying the local address of an evhttp_connection using set_local_address -+ o Fix a memory leak in which failed HTTP connections would not free the request object -+ o Make adding of array members in event_rpcgen more efficient, but doubling memory allocation -+ o Fix a memory leak in the DNS server -+ o Fix compilation when DNS_USE_OPENSSL_FOR_ID is enabled -+ o Fix buffer size and string generation in evdns_resolve_reverse_ipv6(). -+ o Respond to nonstandard DNS queries with "NOTIMPL" rather than by ignoring them. -+ o In DNS responses, the CD flag should be preserved, not the TC flag. -+ o Fix http.c to compile properly with USE_DEBUG; from Christopher Layne -+ o Handle NULL timeouts correctly on Solaris; from Trond Norbye -+ o Recalculate pending events properly when reallocating event array on Solaris; from Trond Norbye -+ o Add Doxygen documentation to header files; from Mark Heily -+ o Add a evdns_set_transaction_id_fn() function to override the default -+ transaction ID generation code. -+ o Add an evutil module (with header evutil.h) to implement our standard cross-platform hacks, on the theory that somebody else would like to use them too. -+ o Fix signals implementation on windows. -+ o Fix http module on windows to close sockets properly. -+ o Make autogen.sh script run correctly on systems where /bin/sh isn't bash. (Patch from Trond Norbye, rewritten by Hagne Mahre and then Hannah Schroeter.) -+ o Skip calling gettime() in timeout_process if we are not in fact waiting for any events. (Patch from Trond Norbye) -+ o Make test subdirectory compile under mingw. -+ o Fix win32 buffer.c behavior so that it is correct for sockets (which do not like ReadFile and WriteFile). -+ o Make the test.sh script run unit tests for the evpoll method. -+ o Make the entire evdns.h header enclosed in "extern C" as appropriate. -+ o Fix implementation of strsep on platforms that lack it -+ o Fix implementation of getaddrinfo on platforms that lack it; mainly, this will make Windows http.c work better. Original patch by Lubomir Marinov. -+ o Fix evport implementation: port_disassociate called on unassociated events resulting in bogus errors; more efficient memory management; from Trond Norbye and Prakash Sangappa -+ o support for hooks on rpc input and output; can be used to implement rpc independent processing such as compression or authentication. -+ o use a min heap instead of a red-black tree for timeouts; as a result finding the min is a O(1) operation now; from Maxim Yegorushkin -+ o associate an event base with an rpc pool -+ o added two additional libraries: libevent_core and libevent_extra in addition to the regular libevent. libevent_core contains only the event core whereas libevent_extra contains dns, http and rpc support -+ o Begin using libtool's library versioning support correctly. If we don't mess up, this will more or less guarantee binaries linked against old versions of libevent continue working when we make changes to libevent that do not break backward compatibility. -+ o Fix evhttp.h compilation when TAILQ_ENTRY is not defined. -+ o Small code cleanups in epoll_dispatch(). -+ o Increase the maximum number of addresses read from a packet in evdns to 32. -+ o Remove support for the rtsig method: it hasn't compiled for a while, and nobody seems to miss it very much. Let us know if there's a good reason to put it back in. -+ o Rename the "class" field in evdns_server_request to dns_question_class, so that it won't break compilation under C++. Use a macro so that old code won't break. Mark the macro as deprecated. -+ o Fix DNS unit tests so that having a DNS server with broken IPv6 support is no longer cause for aborting the unit tests. -+ o Make event_base_free() succeed even if there are pending non-internal events on a base. This may still leak memory and fds, but at least it no longer crashes. -+ o Post-process the config.h file into a new, installed event-config.h file that we can install, and whose macros will be safe to include in header files. -+ o Remove the long-deprecated acconfig.h file. -+ o Do not require #include before #include . -+ o Add new evutil_timer* functions to wrap (or replace) the regular timeval manipulation functions. -+ o Fix many build issues when using the Microsoft C compiler. -+ o Remove a bash-ism in autogen.sh -+ o When calling event_del on a signal, restore the signal handler's previous value rather than setting it to SIG_DFL. Patch from Christopher Layne. -+ o Make the logic for active events work better with internal events; patch from Christopher Layne. -+ o We do not need to specially remove a timeout before calling event_del; patch from Christopher Layne. -diff --git a/libevent/Makefile.am b/libevent/Makefile.am -new file mode 100644 -index 0000000..5ccfd2c ---- /dev/null -+++ b/libevent/Makefile.am -@@ -0,0 +1,62 @@ -+ -+ -+# This is the point release for libevent. It shouldn't include any -+# a/b/c/d/e notations. -+RELEASE = 1.4 -+ -+# This is the version info for the libevent binary API. It has three -+# numbers: -+# Current -- the number of the binary API that we're implementing -+# Revision -- which iteration of the implementation of the binary -+# API are we supplying? -+# Age -- How many previous binary API versions do we also -+# support? -+# -+# If we release a new version that does not change the binary API, -+# increment Revision. -+# -+# If we release a new version that changes the binary API, but does -+# not break programs compiled against the old binary API, increment -+# Current and Age. Set Revision to 0, since this is the first -+# implementation of the new API. -+# -+# Otherwise, we're changing the binary API and breaking bakward -+# compatibility with old binaries. Increment Current. Set Age to 0, -+# since we're backward compatible with no previous APIs. Set Revision -+# to 0 too. -+ -+# History: -+# Libevent 1.4.1 was 2:0:0 -+# Libevent 1.4.2 should be 3:0:0 -+# Libevent 1.4.5 is 3:0:1 (we forgot to increment in the past) -+VERSION_INFO = 3:2:1 -+ -+noinst_LIBRARIES = libevent.a -+ -+ -+ -+BUILT_SOURCES = event-config.h -+ -+event-config.h: config.h -+ echo '/* event-config.h' > $@ -+ echo ' * Generated by autoconf; post-processed by libevent.' >> $@ -+ echo ' * Do not edit this file.' >> $@ -+ echo ' * Do not rely on macros in this file existing in later versions.'>> $@ -+ echo ' */' >> $@ -+ echo '#ifndef _EVENT_CONFIG_H_' >> $@ -+ echo '#define _EVENT_CONFIG_H_' >> $@ -+ -+ sed -e 's/#define /#define _EVENT_/' \ -+ -e 's/#undef /#undef _EVENT_/' \ -+ -e 's/#ifndef /#ifndef _EVENT_/' < config.h >> $@ -+ echo "#endif" >> $@ -+ -+CORE_SRC = event.c log.c evutil.c http.c buffer.c evbuffer.c strlcpy.c $(SYS_SRC) -+ -+libevent_a_SOURCES = $(CORE_SRC) $(EXTRA_SRC) -+libevent_a_DEPENDENCIES = $(LIBOBJS) -+libevent_a_LIBADD = $(LIBOBJS) -+ -+include_HEADERS = event.h evutil.h event-config.h -+ -+INCLUDES = -I$(srcdir)/compat $(SYS_INCLUDES) -diff --git a/libevent/Makefile.in b/libevent/Makefile.in -new file mode 100644 -index 0000000..0600dcc ---- /dev/null -+++ b/libevent/Makefile.in -@@ -0,0 +1,618 @@ -+# Makefile.in generated by automake 1.9.5 from Makefile.am. -+# @configure_input@ -+ -+# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -+# 2003, 2004, 2005 Free Software Foundation, Inc. -+# This Makefile.in is free software; the Free Software Foundation -+# gives unlimited permission to copy and/or distribute it, -+# with or without modifications, as long as this notice is preserved. -+ -+# This program is distributed in the hope that it will be useful, -+# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -+# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -+# PARTICULAR PURPOSE. -+ -+@SET_MAKE@ -+ -+ -+SOURCES = $(libevent_a_SOURCES) -+ -+srcdir = @srcdir@ -+top_srcdir = @top_srcdir@ -+VPATH = @srcdir@ -+pkgdatadir = $(datadir)/@PACKAGE@ -+pkglibdir = $(libdir)/@PACKAGE@ -+pkgincludedir = $(includedir)/@PACKAGE@ -+top_builddir = . -+am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd -+INSTALL = @INSTALL@ -+install_sh_DATA = $(install_sh) -c -m 644 -+install_sh_PROGRAM = $(install_sh) -c -+install_sh_SCRIPT = $(install_sh) -c -+INSTALL_HEADER = $(INSTALL_DATA) -+transform = $(program_transform_name) -+NORMAL_INSTALL = : -+PRE_INSTALL = : -+POST_INSTALL = : -+NORMAL_UNINSTALL = : -+PRE_UNINSTALL = : -+POST_UNINSTALL = : -+subdir = . -+DIST_COMMON = README $(am__configure_deps) $(include_HEADERS) \ -+ $(srcdir)/Makefile.am $(srcdir)/Makefile.in \ -+ $(srcdir)/config.h.in $(top_srcdir)/configure ChangeLog \ -+ depcomp devpoll.c epoll.c epoll_sub.c evport.c install-sh \ -+ kqueue.c missing poll.c select.c signal.c -+ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 -+am__aclocal_m4_deps = $(top_srcdir)/configure.in -+am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ -+ $(ACLOCAL_M4) -+am__CONFIG_DISTCLEAN_FILES = config.status config.cache config.log \ -+ configure.lineno configure.status.lineno -+mkinstalldirs = $(install_sh) -d -+CONFIG_HEADER = config.h -+CONFIG_CLEAN_FILES = -+LIBRARIES = $(noinst_LIBRARIES) -+AR = ar -+ARFLAGS = cru -+libevent_a_AR = $(AR) $(ARFLAGS) -+am__DEPENDENCIES_1 = @LIBOBJS@ -+am__objects_1 = event.$(OBJEXT) log.$(OBJEXT) evutil.$(OBJEXT) \ -+ http.$(OBJEXT) buffer.$(OBJEXT) evbuffer.$(OBJEXT) \ -+ strlcpy.$(OBJEXT) -+am_libevent_a_OBJECTS = $(am__objects_1) -+libevent_a_OBJECTS = $(am_libevent_a_OBJECTS) -+DEFAULT_INCLUDES = -I. -I$(srcdir) -I. -+depcomp = $(SHELL) $(top_srcdir)/depcomp -+am__depfiles_maybe = depfiles -+COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ -+ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -+CCLD = $(CC) -+LINK = $(CCLD) $(AM_CFLAGS) $(CFLAGS) $(AM_LDFLAGS) $(LDFLAGS) -o $@ -+SOURCES = $(libevent_a_SOURCES) -+DIST_SOURCES = $(libevent_a_SOURCES) -+am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; -+am__vpath_adj = case $$p in \ -+ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ -+ *) f=$$p;; \ -+ esac; -+am__strip_dir = `echo $$p | sed -e 's|^.*/||'`; -+am__installdirs = "$(DESTDIR)$(includedir)" -+includeHEADERS_INSTALL = $(INSTALL_HEADER) -+HEADERS = $(include_HEADERS) -+ETAGS = etags -+CTAGS = ctags -+DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) -+distdir = $(PACKAGE)-$(VERSION) -+top_distdir = $(distdir) -+am__remove_distdir = \ -+ { test ! -d $(distdir) \ -+ || { find $(distdir) -type d ! -perm -200 -exec chmod u+w {} ';' \ -+ && rm -fr $(distdir); }; } -+DIST_ARCHIVES = $(distdir).tar.gz -+GZIP_ENV = --best -+distuninstallcheck_listfiles = find . -type f -print -+distcleancheck_listfiles = find . -type f -print -+ACLOCAL = @ACLOCAL@ -+AMDEP_FALSE = @AMDEP_FALSE@ -+AMDEP_TRUE = @AMDEP_TRUE@ -+AMTAR = @AMTAR@ -+AUTOCONF = @AUTOCONF@ -+AUTOHEADER = @AUTOHEADER@ -+AUTOMAKE = @AUTOMAKE@ -+AWK = @AWK@ -+BUILD_WIN32_FALSE = @BUILD_WIN32_FALSE@ -+BUILD_WIN32_TRUE = @BUILD_WIN32_TRUE@ -+CC = @CC@ -+CCDEPMODE = @CCDEPMODE@ -+CFLAGS = @CFLAGS@ -+CPP = @CPP@ -+CPPFLAGS = @CPPFLAGS@ -+CYGPATH_W = @CYGPATH_W@ -+DEFS = @DEFS@ -+DEPDIR = @DEPDIR@ -+ECHO_C = @ECHO_C@ -+ECHO_N = @ECHO_N@ -+ECHO_T = @ECHO_T@ -+EGREP = @EGREP@ -+EXEEXT = @EXEEXT@ -+INSTALL_DATA = @INSTALL_DATA@ -+INSTALL_PROGRAM = @INSTALL_PROGRAM@ -+INSTALL_SCRIPT = @INSTALL_SCRIPT@ -+INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -+LDFLAGS = @LDFLAGS@ -+LIBOBJS = @LIBOBJS@ -+LIBS = @LIBS@ -+LN_S = @LN_S@ -+LTLIBOBJS = @LTLIBOBJS@ -+MAKEINFO = @MAKEINFO@ -+OBJEXT = @OBJEXT@ -+PACKAGE = @PACKAGE@ -+PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ -+PACKAGE_NAME = @PACKAGE_NAME@ -+PACKAGE_STRING = @PACKAGE_STRING@ -+PACKAGE_TARNAME = @PACKAGE_TARNAME@ -+PACKAGE_VERSION = @PACKAGE_VERSION@ -+PATH_SEPARATOR = @PATH_SEPARATOR@ -+RANLIB = @RANLIB@ -+SET_MAKE = @SET_MAKE@ -+SHELL = @SHELL@ -+STRIP = @STRIP@ -+VERSION = @VERSION@ -+ac_ct_CC = @ac_ct_CC@ -+ac_ct_RANLIB = @ac_ct_RANLIB@ -+ac_ct_STRIP = @ac_ct_STRIP@ -+am__fastdepCC_FALSE = @am__fastdepCC_FALSE@ -+am__fastdepCC_TRUE = @am__fastdepCC_TRUE@ -+am__include = @am__include@ -+am__leading_dot = @am__leading_dot@ -+am__quote = @am__quote@ -+am__tar = @am__tar@ -+am__untar = @am__untar@ -+bindir = @bindir@ -+build_alias = @build_alias@ -+datadir = @datadir@ -+exec_prefix = @exec_prefix@ -+host_alias = @host_alias@ -+includedir = @includedir@ -+infodir = @infodir@ -+install_sh = @install_sh@ -+libdir = @libdir@ -+libexecdir = @libexecdir@ -+localstatedir = @localstatedir@ -+mandir = @mandir@ -+mkdir_p = @mkdir_p@ -+oldincludedir = @oldincludedir@ -+prefix = @prefix@ -+program_transform_name = @program_transform_name@ -+sbindir = @sbindir@ -+sharedstatedir = @sharedstatedir@ -+sysconfdir = @sysconfdir@ -+target_alias = @target_alias@ -+ -+# This is the point release for libevent. It shouldn't include any -+# a/b/c/d/e notations. -+RELEASE = 1.4 -+ -+# This is the version info for the libevent binary API. It has three -+# numbers: -+# Current -- the number of the binary API that we're implementing -+# Revision -- which iteration of the implementation of the binary -+# API are we supplying? -+# Age -- How many previous binary API versions do we also -+# support? -+# -+# If we release a new version that does not change the binary API, -+# increment Revision. -+# -+# If we release a new version that changes the binary API, but does -+# not break programs compiled against the old binary API, increment -+# Current and Age. Set Revision to 0, since this is the first -+# implementation of the new API. -+# -+# Otherwise, we're changing the binary API and breaking bakward -+# compatibility with old binaries. Increment Current. Set Age to 0, -+# since we're backward compatible with no previous APIs. Set Revision -+# to 0 too. -+ -+# History: -+# Libevent 1.4.1 was 2:0:0 -+# Libevent 1.4.2 should be 3:0:0 -+# Libevent 1.4.5 is 3:0:1 (we forgot to increment in the past) -+VERSION_INFO = 3:2:1 -+noinst_LIBRARIES = libevent.a -+BUILT_SOURCES = event-config.h -+CORE_SRC = event.c log.c evutil.c http.c buffer.c evbuffer.c strlcpy.c $(SYS_SRC) -+libevent_a_SOURCES = $(CORE_SRC) $(EXTRA_SRC) -+libevent_a_DEPENDENCIES = $(LIBOBJS) -+libevent_a_LIBADD = $(LIBOBJS) -+include_HEADERS = event.h evutil.h event-config.h -+INCLUDES = -I$(srcdir)/compat $(SYS_INCLUDES) -+all: $(BUILT_SOURCES) config.h -+ $(MAKE) $(AM_MAKEFLAGS) all-am -+ -+.SUFFIXES: -+.SUFFIXES: .c .o .obj -+am--refresh: -+ @: -+$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) -+ @for dep in $?; do \ -+ case '$(am__configure_deps)' in \ -+ *$$dep*) \ -+ echo ' cd $(srcdir) && $(AUTOMAKE) --foreign '; \ -+ cd $(srcdir) && $(AUTOMAKE) --foreign \ -+ && exit 0; \ -+ exit 1;; \ -+ esac; \ -+ done; \ -+ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign Makefile'; \ -+ cd $(top_srcdir) && \ -+ $(AUTOMAKE) --foreign Makefile -+.PRECIOUS: Makefile -+Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status -+ @case '$?' in \ -+ *config.status*) \ -+ echo ' $(SHELL) ./config.status'; \ -+ $(SHELL) ./config.status;; \ -+ *) \ -+ echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe)'; \ -+ cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe);; \ -+ esac; -+ -+$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) -+ $(SHELL) ./config.status --recheck -+ -+$(top_srcdir)/configure: $(am__configure_deps) -+ cd $(srcdir) && $(AUTOCONF) -+$(ACLOCAL_M4): $(am__aclocal_m4_deps) -+ cd $(srcdir) && $(ACLOCAL) $(ACLOCAL_AMFLAGS) -+ -+config.h: stamp-h1 -+ @if test ! -f $@; then \ -+ rm -f stamp-h1; \ -+ $(MAKE) stamp-h1; \ -+ else :; fi -+ -+stamp-h1: $(srcdir)/config.h.in $(top_builddir)/config.status -+ @rm -f stamp-h1 -+ cd $(top_builddir) && $(SHELL) ./config.status config.h -+$(srcdir)/config.h.in: $(am__configure_deps) -+ cd $(top_srcdir) && $(AUTOHEADER) -+ rm -f stamp-h1 -+ touch $@ -+ -+distclean-hdr: -+ -rm -f config.h stamp-h1 -+ -+clean-noinstLIBRARIES: -+ -test -z "$(noinst_LIBRARIES)" || rm -f $(noinst_LIBRARIES) -+libevent.a: $(libevent_a_OBJECTS) $(libevent_a_DEPENDENCIES) -+ -rm -f libevent.a -+ $(libevent_a_AR) libevent.a $(libevent_a_OBJECTS) $(libevent_a_LIBADD) -+ $(RANLIB) libevent.a -+ -+mostlyclean-compile: -+ -rm -f *.$(OBJEXT) -+ -+distclean-compile: -+ -rm -f *.tab.c -+ -+@AMDEP_TRUE@@am__include@ @am__quote@$(DEPDIR)/devpoll.Po@am__quote@ -+@AMDEP_TRUE@@am__include@ @am__quote@$(DEPDIR)/epoll.Po@am__quote@ -+@AMDEP_TRUE@@am__include@ @am__quote@$(DEPDIR)/epoll_sub.Po@am__quote@ -+@AMDEP_TRUE@@am__include@ @am__quote@$(DEPDIR)/evport.Po@am__quote@ -+@AMDEP_TRUE@@am__include@ @am__quote@$(DEPDIR)/kqueue.Po@am__quote@ -+@AMDEP_TRUE@@am__include@ @am__quote@$(DEPDIR)/poll.Po@am__quote@ -+@AMDEP_TRUE@@am__include@ @am__quote@$(DEPDIR)/select.Po@am__quote@ -+@AMDEP_TRUE@@am__include@ @am__quote@$(DEPDIR)/signal.Po@am__quote@ -+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/buffer.Po@am__quote@ -+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/evbuffer.Po@am__quote@ -+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/event.Po@am__quote@ -+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/evutil.Po@am__quote@ -+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/http.Po@am__quote@ -+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/log.Po@am__quote@ -+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/strlcpy.Po@am__quote@ -+ -+.c.o: -+@am__fastdepCC_TRUE@ if $(COMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ -+@am__fastdepCC_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -+@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -+@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -+@am__fastdepCC_FALSE@ $(COMPILE) -c $< -+ -+.c.obj: -+@am__fastdepCC_TRUE@ if $(COMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \ -+@am__fastdepCC_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi -+@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ -+@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -+@am__fastdepCC_FALSE@ $(COMPILE) -c `$(CYGPATH_W) '$<'` -+uninstall-info-am: -+install-includeHEADERS: $(include_HEADERS) -+ @$(NORMAL_INSTALL) -+ test -z "$(includedir)" || $(mkdir_p) "$(DESTDIR)$(includedir)" -+ @list='$(include_HEADERS)'; for p in $$list; do \ -+ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ -+ f=$(am__strip_dir) \ -+ echo " $(includeHEADERS_INSTALL) '$$d$$p' '$(DESTDIR)$(includedir)/$$f'"; \ -+ $(includeHEADERS_INSTALL) "$$d$$p" "$(DESTDIR)$(includedir)/$$f"; \ -+ done -+ -+uninstall-includeHEADERS: -+ @$(NORMAL_UNINSTALL) -+ @list='$(include_HEADERS)'; for p in $$list; do \ -+ f=$(am__strip_dir) \ -+ echo " rm -f '$(DESTDIR)$(includedir)/$$f'"; \ -+ rm -f "$(DESTDIR)$(includedir)/$$f"; \ -+ done -+ -+ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) -+ list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ -+ unique=`for i in $$list; do \ -+ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ -+ done | \ -+ $(AWK) ' { files[$$0] = 1; } \ -+ END { for (i in files) print i; }'`; \ -+ mkid -fID $$unique -+tags: TAGS -+ -+TAGS: $(HEADERS) $(SOURCES) config.h.in $(TAGS_DEPENDENCIES) \ -+ $(TAGS_FILES) $(LISP) -+ tags=; \ -+ here=`pwd`; \ -+ list='$(SOURCES) $(HEADERS) config.h.in $(LISP) $(TAGS_FILES)'; \ -+ unique=`for i in $$list; do \ -+ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ -+ done | \ -+ $(AWK) ' { files[$$0] = 1; } \ -+ END { for (i in files) print i; }'`; \ -+ if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ -+ test -n "$$unique" || unique=$$empty_fix; \ -+ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ -+ $$tags $$unique; \ -+ fi -+ctags: CTAGS -+CTAGS: $(HEADERS) $(SOURCES) config.h.in $(TAGS_DEPENDENCIES) \ -+ $(TAGS_FILES) $(LISP) -+ tags=; \ -+ here=`pwd`; \ -+ list='$(SOURCES) $(HEADERS) config.h.in $(LISP) $(TAGS_FILES)'; \ -+ unique=`for i in $$list; do \ -+ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ -+ done | \ -+ $(AWK) ' { files[$$0] = 1; } \ -+ END { for (i in files) print i; }'`; \ -+ test -z "$(CTAGS_ARGS)$$tags$$unique" \ -+ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ -+ $$tags $$unique -+ -+GTAGS: -+ here=`$(am__cd) $(top_builddir) && pwd` \ -+ && cd $(top_srcdir) \ -+ && gtags -i $(GTAGS_ARGS) $$here -+ -+distclean-tags: -+ -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags -+ -+distdir: $(DISTFILES) -+ $(am__remove_distdir) -+ mkdir $(distdir) -+ @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \ -+ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \ -+ list='$(DISTFILES)'; for file in $$list; do \ -+ case $$file in \ -+ $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \ -+ $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \ -+ esac; \ -+ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ -+ dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \ -+ if test "$$dir" != "$$file" && test "$$dir" != "."; then \ -+ dir="/$$dir"; \ -+ $(mkdir_p) "$(distdir)$$dir"; \ -+ else \ -+ dir=''; \ -+ fi; \ -+ if test -d $$d/$$file; then \ -+ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ -+ cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \ -+ fi; \ -+ cp -pR $$d/$$file $(distdir)$$dir || exit 1; \ -+ else \ -+ test -f $(distdir)/$$file \ -+ || cp -p $$d/$$file $(distdir)/$$file \ -+ || exit 1; \ -+ fi; \ -+ done -+ -find $(distdir) -type d ! -perm -777 -exec chmod a+rwx {} \; -o \ -+ ! -type d ! -perm -444 -links 1 -exec chmod a+r {} \; -o \ -+ ! -type d ! -perm -400 -exec chmod a+r {} \; -o \ -+ ! -type d ! -perm -444 -exec $(SHELL) $(install_sh) -c -m a+r {} {} \; \ -+ || chmod -R a+r $(distdir) -+dist-gzip: distdir -+ tardir=$(distdir) && $(am__tar) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz -+ $(am__remove_distdir) -+ -+dist-bzip2: distdir -+ tardir=$(distdir) && $(am__tar) | bzip2 -9 -c >$(distdir).tar.bz2 -+ $(am__remove_distdir) -+ -+dist-tarZ: distdir -+ tardir=$(distdir) && $(am__tar) | compress -c >$(distdir).tar.Z -+ $(am__remove_distdir) -+ -+dist-shar: distdir -+ shar $(distdir) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).shar.gz -+ $(am__remove_distdir) -+ -+dist-zip: distdir -+ -rm -f $(distdir).zip -+ zip -rq $(distdir).zip $(distdir) -+ $(am__remove_distdir) -+ -+dist dist-all: distdir -+ tardir=$(distdir) && $(am__tar) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz -+ $(am__remove_distdir) -+ -+# This target untars the dist file and tries a VPATH configuration. Then -+# it guarantees that the distribution is self-contained by making another -+# tarfile. -+distcheck: dist -+ case '$(DIST_ARCHIVES)' in \ -+ *.tar.gz*) \ -+ GZIP=$(GZIP_ENV) gunzip -c $(distdir).tar.gz | $(am__untar) ;;\ -+ *.tar.bz2*) \ -+ bunzip2 -c $(distdir).tar.bz2 | $(am__untar) ;;\ -+ *.tar.Z*) \ -+ uncompress -c $(distdir).tar.Z | $(am__untar) ;;\ -+ *.shar.gz*) \ -+ GZIP=$(GZIP_ENV) gunzip -c $(distdir).shar.gz | unshar ;;\ -+ *.zip*) \ -+ unzip $(distdir).zip ;;\ -+ esac -+ chmod -R a-w $(distdir); chmod a+w $(distdir) -+ mkdir $(distdir)/_build -+ mkdir $(distdir)/_inst -+ chmod a-w $(distdir) -+ dc_install_base=`$(am__cd) $(distdir)/_inst && pwd | sed -e 's,^[^:\\/]:[\\/],/,'` \ -+ && dc_destdir="$${TMPDIR-/tmp}/am-dc-$$$$/" \ -+ && cd $(distdir)/_build \ -+ && ../configure --srcdir=.. --prefix="$$dc_install_base" \ -+ $(DISTCHECK_CONFIGURE_FLAGS) \ -+ && $(MAKE) $(AM_MAKEFLAGS) \ -+ && $(MAKE) $(AM_MAKEFLAGS) dvi \ -+ && $(MAKE) $(AM_MAKEFLAGS) check \ -+ && $(MAKE) $(AM_MAKEFLAGS) install \ -+ && $(MAKE) $(AM_MAKEFLAGS) installcheck \ -+ && $(MAKE) $(AM_MAKEFLAGS) uninstall \ -+ && $(MAKE) $(AM_MAKEFLAGS) distuninstallcheck_dir="$$dc_install_base" \ -+ distuninstallcheck \ -+ && chmod -R a-w "$$dc_install_base" \ -+ && ({ \ -+ (cd ../.. && umask 077 && mkdir "$$dc_destdir") \ -+ && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" install \ -+ && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" uninstall \ -+ && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" \ -+ distuninstallcheck_dir="$$dc_destdir" distuninstallcheck; \ -+ } || { rm -rf "$$dc_destdir"; exit 1; }) \ -+ && rm -rf "$$dc_destdir" \ -+ && $(MAKE) $(AM_MAKEFLAGS) dist \ -+ && rm -rf $(DIST_ARCHIVES) \ -+ && $(MAKE) $(AM_MAKEFLAGS) distcleancheck -+ $(am__remove_distdir) -+ @(echo "$(distdir) archives ready for distribution: "; \ -+ list='$(DIST_ARCHIVES)'; for i in $$list; do echo $$i; done) | \ -+ sed -e '1{h;s/./=/g;p;x;}' -e '$${p;x;}' -+distuninstallcheck: -+ @cd $(distuninstallcheck_dir) \ -+ && test `$(distuninstallcheck_listfiles) | wc -l` -le 1 \ -+ || { echo "ERROR: files left after uninstall:" ; \ -+ if test -n "$(DESTDIR)"; then \ -+ echo " (check DESTDIR support)"; \ -+ fi ; \ -+ $(distuninstallcheck_listfiles) ; \ -+ exit 1; } >&2 -+distcleancheck: distclean -+ @if test '$(srcdir)' = . ; then \ -+ echo "ERROR: distcleancheck can only run from a VPATH build" ; \ -+ exit 1 ; \ -+ fi -+ @test `$(distcleancheck_listfiles) | wc -l` -eq 0 \ -+ || { echo "ERROR: files left in build directory after distclean:" ; \ -+ $(distcleancheck_listfiles) ; \ -+ exit 1; } >&2 -+check-am: all-am -+check: $(BUILT_SOURCES) -+ $(MAKE) $(AM_MAKEFLAGS) check-am -+all-am: Makefile $(LIBRARIES) $(HEADERS) config.h -+installdirs: -+ for dir in "$(DESTDIR)$(includedir)"; do \ -+ test -z "$$dir" || $(mkdir_p) "$$dir"; \ -+ done -+install: $(BUILT_SOURCES) -+ $(MAKE) $(AM_MAKEFLAGS) install-am -+install-exec: install-exec-am -+install-data: install-data-am -+uninstall: uninstall-am -+ -+install-am: all-am -+ @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am -+ -+installcheck: installcheck-am -+install-strip: -+ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ -+ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ -+ `test -z '$(STRIP)' || \ -+ echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install -+mostlyclean-generic: -+ -+clean-generic: -+ -+distclean-generic: -+ -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -+ -+maintainer-clean-generic: -+ @echo "This command is intended for maintainers to use" -+ @echo "it deletes files that may require special tools to rebuild." -+ -test -z "$(BUILT_SOURCES)" || rm -f $(BUILT_SOURCES) -+clean: clean-am -+ -+clean-am: clean-generic clean-noinstLIBRARIES mostlyclean-am -+ -+distclean: distclean-am -+ -rm -f $(am__CONFIG_DISTCLEAN_FILES) -+ -rm -rf $(DEPDIR) ./$(DEPDIR) -+ -rm -f Makefile -+distclean-am: clean-am distclean-compile distclean-generic \ -+ distclean-hdr distclean-tags -+ -+dvi: dvi-am -+ -+dvi-am: -+ -+html: html-am -+ -+info: info-am -+ -+info-am: -+ -+install-data-am: install-includeHEADERS -+ -+install-exec-am: -+ -+install-info: install-info-am -+ -+install-man: -+ -+installcheck-am: -+ -+maintainer-clean: maintainer-clean-am -+ -rm -f $(am__CONFIG_DISTCLEAN_FILES) -+ -rm -rf $(top_srcdir)/autom4te.cache -+ -rm -rf $(DEPDIR) ./$(DEPDIR) -+ -rm -f Makefile -+maintainer-clean-am: distclean-am maintainer-clean-generic -+ -+mostlyclean: mostlyclean-am -+ -+mostlyclean-am: mostlyclean-compile mostlyclean-generic -+ -+pdf: pdf-am -+ -+pdf-am: -+ -+ps: ps-am -+ -+ps-am: -+ -+uninstall-am: uninstall-includeHEADERS uninstall-info-am -+ -+.PHONY: CTAGS GTAGS all all-am am--refresh check check-am clean \ -+ clean-generic clean-noinstLIBRARIES ctags dist dist-all \ -+ dist-bzip2 dist-gzip dist-shar dist-tarZ dist-zip distcheck \ -+ distclean distclean-compile distclean-generic distclean-hdr \ -+ distclean-tags distcleancheck distdir distuninstallcheck dvi \ -+ dvi-am html html-am info info-am install install-am \ -+ install-data install-data-am install-exec install-exec-am \ -+ install-includeHEADERS install-info install-info-am \ -+ install-man install-strip installcheck installcheck-am \ -+ installdirs maintainer-clean maintainer-clean-generic \ -+ mostlyclean mostlyclean-compile mostlyclean-generic pdf pdf-am \ -+ ps ps-am tags uninstall uninstall-am uninstall-includeHEADERS \ -+ uninstall-info-am -+ -+ -+event-config.h: config.h -+ echo '/* event-config.h' > $@ -+ echo ' * Generated by autoconf; post-processed by libevent.' >> $@ -+ echo ' * Do not edit this file.' >> $@ -+ echo ' * Do not rely on macros in this file existing in later versions.'>> $@ -+ echo ' */' >> $@ -+ echo '#ifndef _EVENT_CONFIG_H_' >> $@ -+ echo '#define _EVENT_CONFIG_H_' >> $@ -+ -+ sed -e 's/#define /#define _EVENT_/' \ -+ -e 's/#undef /#undef _EVENT_/' \ -+ -e 's/#ifndef /#ifndef _EVENT_/' < config.h >> $@ -+ echo "#endif" >> $@ -+# Tell versions [3.59,3.63) of GNU make to not export all variables. -+# Otherwise a system limit (for SysV at least) may be exceeded. -+.NOEXPORT: -diff --git a/libevent/README b/libevent/README -new file mode 100644 -index 0000000..b065039 ---- /dev/null -+++ b/libevent/README -@@ -0,0 +1,57 @@ -+To build libevent, type -+ -+$ ./configure && make -+ -+ (If you got libevent from the subversion repository, you will -+ first need to run the included "autogen.sh" script in order to -+ generate the configure script.) -+ -+Install as root via -+ -+# make install -+ -+You can run the regression tests by -+ -+$ make verify -+ -+Before, reporting any problems, please run the regression tests. -+ -+To enable the low-level tracing build the library as: -+ -+CFLAGS=-DUSE_DEBUG ./configure [...] -+ -+Acknowledgements: -+----------------- -+ -+The following people have helped with suggestions, ideas, code or -+fixing bugs: -+ -+ Alejo -+ Weston Andros Adamson -+ William Ahern -+ Stas Bekman -+ Andrew Danforth -+ Mike Davis -+ Shie Erlich -+ Alexander von Gernler -+ Artur Grabowski -+ Aaron Hopkins -+ Claudio Jeker -+ Scott Lamb -+ Adam Langley -+ Philip Lewis -+ David Libenzi -+ Nick Mathewson -+ Andrey Matveev -+ Richard Nyberg -+ Jon Oberheide -+ Phil Oleson -+ Dave Pacheco -+ Tassilo von Parseval -+ Pierre Phaneuf -+ Jon Poland -+ Bert JW Regeer -+ Dug Song -+ Taral -+ -+If I have forgotten your name, please contact me. -diff --git a/libevent/aclocal.m4 b/libevent/aclocal.m4 -new file mode 100644 -index 0000000..74de4a1 ---- /dev/null -+++ b/libevent/aclocal.m4 -@@ -0,0 +1,862 @@ -+# generated automatically by aclocal 1.9.5 -*- Autoconf -*- -+ -+# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, -+# 2005 Free Software Foundation, Inc. -+# This file is free software; the Free Software Foundation -+# gives unlimited permission to copy and/or distribute it, -+# with or without modifications, as long as this notice is preserved. -+ -+# This program is distributed in the hope that it will be useful, -+# but WITHOUT ANY WARRANTY, to the extent permitted by law; without -+# even the implied warranty of MERCHANTABILITY or FITNESS FOR A -+# PARTICULAR PURPOSE. -+ -+# Copyright (C) 2002, 2003, 2005 Free Software Foundation, Inc. -+# -+# This file is free software; the Free Software Foundation -+# gives unlimited permission to copy and/or distribute it, -+# with or without modifications, as long as this notice is preserved. -+ -+# AM_AUTOMAKE_VERSION(VERSION) -+# ---------------------------- -+# Automake X.Y traces this macro to ensure aclocal.m4 has been -+# generated from the m4 files accompanying Automake X.Y. -+AC_DEFUN([AM_AUTOMAKE_VERSION], [am__api_version="1.9"]) -+ -+# AM_SET_CURRENT_AUTOMAKE_VERSION -+# ------------------------------- -+# Call AM_AUTOMAKE_VERSION so it can be traced. -+# This function is AC_REQUIREd by AC_INIT_AUTOMAKE. -+AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION], -+ [AM_AUTOMAKE_VERSION([1.9.5])]) -+ -+# AM_AUX_DIR_EXPAND -*- Autoconf -*- -+ -+# Copyright (C) 2001, 2003, 2005 Free Software Foundation, Inc. -+# -+# This file is free software; the Free Software Foundation -+# gives unlimited permission to copy and/or distribute it, -+# with or without modifications, as long as this notice is preserved. -+ -+# For projects using AC_CONFIG_AUX_DIR([foo]), Autoconf sets -+# $ac_aux_dir to `$srcdir/foo'. In other projects, it is set to -+# `$srcdir', `$srcdir/..', or `$srcdir/../..'. -+# -+# Of course, Automake must honor this variable whenever it calls a -+# tool from the auxiliary directory. The problem is that $srcdir (and -+# therefore $ac_aux_dir as well) can be either absolute or relative, -+# depending on how configure is run. This is pretty annoying, since -+# it makes $ac_aux_dir quite unusable in subdirectories: in the top -+# source directory, any form will work fine, but in subdirectories a -+# relative path needs to be adjusted first. -+# -+# $ac_aux_dir/missing -+# fails when called from a subdirectory if $ac_aux_dir is relative -+# $top_srcdir/$ac_aux_dir/missing -+# fails if $ac_aux_dir is absolute, -+# fails when called from a subdirectory in a VPATH build with -+# a relative $ac_aux_dir -+# -+# The reason of the latter failure is that $top_srcdir and $ac_aux_dir -+# are both prefixed by $srcdir. In an in-source build this is usually -+# harmless because $srcdir is `.', but things will broke when you -+# start a VPATH build or use an absolute $srcdir. -+# -+# So we could use something similar to $top_srcdir/$ac_aux_dir/missing, -+# iff we strip the leading $srcdir from $ac_aux_dir. That would be: -+# am_aux_dir='\$(top_srcdir)/'`expr "$ac_aux_dir" : "$srcdir//*\(.*\)"` -+# and then we would define $MISSING as -+# MISSING="\${SHELL} $am_aux_dir/missing" -+# This will work as long as MISSING is not called from configure, because -+# unfortunately $(top_srcdir) has no meaning in configure. -+# However there are other variables, like CC, which are often used in -+# configure, and could therefore not use this "fixed" $ac_aux_dir. -+# -+# Another solution, used here, is to always expand $ac_aux_dir to an -+# absolute PATH. The drawback is that using absolute paths prevent a -+# configured tree to be moved without reconfiguration. -+ -+AC_DEFUN([AM_AUX_DIR_EXPAND], -+[dnl Rely on autoconf to set up CDPATH properly. -+AC_PREREQ([2.50])dnl -+# expand $ac_aux_dir to an absolute path -+am_aux_dir=`cd $ac_aux_dir && pwd` -+]) -+ -+# AM_CONDITIONAL -*- Autoconf -*- -+ -+# Copyright (C) 1997, 2000, 2001, 2003, 2004, 2005 -+# Free Software Foundation, Inc. -+# -+# This file is free software; the Free Software Foundation -+# gives unlimited permission to copy and/or distribute it, -+# with or without modifications, as long as this notice is preserved. -+ -+# serial 7 -+ -+# AM_CONDITIONAL(NAME, SHELL-CONDITION) -+# ------------------------------------- -+# Define a conditional. -+AC_DEFUN([AM_CONDITIONAL], -+[AC_PREREQ(2.52)dnl -+ ifelse([$1], [TRUE], [AC_FATAL([$0: invalid condition: $1])], -+ [$1], [FALSE], [AC_FATAL([$0: invalid condition: $1])])dnl -+AC_SUBST([$1_TRUE]) -+AC_SUBST([$1_FALSE]) -+if $2; then -+ $1_TRUE= -+ $1_FALSE='#' -+else -+ $1_TRUE='#' -+ $1_FALSE= -+fi -+AC_CONFIG_COMMANDS_PRE( -+[if test -z "${$1_TRUE}" && test -z "${$1_FALSE}"; then -+ AC_MSG_ERROR([[conditional "$1" was never defined. -+Usually this means the macro was only invoked conditionally.]]) -+fi])]) -+ -+ -+# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005 -+# Free Software Foundation, Inc. -+# -+# This file is free software; the Free Software Foundation -+# gives unlimited permission to copy and/or distribute it, -+# with or without modifications, as long as this notice is preserved. -+ -+# serial 8 -+ -+# There are a few dirty hacks below to avoid letting `AC_PROG_CC' be -+# written in clear, in which case automake, when reading aclocal.m4, -+# will think it sees a *use*, and therefore will trigger all it's -+# C support machinery. Also note that it means that autoscan, seeing -+# CC etc. in the Makefile, will ask for an AC_PROG_CC use... -+ -+ -+# _AM_DEPENDENCIES(NAME) -+# ---------------------- -+# See how the compiler implements dependency checking. -+# NAME is "CC", "CXX", "GCJ", or "OBJC". -+# We try a few techniques and use that to set a single cache variable. -+# -+# We don't AC_REQUIRE the corresponding AC_PROG_CC since the latter was -+# modified to invoke _AM_DEPENDENCIES(CC); we would have a circular -+# dependency, and given that the user is not expected to run this macro, -+# just rely on AC_PROG_CC. -+AC_DEFUN([_AM_DEPENDENCIES], -+[AC_REQUIRE([AM_SET_DEPDIR])dnl -+AC_REQUIRE([AM_OUTPUT_DEPENDENCY_COMMANDS])dnl -+AC_REQUIRE([AM_MAKE_INCLUDE])dnl -+AC_REQUIRE([AM_DEP_TRACK])dnl -+ -+ifelse([$1], CC, [depcc="$CC" am_compiler_list=], -+ [$1], CXX, [depcc="$CXX" am_compiler_list=], -+ [$1], OBJC, [depcc="$OBJC" am_compiler_list='gcc3 gcc'], -+ [$1], GCJ, [depcc="$GCJ" am_compiler_list='gcc3 gcc'], -+ [depcc="$$1" am_compiler_list=]) -+ -+AC_CACHE_CHECK([dependency style of $depcc], -+ [am_cv_$1_dependencies_compiler_type], -+[if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then -+ # We make a subdir and do the tests there. Otherwise we can end up -+ # making bogus files that we don't know about and never remove. For -+ # instance it was reported that on HP-UX the gcc test will end up -+ # making a dummy file named `D' -- because `-MD' means `put the output -+ # in D'. -+ mkdir conftest.dir -+ # Copy depcomp to subdir because otherwise we won't find it if we're -+ # using a relative directory. -+ cp "$am_depcomp" conftest.dir -+ cd conftest.dir -+ # We will build objects and dependencies in a subdirectory because -+ # it helps to detect inapplicable dependency modes. For instance -+ # both Tru64's cc and ICC support -MD to output dependencies as a -+ # side effect of compilation, but ICC will put the dependencies in -+ # the current directory while Tru64 will put them in the object -+ # directory. -+ mkdir sub -+ -+ am_cv_$1_dependencies_compiler_type=none -+ if test "$am_compiler_list" = ""; then -+ am_compiler_list=`sed -n ['s/^#*\([a-zA-Z0-9]*\))$/\1/p'] < ./depcomp` -+ fi -+ for depmode in $am_compiler_list; do -+ # Setup a source with many dependencies, because some compilers -+ # like to wrap large dependency lists on column 80 (with \), and -+ # we should not choose a depcomp mode which is confused by this. -+ # -+ # We need to recreate these files for each test, as the compiler may -+ # overwrite some of them when testing with obscure command lines. -+ # This happens at least with the AIX C compiler. -+ : > sub/conftest.c -+ for i in 1 2 3 4 5 6; do -+ echo '#include "conftst'$i'.h"' >> sub/conftest.c -+ # Using `: > sub/conftst$i.h' creates only sub/conftst1.h with -+ # Solaris 8's {/usr,}/bin/sh. -+ touch sub/conftst$i.h -+ done -+ echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf -+ -+ case $depmode in -+ nosideeffect) -+ # after this tag, mechanisms are not by side-effect, so they'll -+ # only be used when explicitly requested -+ if test "x$enable_dependency_tracking" = xyes; then -+ continue -+ else -+ break -+ fi -+ ;; -+ none) break ;; -+ esac -+ # We check with `-c' and `-o' for the sake of the "dashmstdout" -+ # mode. It turns out that the SunPro C++ compiler does not properly -+ # handle `-M -o', and we need to detect this. -+ if depmode=$depmode \ -+ source=sub/conftest.c object=sub/conftest.${OBJEXT-o} \ -+ depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ -+ $SHELL ./depcomp $depcc -c -o sub/conftest.${OBJEXT-o} sub/conftest.c \ -+ >/dev/null 2>conftest.err && -+ grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && -+ grep sub/conftest.${OBJEXT-o} sub/conftest.Po > /dev/null 2>&1 && -+ ${MAKE-make} -s -f confmf > /dev/null 2>&1; then -+ # icc doesn't choke on unknown options, it will just issue warnings -+ # or remarks (even with -Werror). So we grep stderr for any message -+ # that says an option was ignored or not supported. -+ # When given -MP, icc 7.0 and 7.1 complain thusly: -+ # icc: Command line warning: ignoring option '-M'; no argument required -+ # The diagnosis changed in icc 8.0: -+ # icc: Command line remark: option '-MP' not supported -+ if (grep 'ignoring option' conftest.err || -+ grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else -+ am_cv_$1_dependencies_compiler_type=$depmode -+ break -+ fi -+ fi -+ done -+ -+ cd .. -+ rm -rf conftest.dir -+else -+ am_cv_$1_dependencies_compiler_type=none -+fi -+]) -+AC_SUBST([$1DEPMODE], [depmode=$am_cv_$1_dependencies_compiler_type]) -+AM_CONDITIONAL([am__fastdep$1], [ -+ test "x$enable_dependency_tracking" != xno \ -+ && test "$am_cv_$1_dependencies_compiler_type" = gcc3]) -+]) -+ -+ -+# AM_SET_DEPDIR -+# ------------- -+# Choose a directory name for dependency files. -+# This macro is AC_REQUIREd in _AM_DEPENDENCIES -+AC_DEFUN([AM_SET_DEPDIR], -+[AC_REQUIRE([AM_SET_LEADING_DOT])dnl -+AC_SUBST([DEPDIR], ["${am__leading_dot}deps"])dnl -+]) -+ -+ -+# AM_DEP_TRACK -+# ------------ -+AC_DEFUN([AM_DEP_TRACK], -+[AC_ARG_ENABLE(dependency-tracking, -+[ --disable-dependency-tracking speeds up one-time build -+ --enable-dependency-tracking do not reject slow dependency extractors]) -+if test "x$enable_dependency_tracking" != xno; then -+ am_depcomp="$ac_aux_dir/depcomp" -+ AMDEPBACKSLASH='\' -+fi -+AM_CONDITIONAL([AMDEP], [test "x$enable_dependency_tracking" != xno]) -+AC_SUBST([AMDEPBACKSLASH]) -+]) -+ -+# Generate code to set up dependency tracking. -*- Autoconf -*- -+ -+# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005 -+# Free Software Foundation, Inc. -+# -+# This file is free software; the Free Software Foundation -+# gives unlimited permission to copy and/or distribute it, -+# with or without modifications, as long as this notice is preserved. -+ -+#serial 3 -+ -+# _AM_OUTPUT_DEPENDENCY_COMMANDS -+# ------------------------------ -+AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS], -+[for mf in $CONFIG_FILES; do -+ # Strip MF so we end up with the name of the file. -+ mf=`echo "$mf" | sed -e 's/:.*$//'` -+ # Check whether this is an Automake generated Makefile or not. -+ # We used to match only the files named `Makefile.in', but -+ # some people rename them; so instead we look at the file content. -+ # Grep'ing the first line is not enough: some people post-process -+ # each Makefile.in and add a new line on top of each file to say so. -+ # So let's grep whole file. -+ if grep '^#.*generated by automake' $mf > /dev/null 2>&1; then -+ dirpart=`AS_DIRNAME("$mf")` -+ else -+ continue -+ fi -+ # Extract the definition of DEPDIR, am__include, and am__quote -+ # from the Makefile without running `make'. -+ DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"` -+ test -z "$DEPDIR" && continue -+ am__include=`sed -n 's/^am__include = //p' < "$mf"` -+ test -z "am__include" && continue -+ am__quote=`sed -n 's/^am__quote = //p' < "$mf"` -+ # When using ansi2knr, U may be empty or an underscore; expand it -+ U=`sed -n 's/^U = //p' < "$mf"` -+ # Find all dependency output files, they are included files with -+ # $(DEPDIR) in their names. We invoke sed twice because it is the -+ # simplest approach to changing $(DEPDIR) to its actual value in the -+ # expansion. -+ for file in `sed -n " -+ s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \ -+ sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g' -e 's/\$U/'"$U"'/g'`; do -+ # Make sure the directory exists. -+ test -f "$dirpart/$file" && continue -+ fdir=`AS_DIRNAME(["$file"])` -+ AS_MKDIR_P([$dirpart/$fdir]) -+ # echo "creating $dirpart/$file" -+ echo '# dummy' > "$dirpart/$file" -+ done -+done -+])# _AM_OUTPUT_DEPENDENCY_COMMANDS -+ -+ -+# AM_OUTPUT_DEPENDENCY_COMMANDS -+# ----------------------------- -+# This macro should only be invoked once -- use via AC_REQUIRE. -+# -+# This code is only required when automatic dependency tracking -+# is enabled. FIXME. This creates each `.P' file that we will -+# need in order to bootstrap the dependency handling code. -+AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS], -+[AC_CONFIG_COMMANDS([depfiles], -+ [test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS], -+ [AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"]) -+]) -+ -+# Copyright (C) 1996, 1997, 2000, 2001, 2003, 2005 -+# Free Software Foundation, Inc. -+# -+# This file is free software; the Free Software Foundation -+# gives unlimited permission to copy and/or distribute it, -+# with or without modifications, as long as this notice is preserved. -+ -+# serial 8 -+ -+# AM_CONFIG_HEADER is obsolete. It has been replaced by AC_CONFIG_HEADERS. -+AU_DEFUN([AM_CONFIG_HEADER], [AC_CONFIG_HEADERS($@)]) -+ -+# Do all the work for Automake. -*- Autoconf -*- -+ -+# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005 -+# Free Software Foundation, Inc. -+# -+# This file is free software; the Free Software Foundation -+# gives unlimited permission to copy and/or distribute it, -+# with or without modifications, as long as this notice is preserved. -+ -+# serial 12 -+ -+# This macro actually does too much. Some checks are only needed if -+# your package does certain things. But this isn't really a big deal. -+ -+# AM_INIT_AUTOMAKE(PACKAGE, VERSION, [NO-DEFINE]) -+# AM_INIT_AUTOMAKE([OPTIONS]) -+# ----------------------------------------------- -+# The call with PACKAGE and VERSION arguments is the old style -+# call (pre autoconf-2.50), which is being phased out. PACKAGE -+# and VERSION should now be passed to AC_INIT and removed from -+# the call to AM_INIT_AUTOMAKE. -+# We support both call styles for the transition. After -+# the next Automake release, Autoconf can make the AC_INIT -+# arguments mandatory, and then we can depend on a new Autoconf -+# release and drop the old call support. -+AC_DEFUN([AM_INIT_AUTOMAKE], -+[AC_PREREQ([2.58])dnl -+dnl Autoconf wants to disallow AM_ names. We explicitly allow -+dnl the ones we care about. -+m4_pattern_allow([^AM_[A-Z]+FLAGS$])dnl -+AC_REQUIRE([AM_SET_CURRENT_AUTOMAKE_VERSION])dnl -+AC_REQUIRE([AC_PROG_INSTALL])dnl -+# test to see if srcdir already configured -+if test "`cd $srcdir && pwd`" != "`pwd`" && -+ test -f $srcdir/config.status; then -+ AC_MSG_ERROR([source directory already configured; run "make distclean" there first]) -+fi -+ -+# test whether we have cygpath -+if test -z "$CYGPATH_W"; then -+ if (cygpath --version) >/dev/null 2>/dev/null; then -+ CYGPATH_W='cygpath -w' -+ else -+ CYGPATH_W=echo -+ fi -+fi -+AC_SUBST([CYGPATH_W]) -+ -+# Define the identity of the package. -+dnl Distinguish between old-style and new-style calls. -+m4_ifval([$2], -+[m4_ifval([$3], [_AM_SET_OPTION([no-define])])dnl -+ AC_SUBST([PACKAGE], [$1])dnl -+ AC_SUBST([VERSION], [$2])], -+[_AM_SET_OPTIONS([$1])dnl -+ AC_SUBST([PACKAGE], ['AC_PACKAGE_TARNAME'])dnl -+ AC_SUBST([VERSION], ['AC_PACKAGE_VERSION'])])dnl -+ -+_AM_IF_OPTION([no-define],, -+[AC_DEFINE_UNQUOTED(PACKAGE, "$PACKAGE", [Name of package]) -+ AC_DEFINE_UNQUOTED(VERSION, "$VERSION", [Version number of package])])dnl -+ -+# Some tools Automake needs. -+AC_REQUIRE([AM_SANITY_CHECK])dnl -+AC_REQUIRE([AC_ARG_PROGRAM])dnl -+AM_MISSING_PROG(ACLOCAL, aclocal-${am__api_version}) -+AM_MISSING_PROG(AUTOCONF, autoconf) -+AM_MISSING_PROG(AUTOMAKE, automake-${am__api_version}) -+AM_MISSING_PROG(AUTOHEADER, autoheader) -+AM_MISSING_PROG(MAKEINFO, makeinfo) -+AM_PROG_INSTALL_SH -+AM_PROG_INSTALL_STRIP -+AC_REQUIRE([AM_PROG_MKDIR_P])dnl -+# We need awk for the "check" target. The system "awk" is bad on -+# some platforms. -+AC_REQUIRE([AC_PROG_AWK])dnl -+AC_REQUIRE([AC_PROG_MAKE_SET])dnl -+AC_REQUIRE([AM_SET_LEADING_DOT])dnl -+_AM_IF_OPTION([tar-ustar], [_AM_PROG_TAR([ustar])], -+ [_AM_IF_OPTION([tar-pax], [_AM_PROG_TAR([pax])], -+ [_AM_PROG_TAR([v7])])]) -+_AM_IF_OPTION([no-dependencies],, -+[AC_PROVIDE_IFELSE([AC_PROG_CC], -+ [_AM_DEPENDENCIES(CC)], -+ [define([AC_PROG_CC], -+ defn([AC_PROG_CC])[_AM_DEPENDENCIES(CC)])])dnl -+AC_PROVIDE_IFELSE([AC_PROG_CXX], -+ [_AM_DEPENDENCIES(CXX)], -+ [define([AC_PROG_CXX], -+ defn([AC_PROG_CXX])[_AM_DEPENDENCIES(CXX)])])dnl -+]) -+]) -+ -+ -+# When config.status generates a header, we must update the stamp-h file. -+# This file resides in the same directory as the config header -+# that is generated. The stamp files are numbered to have different names. -+ -+# Autoconf calls _AC_AM_CONFIG_HEADER_HOOK (when defined) in the -+# loop where config.status creates the headers, so we can generate -+# our stamp files there. -+AC_DEFUN([_AC_AM_CONFIG_HEADER_HOOK], -+[# Compute $1's index in $config_headers. -+_am_stamp_count=1 -+for _am_header in $config_headers :; do -+ case $_am_header in -+ $1 | $1:* ) -+ break ;; -+ * ) -+ _am_stamp_count=`expr $_am_stamp_count + 1` ;; -+ esac -+done -+echo "timestamp for $1" >`AS_DIRNAME([$1])`/stamp-h[]$_am_stamp_count]) -+ -+# Copyright (C) 2001, 2003, 2005 Free Software Foundation, Inc. -+# -+# This file is free software; the Free Software Foundation -+# gives unlimited permission to copy and/or distribute it, -+# with or without modifications, as long as this notice is preserved. -+ -+# AM_PROG_INSTALL_SH -+# ------------------ -+# Define $install_sh. -+AC_DEFUN([AM_PROG_INSTALL_SH], -+[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl -+install_sh=${install_sh-"$am_aux_dir/install-sh"} -+AC_SUBST(install_sh)]) -+ -+# Copyright (C) 2003, 2005 Free Software Foundation, Inc. -+# -+# This file is free software; the Free Software Foundation -+# gives unlimited permission to copy and/or distribute it, -+# with or without modifications, as long as this notice is preserved. -+ -+# serial 2 -+ -+# Check whether the underlying file-system supports filenames -+# with a leading dot. For instance MS-DOS doesn't. -+AC_DEFUN([AM_SET_LEADING_DOT], -+[rm -rf .tst 2>/dev/null -+mkdir .tst 2>/dev/null -+if test -d .tst; then -+ am__leading_dot=. -+else -+ am__leading_dot=_ -+fi -+rmdir .tst 2>/dev/null -+AC_SUBST([am__leading_dot])]) -+ -+# Check to see how 'make' treats includes. -*- Autoconf -*- -+ -+# Copyright (C) 2001, 2002, 2003, 2005 Free Software Foundation, Inc. -+# -+# This file is free software; the Free Software Foundation -+# gives unlimited permission to copy and/or distribute it, -+# with or without modifications, as long as this notice is preserved. -+ -+# serial 3 -+ -+# AM_MAKE_INCLUDE() -+# ----------------- -+# Check to see how make treats includes. -+AC_DEFUN([AM_MAKE_INCLUDE], -+[am_make=${MAKE-make} -+cat > confinc << 'END' -+am__doit: -+ @echo done -+.PHONY: am__doit -+END -+# If we don't find an include directive, just comment out the code. -+AC_MSG_CHECKING([for style of include used by $am_make]) -+am__include="#" -+am__quote= -+_am_result=none -+# First try GNU make style include. -+echo "include confinc" > confmf -+# We grep out `Entering directory' and `Leaving directory' -+# messages which can occur if `w' ends up in MAKEFLAGS. -+# In particular we don't look at `^make:' because GNU make might -+# be invoked under some other name (usually "gmake"), in which -+# case it prints its new name instead of `make'. -+if test "`$am_make -s -f confmf 2> /dev/null | grep -v 'ing directory'`" = "done"; then -+ am__include=include -+ am__quote= -+ _am_result=GNU -+fi -+# Now try BSD make style include. -+if test "$am__include" = "#"; then -+ echo '.include "confinc"' > confmf -+ if test "`$am_make -s -f confmf 2> /dev/null`" = "done"; then -+ am__include=.include -+ am__quote="\"" -+ _am_result=BSD -+ fi -+fi -+AC_SUBST([am__include]) -+AC_SUBST([am__quote]) -+AC_MSG_RESULT([$_am_result]) -+rm -f confinc confmf -+]) -+ -+# Fake the existence of programs that GNU maintainers use. -*- Autoconf -*- -+ -+# Copyright (C) 1997, 1999, 2000, 2001, 2003, 2005 -+# Free Software Foundation, Inc. -+# -+# This file is free software; the Free Software Foundation -+# gives unlimited permission to copy and/or distribute it, -+# with or without modifications, as long as this notice is preserved. -+ -+# serial 4 -+ -+# AM_MISSING_PROG(NAME, PROGRAM) -+# ------------------------------ -+AC_DEFUN([AM_MISSING_PROG], -+[AC_REQUIRE([AM_MISSING_HAS_RUN]) -+$1=${$1-"${am_missing_run}$2"} -+AC_SUBST($1)]) -+ -+ -+# AM_MISSING_HAS_RUN -+# ------------------ -+# Define MISSING if not defined so far and test if it supports --run. -+# If it does, set am_missing_run to use it, otherwise, to nothing. -+AC_DEFUN([AM_MISSING_HAS_RUN], -+[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl -+test x"${MISSING+set}" = xset || MISSING="\${SHELL} $am_aux_dir/missing" -+# Use eval to expand $SHELL -+if eval "$MISSING --run true"; then -+ am_missing_run="$MISSING --run " -+else -+ am_missing_run= -+ AC_MSG_WARN([`missing' script is too old or missing]) -+fi -+]) -+ -+# Copyright (C) 2003, 2004, 2005 Free Software Foundation, Inc. -+# -+# This file is free software; the Free Software Foundation -+# gives unlimited permission to copy and/or distribute it, -+# with or without modifications, as long as this notice is preserved. -+ -+# AM_PROG_MKDIR_P -+# --------------- -+# Check whether `mkdir -p' is supported, fallback to mkinstalldirs otherwise. -+# -+# Automake 1.8 used `mkdir -m 0755 -p --' to ensure that directories -+# created by `make install' are always world readable, even if the -+# installer happens to have an overly restrictive umask (e.g. 077). -+# This was a mistake. There are at least two reasons why we must not -+# use `-m 0755': -+# - it causes special bits like SGID to be ignored, -+# - it may be too restrictive (some setups expect 775 directories). -+# -+# Do not use -m 0755 and let people choose whatever they expect by -+# setting umask. -+# -+# We cannot accept any implementation of `mkdir' that recognizes `-p'. -+# Some implementations (such as Solaris 8's) are not thread-safe: if a -+# parallel make tries to run `mkdir -p a/b' and `mkdir -p a/c' -+# concurrently, both version can detect that a/ is missing, but only -+# one can create it and the other will error out. Consequently we -+# restrict ourselves to GNU make (using the --version option ensures -+# this.) -+AC_DEFUN([AM_PROG_MKDIR_P], -+[if mkdir -p --version . >/dev/null 2>&1 && test ! -d ./--version; then -+ # We used to keeping the `.' as first argument, in order to -+ # allow $(mkdir_p) to be used without argument. As in -+ # $(mkdir_p) $(somedir) -+ # where $(somedir) is conditionally defined. However this is wrong -+ # for two reasons: -+ # 1. if the package is installed by a user who cannot write `.' -+ # make install will fail, -+ # 2. the above comment should most certainly read -+ # $(mkdir_p) $(DESTDIR)$(somedir) -+ # so it does not work when $(somedir) is undefined and -+ # $(DESTDIR) is not. -+ # To support the latter case, we have to write -+ # test -z "$(somedir)" || $(mkdir_p) $(DESTDIR)$(somedir), -+ # so the `.' trick is pointless. -+ mkdir_p='mkdir -p --' -+else -+ # On NextStep and OpenStep, the `mkdir' command does not -+ # recognize any option. It will interpret all options as -+ # directories to create, and then abort because `.' already -+ # exists. -+ for d in ./-p ./--version; -+ do -+ test -d $d && rmdir $d -+ done -+ # $(mkinstalldirs) is defined by Automake if mkinstalldirs exists. -+ if test -f "$ac_aux_dir/mkinstalldirs"; then -+ mkdir_p='$(mkinstalldirs)' -+ else -+ mkdir_p='$(install_sh) -d' -+ fi -+fi -+AC_SUBST([mkdir_p])]) -+ -+# Helper functions for option handling. -*- Autoconf -*- -+ -+# Copyright (C) 2001, 2002, 2003, 2005 Free Software Foundation, Inc. -+# -+# This file is free software; the Free Software Foundation -+# gives unlimited permission to copy and/or distribute it, -+# with or without modifications, as long as this notice is preserved. -+ -+# serial 3 -+ -+# _AM_MANGLE_OPTION(NAME) -+# ----------------------- -+AC_DEFUN([_AM_MANGLE_OPTION], -+[[_AM_OPTION_]m4_bpatsubst($1, [[^a-zA-Z0-9_]], [_])]) -+ -+# _AM_SET_OPTION(NAME) -+# ------------------------------ -+# Set option NAME. Presently that only means defining a flag for this option. -+AC_DEFUN([_AM_SET_OPTION], -+[m4_define(_AM_MANGLE_OPTION([$1]), 1)]) -+ -+# _AM_SET_OPTIONS(OPTIONS) -+# ---------------------------------- -+# OPTIONS is a space-separated list of Automake options. -+AC_DEFUN([_AM_SET_OPTIONS], -+[AC_FOREACH([_AM_Option], [$1], [_AM_SET_OPTION(_AM_Option)])]) -+ -+# _AM_IF_OPTION(OPTION, IF-SET, [IF-NOT-SET]) -+# ------------------------------------------- -+# Execute IF-SET if OPTION is set, IF-NOT-SET otherwise. -+AC_DEFUN([_AM_IF_OPTION], -+[m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])]) -+ -+# Check to make sure that the build environment is sane. -*- Autoconf -*- -+ -+# Copyright (C) 1996, 1997, 2000, 2001, 2003, 2005 -+# Free Software Foundation, Inc. -+# -+# This file is free software; the Free Software Foundation -+# gives unlimited permission to copy and/or distribute it, -+# with or without modifications, as long as this notice is preserved. -+ -+# serial 4 -+ -+# AM_SANITY_CHECK -+# --------------- -+AC_DEFUN([AM_SANITY_CHECK], -+[AC_MSG_CHECKING([whether build environment is sane]) -+# Just in case -+sleep 1 -+echo timestamp > conftest.file -+# Do `set' in a subshell so we don't clobber the current shell's -+# arguments. Must try -L first in case configure is actually a -+# symlink; some systems play weird games with the mod time of symlinks -+# (eg FreeBSD returns the mod time of the symlink's containing -+# directory). -+if ( -+ set X `ls -Lt $srcdir/configure conftest.file 2> /dev/null` -+ if test "$[*]" = "X"; then -+ # -L didn't work. -+ set X `ls -t $srcdir/configure conftest.file` -+ fi -+ rm -f conftest.file -+ if test "$[*]" != "X $srcdir/configure conftest.file" \ -+ && test "$[*]" != "X conftest.file $srcdir/configure"; then -+ -+ # If neither matched, then we have a broken ls. This can happen -+ # if, for instance, CONFIG_SHELL is bash and it inherits a -+ # broken ls alias from the environment. This has actually -+ # happened. Such a system could not be considered "sane". -+ AC_MSG_ERROR([ls -t appears to fail. Make sure there is not a broken -+alias in your environment]) -+ fi -+ -+ test "$[2]" = conftest.file -+ ) -+then -+ # Ok. -+ : -+else -+ AC_MSG_ERROR([newly created file is older than distributed files! -+Check your system clock]) -+fi -+AC_MSG_RESULT(yes)]) -+ -+# Copyright (C) 2001, 2003, 2005 Free Software Foundation, Inc. -+# -+# This file is free software; the Free Software Foundation -+# gives unlimited permission to copy and/or distribute it, -+# with or without modifications, as long as this notice is preserved. -+ -+# AM_PROG_INSTALL_STRIP -+# --------------------- -+# One issue with vendor `install' (even GNU) is that you can't -+# specify the program used to strip binaries. This is especially -+# annoying in cross-compiling environments, where the build's strip -+# is unlikely to handle the host's binaries. -+# Fortunately install-sh will honor a STRIPPROG variable, so we -+# always use install-sh in `make install-strip', and initialize -+# STRIPPROG with the value of the STRIP variable (set by the user). -+AC_DEFUN([AM_PROG_INSTALL_STRIP], -+[AC_REQUIRE([AM_PROG_INSTALL_SH])dnl -+# Installed binaries are usually stripped using `strip' when the user -+# run `make install-strip'. However `strip' might not be the right -+# tool to use in cross-compilation environments, therefore Automake -+# will honor the `STRIP' environment variable to overrule this program. -+dnl Don't test for $cross_compiling = yes, because it might be `maybe'. -+if test "$cross_compiling" != no; then -+ AC_CHECK_TOOL([STRIP], [strip], :) -+fi -+INSTALL_STRIP_PROGRAM="\${SHELL} \$(install_sh) -c -s" -+AC_SUBST([INSTALL_STRIP_PROGRAM])]) -+ -+# Check how to create a tarball. -*- Autoconf -*- -+ -+# Copyright (C) 2004, 2005 Free Software Foundation, Inc. -+# -+# This file is free software; the Free Software Foundation -+# gives unlimited permission to copy and/or distribute it, -+# with or without modifications, as long as this notice is preserved. -+ -+# serial 2 -+ -+# _AM_PROG_TAR(FORMAT) -+# -------------------- -+# Check how to create a tarball in format FORMAT. -+# FORMAT should be one of `v7', `ustar', or `pax'. -+# -+# Substitute a variable $(am__tar) that is a command -+# writing to stdout a FORMAT-tarball containing the directory -+# $tardir. -+# tardir=directory && $(am__tar) > result.tar -+# -+# Substitute a variable $(am__untar) that extract such -+# a tarball read from stdin. -+# $(am__untar) < result.tar -+AC_DEFUN([_AM_PROG_TAR], -+[# Always define AMTAR for backward compatibility. -+AM_MISSING_PROG([AMTAR], [tar]) -+m4_if([$1], [v7], -+ [am__tar='${AMTAR} chof - "$$tardir"'; am__untar='${AMTAR} xf -'], -+ [m4_case([$1], [ustar],, [pax],, -+ [m4_fatal([Unknown tar format])]) -+AC_MSG_CHECKING([how to create a $1 tar archive]) -+# Loop over all known methods to create a tar archive until one works. -+_am_tools='gnutar m4_if([$1], [ustar], [plaintar]) pax cpio none' -+_am_tools=${am_cv_prog_tar_$1-$_am_tools} -+# Do not fold the above two line into one, because Tru64 sh and -+# Solaris sh will not grok spaces in the rhs of `-'. -+for _am_tool in $_am_tools -+do -+ case $_am_tool in -+ gnutar) -+ for _am_tar in tar gnutar gtar; -+ do -+ AM_RUN_LOG([$_am_tar --version]) && break -+ done -+ am__tar="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$$tardir"' -+ am__tar_="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$tardir"' -+ am__untar="$_am_tar -xf -" -+ ;; -+ plaintar) -+ # Must skip GNU tar: if it does not support --format= it doesn't create -+ # ustar tarball either. -+ (tar --version) >/dev/null 2>&1 && continue -+ am__tar='tar chf - "$$tardir"' -+ am__tar_='tar chf - "$tardir"' -+ am__untar='tar xf -' -+ ;; -+ pax) -+ am__tar='pax -L -x $1 -w "$$tardir"' -+ am__tar_='pax -L -x $1 -w "$tardir"' -+ am__untar='pax -r' -+ ;; -+ cpio) -+ am__tar='find "$$tardir" -print | cpio -o -H $1 -L' -+ am__tar_='find "$tardir" -print | cpio -o -H $1 -L' -+ am__untar='cpio -i -H $1 -d' -+ ;; -+ none) -+ am__tar=false -+ am__tar_=false -+ am__untar=false -+ ;; -+ esac -+ -+ # If the value was cached, stop now. We just wanted to have am__tar -+ # and am__untar set. -+ test -n "${am_cv_prog_tar_$1}" && break -+ -+ # tar/untar a dummy directory, and stop if the command works -+ rm -rf conftest.dir -+ mkdir conftest.dir -+ echo GrepMe > conftest.dir/file -+ AM_RUN_LOG([tardir=conftest.dir && eval $am__tar_ >conftest.tar]) -+ rm -rf conftest.dir -+ if test -s conftest.tar; then -+ AM_RUN_LOG([$am__untar /dev/null 2>&1 && break -+ fi -+done -+rm -rf conftest.dir -+ -+AC_CACHE_VAL([am_cv_prog_tar_$1], [am_cv_prog_tar_$1=$_am_tool]) -+AC_MSG_RESULT([$am_cv_prog_tar_$1])]) -+AC_SUBST([am__tar]) -+AC_SUBST([am__untar]) -+]) # _AM_PROG_TAR -+ -diff --git a/libevent/autogen.sh b/libevent/autogen.sh -new file mode 100644 -index 0000000..218dbf4 ---- /dev/null -+++ b/libevent/autogen.sh -@@ -0,0 +1,8 @@ -+#!/bin/sh -+ -+aclocal && \ -+ autoheader && \ -+ autoconf && \ -+ automake --foreign --force-missing --add-missing --copy -+ -+rm -rf autom4te.cache -diff --git a/libevent/buffer.c b/libevent/buffer.c -new file mode 100644 -index 0000000..e66080f ---- /dev/null -+++ b/libevent/buffer.c -@@ -0,0 +1,451 @@ -+/* -+ * Copyright (c) 2002, 2003 Niels Provos -+ * All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. The name of the author may not be used to endorse or promote products -+ * derived from this software without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR -+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES -+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. -+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, -+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT -+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF -+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+ */ -+ -+#ifdef HAVE_CONFIG_H -+#include "config.h" -+#endif -+ -+#ifdef WIN32 -+#include -+#include -+#endif -+ -+#ifdef HAVE_VASPRINTF -+/* If we have vasprintf, we need to define this before we include stdio.h. */ -+#define _GNU_SOURCE -+#endif -+ -+#include -+ -+#ifdef HAVE_SYS_TIME_H -+#include -+#endif -+ -+#ifdef HAVE_SYS_IOCTL_H -+#include -+#endif -+ -+#include -+#include -+#include -+#include -+#include -+#ifdef HAVE_STDARG_H -+#include -+#endif -+#ifdef HAVE_UNISTD_H -+#include -+#endif -+ -+#include "event.h" -+#include "config.h" -+#include "evutil.h" -+ -+struct evbuffer * -+evbuffer_new(void) -+{ -+ struct evbuffer *buffer; -+ -+ buffer = calloc(1, sizeof(struct evbuffer)); -+ -+ return (buffer); -+} -+ -+void -+evbuffer_free(struct evbuffer *buffer) -+{ -+ if (buffer->orig_buffer != NULL) -+ free(buffer->orig_buffer); -+ free(buffer); -+} -+ -+/* -+ * This is a destructive add. The data from one buffer moves into -+ * the other buffer. -+ */ -+ -+#define SWAP(x,y) do { \ -+ (x)->buffer = (y)->buffer; \ -+ (x)->orig_buffer = (y)->orig_buffer; \ -+ (x)->misalign = (y)->misalign; \ -+ (x)->totallen = (y)->totallen; \ -+ (x)->off = (y)->off; \ -+} while (0) -+ -+int -+evbuffer_add_buffer(struct evbuffer *outbuf, struct evbuffer *inbuf) -+{ -+ int res; -+ -+ /* Short cut for better performance */ -+ if (outbuf->off == 0) { -+ struct evbuffer tmp; -+ size_t oldoff = inbuf->off; -+ -+ /* Swap them directly */ -+ SWAP(&tmp, outbuf); -+ SWAP(outbuf, inbuf); -+ SWAP(inbuf, &tmp); -+ -+ /* -+ * Optimization comes with a price; we need to notify the -+ * buffer if necessary of the changes. oldoff is the amount -+ * of data that we transfered from inbuf to outbuf -+ */ -+ if (inbuf->off != oldoff && inbuf->cb != NULL) -+ (*inbuf->cb)(inbuf, oldoff, inbuf->off, inbuf->cbarg); -+ if (oldoff && outbuf->cb != NULL) -+ (*outbuf->cb)(outbuf, 0, oldoff, outbuf->cbarg); -+ -+ return (0); -+ } -+ -+ res = evbuffer_add(outbuf, inbuf->buffer, inbuf->off); -+ if (res == 0) { -+ /* We drain the input buffer on success */ -+ evbuffer_drain(inbuf, inbuf->off); -+ } -+ -+ return (res); -+} -+ -+int -+evbuffer_add_vprintf(struct evbuffer *buf, const char *fmt, va_list ap) -+{ -+ char *buffer; -+ size_t space; -+ size_t oldoff = buf->off; -+ int sz; -+ va_list aq; -+ -+ /* make sure that at least some space is available */ -+ evbuffer_expand(buf, 64); -+ for (;;) { -+ size_t used = buf->misalign + buf->off; -+ buffer = (char *)buf->buffer + buf->off; -+ assert(buf->totallen >= used); -+ space = buf->totallen - used; -+ -+#ifndef va_copy -+#define va_copy(dst, src) memcpy(&(dst), &(src), sizeof(va_list)) -+#endif -+ va_copy(aq, ap); -+ -+ sz = evutil_vsnprintf(buffer, space, fmt, aq); -+ -+ va_end(aq); -+ -+ if (sz < 0) -+ return (-1); -+ if (sz < space) { -+ buf->off += sz; -+ if (buf->cb != NULL) -+ (*buf->cb)(buf, oldoff, buf->off, buf->cbarg); -+ return (sz); -+ } -+ if (evbuffer_expand(buf, sz + 1) == -1) -+ return (-1); -+ -+ } -+ /* NOTREACHED */ -+} -+ -+int -+evbuffer_add_printf(struct evbuffer *buf, const char *fmt, ...) -+{ -+ int res = -1; -+ va_list ap; -+ -+ va_start(ap, fmt); -+ res = evbuffer_add_vprintf(buf, fmt, ap); -+ va_end(ap); -+ -+ return (res); -+} -+ -+/* Reads data from an event buffer and drains the bytes read */ -+ -+int -+evbuffer_remove(struct evbuffer *buf, void *data, size_t datlen) -+{ -+ size_t nread = datlen; -+ if (nread >= buf->off) -+ nread = buf->off; -+ -+ memcpy(data, buf->buffer, nread); -+ evbuffer_drain(buf, nread); -+ -+ return (nread); -+} -+ -+/* -+ * Reads a line terminated by either '\r\n', '\n\r' or '\r' or '\n'. -+ * The returned buffer needs to be freed by the called. -+ */ -+ -+char * -+evbuffer_readline(struct evbuffer *buffer) -+{ -+ u_char *data = EVBUFFER_DATA(buffer); -+ size_t len = EVBUFFER_LENGTH(buffer); -+ char *line; -+ unsigned int i; -+ -+ for (i = 0; i < len; i++) { -+ if (data[i] == '\r' || data[i] == '\n') -+ break; -+ } -+ -+ if (i == len) -+ return (NULL); -+ -+ if ((line = malloc(i + 1)) == NULL) { -+ fprintf(stderr, "%s: out of memory\n", __func__); -+ evbuffer_drain(buffer, i); -+ return (NULL); -+ } -+ -+ memcpy(line, data, i); -+ line[i] = '\0'; -+ -+ /* -+ * Some protocols terminate a line with '\r\n', so check for -+ * that, too. -+ */ -+ if ( i < len - 1 ) { -+ char fch = data[i], sch = data[i+1]; -+ -+ /* Drain one more character if needed */ -+ if ( (sch == '\r' || sch == '\n') && sch != fch ) -+ i += 1; -+ } -+ -+ evbuffer_drain(buffer, i + 1); -+ -+ return (line); -+} -+ -+/* Adds data to an event buffer */ -+ -+static void -+evbuffer_align(struct evbuffer *buf) -+{ -+ memmove(buf->orig_buffer, buf->buffer, buf->off); -+ buf->buffer = buf->orig_buffer; -+ buf->misalign = 0; -+} -+ -+/* Expands the available space in the event buffer to at least datlen */ -+ -+int -+evbuffer_expand(struct evbuffer *buf, size_t datlen) -+{ -+ size_t need = buf->misalign + buf->off + datlen; -+ -+ /* If we can fit all the data, then we don't have to do anything */ -+ if (buf->totallen >= need) -+ return (0); -+ -+ /* -+ * If the misalignment fulfills our data needs, we just force an -+ * alignment to happen. Afterwards, we have enough space. -+ */ -+ if (buf->misalign >= datlen) { -+ evbuffer_align(buf); -+ } else { -+ void *newbuf; -+ size_t length = buf->totallen; -+ -+ if (length < 256) -+ length = 256; -+ while (length < need) -+ length <<= 1; -+ -+ if (buf->orig_buffer != buf->buffer) -+ evbuffer_align(buf); -+ if ((newbuf = realloc(buf->buffer, length)) == NULL) -+ return (-1); -+ -+ buf->orig_buffer = buf->buffer = newbuf; -+ buf->totallen = length; -+ } -+ -+ return (0); -+} -+ -+int -+evbuffer_add(struct evbuffer *buf, const void *data, size_t datlen) -+{ -+ size_t need = buf->misalign + buf->off + datlen; -+ size_t oldoff = buf->off; -+ -+ if (buf->totallen < need) { -+ if (evbuffer_expand(buf, datlen) == -1) -+ return (-1); -+ } -+ -+ memcpy(buf->buffer + buf->off, data, datlen); -+ buf->off += datlen; -+ -+ if (datlen && buf->cb != NULL) -+ (*buf->cb)(buf, oldoff, buf->off, buf->cbarg); -+ -+ return (0); -+} -+ -+void -+evbuffer_drain(struct evbuffer *buf, size_t len) -+{ -+ size_t oldoff = buf->off; -+ -+ if (len >= buf->off) { -+ buf->off = 0; -+ buf->buffer = buf->orig_buffer; -+ buf->misalign = 0; -+ goto done; -+ } -+ -+ buf->buffer += len; -+ buf->misalign += len; -+ -+ buf->off -= len; -+ -+ done: -+ /* Tell someone about changes in this buffer */ -+ if (buf->off != oldoff && buf->cb != NULL) -+ (*buf->cb)(buf, oldoff, buf->off, buf->cbarg); -+ -+} -+ -+/* -+ * Reads data from a file descriptor into a buffer. -+ */ -+ -+#define EVBUFFER_MAX_READ 4096 -+ -+int -+evbuffer_read(struct evbuffer *buf, int fd, int howmuch) -+{ -+ u_char *p; -+ size_t oldoff = buf->off; -+ int n = EVBUFFER_MAX_READ; -+ -+#if defined(FIONREAD) -+#ifdef WIN32 -+ long lng = n; -+ if (ioctlsocket(fd, FIONREAD, &lng) == -1 || (n=lng) == 0) { -+#else -+ if (ioctl(fd, FIONREAD, &n) == -1 || n == 0) { -+#endif -+ n = EVBUFFER_MAX_READ; -+ } else if (n > EVBUFFER_MAX_READ && n > howmuch) { -+ /* -+ * It's possible that a lot of data is available for -+ * reading. We do not want to exhaust resources -+ * before the reader has a chance to do something -+ * about it. If the reader does not tell us how much -+ * data we should read, we artifically limit it. -+ */ -+ if (n > buf->totallen << 2) -+ n = buf->totallen << 2; -+ if (n < EVBUFFER_MAX_READ) -+ n = EVBUFFER_MAX_READ; -+ } -+#endif -+ if (howmuch < 0 || howmuch > n) -+ howmuch = n; -+ -+ /* If we don't have FIONREAD, we might waste some space here */ -+ if (evbuffer_expand(buf, howmuch) == -1) -+ return (-1); -+ -+ /* We can append new data at this point */ -+ p = buf->buffer + buf->off; -+ -+#ifndef WIN32 -+ n = read(fd, p, howmuch); -+#else -+ n = recv(fd, p, howmuch, 0); -+#endif -+ if (n == -1) -+ return (-1); -+ if (n == 0) -+ return (0); -+ -+ buf->off += n; -+ -+ /* Tell someone about changes in this buffer */ -+ if (buf->off != oldoff && buf->cb != NULL) -+ (*buf->cb)(buf, oldoff, buf->off, buf->cbarg); -+ -+ return (n); -+} -+ -+int -+evbuffer_write(struct evbuffer *buffer, int fd) -+{ -+ int n; -+ -+#ifndef WIN32 -+ n = write(fd, buffer->buffer, buffer->off); -+#else -+ n = send(fd, buffer->buffer, buffer->off, 0); -+#endif -+ if (n == -1) -+ return (-1); -+ if (n == 0) -+ return (0); -+ evbuffer_drain(buffer, n); -+ -+ return (n); -+} -+ -+u_char * -+evbuffer_find(struct evbuffer *buffer, const u_char *what, size_t len) -+{ -+ u_char *search = buffer->buffer, *end = search + buffer->off; -+ u_char *p; -+ -+ while (search < end && -+ (p = memchr(search, *what, end - search)) != NULL) { -+ if (p + len > end) -+ break; -+ if (memcmp(p, what, len) == 0) -+ return (p); -+ search = p + 1; -+ } -+ -+ return (NULL); -+} -+ -+void evbuffer_setcb(struct evbuffer *buffer, -+ void (*cb)(struct evbuffer *, size_t, size_t, void *), -+ void *cbarg) -+{ -+ buffer->cb = cb; -+ buffer->cbarg = cbarg; -+} -diff --git a/libevent/compat/sys/_time.h b/libevent/compat/sys/_time.h -new file mode 100644 -index 0000000..8cabb0d ---- /dev/null -+++ b/libevent/compat/sys/_time.h -@@ -0,0 +1,163 @@ -+/* $OpenBSD: time.h,v 1.11 2000/10/10 13:36:48 itojun Exp $ */ -+/* $NetBSD: time.h,v 1.18 1996/04/23 10:29:33 mycroft Exp $ */ -+ -+/* -+ * Copyright (c) 1982, 1986, 1993 -+ * The Regents of the University of California. All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. Neither the name of the University nor the names of its contributors -+ * may be used to endorse or promote products derived from this software -+ * without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND -+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -+ * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE -+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL -+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS -+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) -+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY -+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF -+ * SUCH DAMAGE. -+ * -+ * @(#)time.h 8.2 (Berkeley) 7/10/94 -+ */ -+ -+#ifndef _SYS_TIME_H_ -+#define _SYS_TIME_H_ -+ -+#include -+ -+/* -+ * Structure returned by gettimeofday(2) system call, -+ * and used in other calls. -+ */ -+struct timeval { -+ long tv_sec; /* seconds */ -+ long tv_usec; /* and microseconds */ -+}; -+ -+/* -+ * Structure defined by POSIX.1b to be like a timeval. -+ */ -+struct timespec { -+ time_t tv_sec; /* seconds */ -+ long tv_nsec; /* and nanoseconds */ -+}; -+ -+#define TIMEVAL_TO_TIMESPEC(tv, ts) { \ -+ (ts)->tv_sec = (tv)->tv_sec; \ -+ (ts)->tv_nsec = (tv)->tv_usec * 1000; \ -+} -+#define TIMESPEC_TO_TIMEVAL(tv, ts) { \ -+ (tv)->tv_sec = (ts)->tv_sec; \ -+ (tv)->tv_usec = (ts)->tv_nsec / 1000; \ -+} -+ -+struct timezone { -+ int tz_minuteswest; /* minutes west of Greenwich */ -+ int tz_dsttime; /* type of dst correction */ -+}; -+#define DST_NONE 0 /* not on dst */ -+#define DST_USA 1 /* USA style dst */ -+#define DST_AUST 2 /* Australian style dst */ -+#define DST_WET 3 /* Western European dst */ -+#define DST_MET 4 /* Middle European dst */ -+#define DST_EET 5 /* Eastern European dst */ -+#define DST_CAN 6 /* Canada */ -+ -+/* Operations on timevals. */ -+#define timerclear(tvp) (tvp)->tv_sec = (tvp)->tv_usec = 0 -+#define timerisset(tvp) ((tvp)->tv_sec || (tvp)->tv_usec) -+#define timercmp(tvp, uvp, cmp) \ -+ (((tvp)->tv_sec == (uvp)->tv_sec) ? \ -+ ((tvp)->tv_usec cmp (uvp)->tv_usec) : \ -+ ((tvp)->tv_sec cmp (uvp)->tv_sec)) -+#define timeradd(tvp, uvp, vvp) \ -+ do { \ -+ (vvp)->tv_sec = (tvp)->tv_sec + (uvp)->tv_sec; \ -+ (vvp)->tv_usec = (tvp)->tv_usec + (uvp)->tv_usec; \ -+ if ((vvp)->tv_usec >= 1000000) { \ -+ (vvp)->tv_sec++; \ -+ (vvp)->tv_usec -= 1000000; \ -+ } \ -+ } while (0) -+#define timersub(tvp, uvp, vvp) \ -+ do { \ -+ (vvp)->tv_sec = (tvp)->tv_sec - (uvp)->tv_sec; \ -+ (vvp)->tv_usec = (tvp)->tv_usec - (uvp)->tv_usec; \ -+ if ((vvp)->tv_usec < 0) { \ -+ (vvp)->tv_sec--; \ -+ (vvp)->tv_usec += 1000000; \ -+ } \ -+ } while (0) -+ -+/* Operations on timespecs. */ -+#define timespecclear(tsp) (tsp)->tv_sec = (tsp)->tv_nsec = 0 -+#define timespecisset(tsp) ((tsp)->tv_sec || (tsp)->tv_nsec) -+#define timespeccmp(tsp, usp, cmp) \ -+ (((tsp)->tv_sec == (usp)->tv_sec) ? \ -+ ((tsp)->tv_nsec cmp (usp)->tv_nsec) : \ -+ ((tsp)->tv_sec cmp (usp)->tv_sec)) -+#define timespecadd(tsp, usp, vsp) \ -+ do { \ -+ (vsp)->tv_sec = (tsp)->tv_sec + (usp)->tv_sec; \ -+ (vsp)->tv_nsec = (tsp)->tv_nsec + (usp)->tv_nsec; \ -+ if ((vsp)->tv_nsec >= 1000000000L) { \ -+ (vsp)->tv_sec++; \ -+ (vsp)->tv_nsec -= 1000000000L; \ -+ } \ -+ } while (0) -+#define timespecsub(tsp, usp, vsp) \ -+ do { \ -+ (vsp)->tv_sec = (tsp)->tv_sec - (usp)->tv_sec; \ -+ (vsp)->tv_nsec = (tsp)->tv_nsec - (usp)->tv_nsec; \ -+ if ((vsp)->tv_nsec < 0) { \ -+ (vsp)->tv_sec--; \ -+ (vsp)->tv_nsec += 1000000000L; \ -+ } \ -+ } while (0) -+ -+/* -+ * Names of the interval timers, and structure -+ * defining a timer setting. -+ */ -+#define ITIMER_REAL 0 -+#define ITIMER_VIRTUAL 1 -+#define ITIMER_PROF 2 -+ -+struct itimerval { -+ struct timeval it_interval; /* timer interval */ -+ struct timeval it_value; /* current value */ -+}; -+ -+/* -+ * Getkerninfo clock information structure -+ */ -+struct clockinfo { -+ int hz; /* clock frequency */ -+ int tick; /* micro-seconds per hz tick */ -+ int tickadj; /* clock skew rate for adjtime() */ -+ int stathz; /* statistics clock frequency */ -+ int profhz; /* profiling clock frequency */ -+}; -+ -+#define CLOCK_REALTIME 0 -+#define CLOCK_VIRTUAL 1 -+#define CLOCK_PROF 2 -+ -+#define TIMER_RELTIME 0x0 /* relative timer */ -+#define TIMER_ABSTIME 0x1 /* absolute timer */ -+ -+/* --- stuff got cut here - niels --- */ -+ -+#endif /* !_SYS_TIME_H_ */ -diff --git a/libevent/compat/sys/queue.h b/libevent/compat/sys/queue.h -new file mode 100644 -index 0000000..c0956dd ---- /dev/null -+++ b/libevent/compat/sys/queue.h -@@ -0,0 +1,488 @@ -+/* $OpenBSD: queue.h,v 1.16 2000/09/07 19:47:59 art Exp $ */ -+/* $NetBSD: queue.h,v 1.11 1996/05/16 05:17:14 mycroft Exp $ */ -+ -+/* -+ * Copyright (c) 1991, 1993 -+ * The Regents of the University of California. All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. Neither the name of the University nor the names of its contributors -+ * may be used to endorse or promote products derived from this software -+ * without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND -+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -+ * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE -+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL -+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS -+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) -+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY -+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF -+ * SUCH DAMAGE. -+ * -+ * @(#)queue.h 8.5 (Berkeley) 8/20/94 -+ */ -+ -+#ifndef _SYS_QUEUE_H_ -+#define _SYS_QUEUE_H_ -+ -+/* -+ * This file defines five types of data structures: singly-linked lists, -+ * lists, simple queues, tail queues, and circular queues. -+ * -+ * -+ * A singly-linked list is headed by a single forward pointer. The elements -+ * are singly linked for minimum space and pointer manipulation overhead at -+ * the expense of O(n) removal for arbitrary elements. New elements can be -+ * added to the list after an existing element or at the head of the list. -+ * Elements being removed from the head of the list should use the explicit -+ * macro for this purpose for optimum efficiency. A singly-linked list may -+ * only be traversed in the forward direction. Singly-linked lists are ideal -+ * for applications with large datasets and few or no removals or for -+ * implementing a LIFO queue. -+ * -+ * A list is headed by a single forward pointer (or an array of forward -+ * pointers for a hash table header). The elements are doubly linked -+ * so that an arbitrary element can be removed without a need to -+ * traverse the list. New elements can be added to the list before -+ * or after an existing element or at the head of the list. A list -+ * may only be traversed in the forward direction. -+ * -+ * A simple queue is headed by a pair of pointers, one the head of the -+ * list and the other to the tail of the list. The elements are singly -+ * linked to save space, so elements can only be removed from the -+ * head of the list. New elements can be added to the list before or after -+ * an existing element, at the head of the list, or at the end of the -+ * list. A simple queue may only be traversed in the forward direction. -+ * -+ * A tail queue is headed by a pair of pointers, one to the head of the -+ * list and the other to the tail of the list. The elements are doubly -+ * linked so that an arbitrary element can be removed without a need to -+ * traverse the list. New elements can be added to the list before or -+ * after an existing element, at the head of the list, or at the end of -+ * the list. A tail queue may be traversed in either direction. -+ * -+ * A circle queue is headed by a pair of pointers, one to the head of the -+ * list and the other to the tail of the list. The elements are doubly -+ * linked so that an arbitrary element can be removed without a need to -+ * traverse the list. New elements can be added to the list before or after -+ * an existing element, at the head of the list, or at the end of the list. -+ * A circle queue may be traversed in either direction, but has a more -+ * complex end of list detection. -+ * -+ * For details on the use of these macros, see the queue(3) manual page. -+ */ -+ -+/* -+ * Singly-linked List definitions. -+ */ -+#define SLIST_HEAD(name, type) \ -+struct name { \ -+ struct type *slh_first; /* first element */ \ -+} -+ -+#define SLIST_HEAD_INITIALIZER(head) \ -+ { NULL } -+ -+#ifndef WIN32 -+#define SLIST_ENTRY(type) \ -+struct { \ -+ struct type *sle_next; /* next element */ \ -+} -+#endif -+ -+/* -+ * Singly-linked List access methods. -+ */ -+#define SLIST_FIRST(head) ((head)->slh_first) -+#define SLIST_END(head) NULL -+#define SLIST_EMPTY(head) (SLIST_FIRST(head) == SLIST_END(head)) -+#define SLIST_NEXT(elm, field) ((elm)->field.sle_next) -+ -+#define SLIST_FOREACH(var, head, field) \ -+ for((var) = SLIST_FIRST(head); \ -+ (var) != SLIST_END(head); \ -+ (var) = SLIST_NEXT(var, field)) -+ -+/* -+ * Singly-linked List functions. -+ */ -+#define SLIST_INIT(head) { \ -+ SLIST_FIRST(head) = SLIST_END(head); \ -+} -+ -+#define SLIST_INSERT_AFTER(slistelm, elm, field) do { \ -+ (elm)->field.sle_next = (slistelm)->field.sle_next; \ -+ (slistelm)->field.sle_next = (elm); \ -+} while (0) -+ -+#define SLIST_INSERT_HEAD(head, elm, field) do { \ -+ (elm)->field.sle_next = (head)->slh_first; \ -+ (head)->slh_first = (elm); \ -+} while (0) -+ -+#define SLIST_REMOVE_HEAD(head, field) do { \ -+ (head)->slh_first = (head)->slh_first->field.sle_next; \ -+} while (0) -+ -+/* -+ * List definitions. -+ */ -+#define LIST_HEAD(name, type) \ -+struct name { \ -+ struct type *lh_first; /* first element */ \ -+} -+ -+#define LIST_HEAD_INITIALIZER(head) \ -+ { NULL } -+ -+#define LIST_ENTRY(type) \ -+struct { \ -+ struct type *le_next; /* next element */ \ -+ struct type **le_prev; /* address of previous next element */ \ -+} -+ -+/* -+ * List access methods -+ */ -+#define LIST_FIRST(head) ((head)->lh_first) -+#define LIST_END(head) NULL -+#define LIST_EMPTY(head) (LIST_FIRST(head) == LIST_END(head)) -+#define LIST_NEXT(elm, field) ((elm)->field.le_next) -+ -+#define LIST_FOREACH(var, head, field) \ -+ for((var) = LIST_FIRST(head); \ -+ (var)!= LIST_END(head); \ -+ (var) = LIST_NEXT(var, field)) -+ -+/* -+ * List functions. -+ */ -+#define LIST_INIT(head) do { \ -+ LIST_FIRST(head) = LIST_END(head); \ -+} while (0) -+ -+#define LIST_INSERT_AFTER(listelm, elm, field) do { \ -+ if (((elm)->field.le_next = (listelm)->field.le_next) != NULL) \ -+ (listelm)->field.le_next->field.le_prev = \ -+ &(elm)->field.le_next; \ -+ (listelm)->field.le_next = (elm); \ -+ (elm)->field.le_prev = &(listelm)->field.le_next; \ -+} while (0) -+ -+#define LIST_INSERT_BEFORE(listelm, elm, field) do { \ -+ (elm)->field.le_prev = (listelm)->field.le_prev; \ -+ (elm)->field.le_next = (listelm); \ -+ *(listelm)->field.le_prev = (elm); \ -+ (listelm)->field.le_prev = &(elm)->field.le_next; \ -+} while (0) -+ -+#define LIST_INSERT_HEAD(head, elm, field) do { \ -+ if (((elm)->field.le_next = (head)->lh_first) != NULL) \ -+ (head)->lh_first->field.le_prev = &(elm)->field.le_next;\ -+ (head)->lh_first = (elm); \ -+ (elm)->field.le_prev = &(head)->lh_first; \ -+} while (0) -+ -+#define LIST_REMOVE(elm, field) do { \ -+ if ((elm)->field.le_next != NULL) \ -+ (elm)->field.le_next->field.le_prev = \ -+ (elm)->field.le_prev; \ -+ *(elm)->field.le_prev = (elm)->field.le_next; \ -+} while (0) -+ -+#define LIST_REPLACE(elm, elm2, field) do { \ -+ if (((elm2)->field.le_next = (elm)->field.le_next) != NULL) \ -+ (elm2)->field.le_next->field.le_prev = \ -+ &(elm2)->field.le_next; \ -+ (elm2)->field.le_prev = (elm)->field.le_prev; \ -+ *(elm2)->field.le_prev = (elm2); \ -+} while (0) -+ -+/* -+ * Simple queue definitions. -+ */ -+#define SIMPLEQ_HEAD(name, type) \ -+struct name { \ -+ struct type *sqh_first; /* first element */ \ -+ struct type **sqh_last; /* addr of last next element */ \ -+} -+ -+#define SIMPLEQ_HEAD_INITIALIZER(head) \ -+ { NULL, &(head).sqh_first } -+ -+#define SIMPLEQ_ENTRY(type) \ -+struct { \ -+ struct type *sqe_next; /* next element */ \ -+} -+ -+/* -+ * Simple queue access methods. -+ */ -+#define SIMPLEQ_FIRST(head) ((head)->sqh_first) -+#define SIMPLEQ_END(head) NULL -+#define SIMPLEQ_EMPTY(head) (SIMPLEQ_FIRST(head) == SIMPLEQ_END(head)) -+#define SIMPLEQ_NEXT(elm, field) ((elm)->field.sqe_next) -+ -+#define SIMPLEQ_FOREACH(var, head, field) \ -+ for((var) = SIMPLEQ_FIRST(head); \ -+ (var) != SIMPLEQ_END(head); \ -+ (var) = SIMPLEQ_NEXT(var, field)) -+ -+/* -+ * Simple queue functions. -+ */ -+#define SIMPLEQ_INIT(head) do { \ -+ (head)->sqh_first = NULL; \ -+ (head)->sqh_last = &(head)->sqh_first; \ -+} while (0) -+ -+#define SIMPLEQ_INSERT_HEAD(head, elm, field) do { \ -+ if (((elm)->field.sqe_next = (head)->sqh_first) == NULL) \ -+ (head)->sqh_last = &(elm)->field.sqe_next; \ -+ (head)->sqh_first = (elm); \ -+} while (0) -+ -+#define SIMPLEQ_INSERT_TAIL(head, elm, field) do { \ -+ (elm)->field.sqe_next = NULL; \ -+ *(head)->sqh_last = (elm); \ -+ (head)->sqh_last = &(elm)->field.sqe_next; \ -+} while (0) -+ -+#define SIMPLEQ_INSERT_AFTER(head, listelm, elm, field) do { \ -+ if (((elm)->field.sqe_next = (listelm)->field.sqe_next) == NULL)\ -+ (head)->sqh_last = &(elm)->field.sqe_next; \ -+ (listelm)->field.sqe_next = (elm); \ -+} while (0) -+ -+#define SIMPLEQ_REMOVE_HEAD(head, elm, field) do { \ -+ if (((head)->sqh_first = (elm)->field.sqe_next) == NULL) \ -+ (head)->sqh_last = &(head)->sqh_first; \ -+} while (0) -+ -+/* -+ * Tail queue definitions. -+ */ -+#define TAILQ_HEAD(name, type) \ -+struct name { \ -+ struct type *tqh_first; /* first element */ \ -+ struct type **tqh_last; /* addr of last next element */ \ -+} -+ -+#define TAILQ_HEAD_INITIALIZER(head) \ -+ { NULL, &(head).tqh_first } -+ -+#define TAILQ_ENTRY(type) \ -+struct { \ -+ struct type *tqe_next; /* next element */ \ -+ struct type **tqe_prev; /* address of previous next element */ \ -+} -+ -+/* -+ * tail queue access methods -+ */ -+#define TAILQ_FIRST(head) ((head)->tqh_first) -+#define TAILQ_END(head) NULL -+#define TAILQ_NEXT(elm, field) ((elm)->field.tqe_next) -+#define TAILQ_LAST(head, headname) \ -+ (*(((struct headname *)((head)->tqh_last))->tqh_last)) -+/* XXX */ -+#define TAILQ_PREV(elm, headname, field) \ -+ (*(((struct headname *)((elm)->field.tqe_prev))->tqh_last)) -+#define TAILQ_EMPTY(head) \ -+ (TAILQ_FIRST(head) == TAILQ_END(head)) -+ -+#define TAILQ_FOREACH(var, head, field) \ -+ for((var) = TAILQ_FIRST(head); \ -+ (var) != TAILQ_END(head); \ -+ (var) = TAILQ_NEXT(var, field)) -+ -+#define TAILQ_FOREACH_REVERSE(var, head, field, headname) \ -+ for((var) = TAILQ_LAST(head, headname); \ -+ (var) != TAILQ_END(head); \ -+ (var) = TAILQ_PREV(var, headname, field)) -+ -+/* -+ * Tail queue functions. -+ */ -+#define TAILQ_INIT(head) do { \ -+ (head)->tqh_first = NULL; \ -+ (head)->tqh_last = &(head)->tqh_first; \ -+} while (0) -+ -+#define TAILQ_INSERT_HEAD(head, elm, field) do { \ -+ if (((elm)->field.tqe_next = (head)->tqh_first) != NULL) \ -+ (head)->tqh_first->field.tqe_prev = \ -+ &(elm)->field.tqe_next; \ -+ else \ -+ (head)->tqh_last = &(elm)->field.tqe_next; \ -+ (head)->tqh_first = (elm); \ -+ (elm)->field.tqe_prev = &(head)->tqh_first; \ -+} while (0) -+ -+#define TAILQ_INSERT_TAIL(head, elm, field) do { \ -+ (elm)->field.tqe_next = NULL; \ -+ (elm)->field.tqe_prev = (head)->tqh_last; \ -+ *(head)->tqh_last = (elm); \ -+ (head)->tqh_last = &(elm)->field.tqe_next; \ -+} while (0) -+ -+#define TAILQ_INSERT_AFTER(head, listelm, elm, field) do { \ -+ if (((elm)->field.tqe_next = (listelm)->field.tqe_next) != NULL)\ -+ (elm)->field.tqe_next->field.tqe_prev = \ -+ &(elm)->field.tqe_next; \ -+ else \ -+ (head)->tqh_last = &(elm)->field.tqe_next; \ -+ (listelm)->field.tqe_next = (elm); \ -+ (elm)->field.tqe_prev = &(listelm)->field.tqe_next; \ -+} while (0) -+ -+#define TAILQ_INSERT_BEFORE(listelm, elm, field) do { \ -+ (elm)->field.tqe_prev = (listelm)->field.tqe_prev; \ -+ (elm)->field.tqe_next = (listelm); \ -+ *(listelm)->field.tqe_prev = (elm); \ -+ (listelm)->field.tqe_prev = &(elm)->field.tqe_next; \ -+} while (0) -+ -+#define TAILQ_REMOVE(head, elm, field) do { \ -+ if (((elm)->field.tqe_next) != NULL) \ -+ (elm)->field.tqe_next->field.tqe_prev = \ -+ (elm)->field.tqe_prev; \ -+ else \ -+ (head)->tqh_last = (elm)->field.tqe_prev; \ -+ *(elm)->field.tqe_prev = (elm)->field.tqe_next; \ -+} while (0) -+ -+#define TAILQ_REPLACE(head, elm, elm2, field) do { \ -+ if (((elm2)->field.tqe_next = (elm)->field.tqe_next) != NULL) \ -+ (elm2)->field.tqe_next->field.tqe_prev = \ -+ &(elm2)->field.tqe_next; \ -+ else \ -+ (head)->tqh_last = &(elm2)->field.tqe_next; \ -+ (elm2)->field.tqe_prev = (elm)->field.tqe_prev; \ -+ *(elm2)->field.tqe_prev = (elm2); \ -+} while (0) -+ -+/* -+ * Circular queue definitions. -+ */ -+#define CIRCLEQ_HEAD(name, type) \ -+struct name { \ -+ struct type *cqh_first; /* first element */ \ -+ struct type *cqh_last; /* last element */ \ -+} -+ -+#define CIRCLEQ_HEAD_INITIALIZER(head) \ -+ { CIRCLEQ_END(&head), CIRCLEQ_END(&head) } -+ -+#define CIRCLEQ_ENTRY(type) \ -+struct { \ -+ struct type *cqe_next; /* next element */ \ -+ struct type *cqe_prev; /* previous element */ \ -+} -+ -+/* -+ * Circular queue access methods -+ */ -+#define CIRCLEQ_FIRST(head) ((head)->cqh_first) -+#define CIRCLEQ_LAST(head) ((head)->cqh_last) -+#define CIRCLEQ_END(head) ((void *)(head)) -+#define CIRCLEQ_NEXT(elm, field) ((elm)->field.cqe_next) -+#define CIRCLEQ_PREV(elm, field) ((elm)->field.cqe_prev) -+#define CIRCLEQ_EMPTY(head) \ -+ (CIRCLEQ_FIRST(head) == CIRCLEQ_END(head)) -+ -+#define CIRCLEQ_FOREACH(var, head, field) \ -+ for((var) = CIRCLEQ_FIRST(head); \ -+ (var) != CIRCLEQ_END(head); \ -+ (var) = CIRCLEQ_NEXT(var, field)) -+ -+#define CIRCLEQ_FOREACH_REVERSE(var, head, field) \ -+ for((var) = CIRCLEQ_LAST(head); \ -+ (var) != CIRCLEQ_END(head); \ -+ (var) = CIRCLEQ_PREV(var, field)) -+ -+/* -+ * Circular queue functions. -+ */ -+#define CIRCLEQ_INIT(head) do { \ -+ (head)->cqh_first = CIRCLEQ_END(head); \ -+ (head)->cqh_last = CIRCLEQ_END(head); \ -+} while (0) -+ -+#define CIRCLEQ_INSERT_AFTER(head, listelm, elm, field) do { \ -+ (elm)->field.cqe_next = (listelm)->field.cqe_next; \ -+ (elm)->field.cqe_prev = (listelm); \ -+ if ((listelm)->field.cqe_next == CIRCLEQ_END(head)) \ -+ (head)->cqh_last = (elm); \ -+ else \ -+ (listelm)->field.cqe_next->field.cqe_prev = (elm); \ -+ (listelm)->field.cqe_next = (elm); \ -+} while (0) -+ -+#define CIRCLEQ_INSERT_BEFORE(head, listelm, elm, field) do { \ -+ (elm)->field.cqe_next = (listelm); \ -+ (elm)->field.cqe_prev = (listelm)->field.cqe_prev; \ -+ if ((listelm)->field.cqe_prev == CIRCLEQ_END(head)) \ -+ (head)->cqh_first = (elm); \ -+ else \ -+ (listelm)->field.cqe_prev->field.cqe_next = (elm); \ -+ (listelm)->field.cqe_prev = (elm); \ -+} while (0) -+ -+#define CIRCLEQ_INSERT_HEAD(head, elm, field) do { \ -+ (elm)->field.cqe_next = (head)->cqh_first; \ -+ (elm)->field.cqe_prev = CIRCLEQ_END(head); \ -+ if ((head)->cqh_last == CIRCLEQ_END(head)) \ -+ (head)->cqh_last = (elm); \ -+ else \ -+ (head)->cqh_first->field.cqe_prev = (elm); \ -+ (head)->cqh_first = (elm); \ -+} while (0) -+ -+#define CIRCLEQ_INSERT_TAIL(head, elm, field) do { \ -+ (elm)->field.cqe_next = CIRCLEQ_END(head); \ -+ (elm)->field.cqe_prev = (head)->cqh_last; \ -+ if ((head)->cqh_first == CIRCLEQ_END(head)) \ -+ (head)->cqh_first = (elm); \ -+ else \ -+ (head)->cqh_last->field.cqe_next = (elm); \ -+ (head)->cqh_last = (elm); \ -+} while (0) -+ -+#define CIRCLEQ_REMOVE(head, elm, field) do { \ -+ if ((elm)->field.cqe_next == CIRCLEQ_END(head)) \ -+ (head)->cqh_last = (elm)->field.cqe_prev; \ -+ else \ -+ (elm)->field.cqe_next->field.cqe_prev = \ -+ (elm)->field.cqe_prev; \ -+ if ((elm)->field.cqe_prev == CIRCLEQ_END(head)) \ -+ (head)->cqh_first = (elm)->field.cqe_next; \ -+ else \ -+ (elm)->field.cqe_prev->field.cqe_next = \ -+ (elm)->field.cqe_next; \ -+} while (0) -+ -+#define CIRCLEQ_REPLACE(head, elm, elm2, field) do { \ -+ if (((elm2)->field.cqe_next = (elm)->field.cqe_next) == \ -+ CIRCLEQ_END(head)) \ -+ (head).cqh_last = (elm2); \ -+ else \ -+ (elm2)->field.cqe_next->field.cqe_prev = (elm2); \ -+ if (((elm2)->field.cqe_prev = (elm)->field.cqe_prev) == \ -+ CIRCLEQ_END(head)) \ -+ (head).cqh_first = (elm2); \ -+ else \ -+ (elm2)->field.cqe_prev->field.cqe_next = (elm2); \ -+} while (0) -+ -+#endif /* !_SYS_QUEUE_H_ */ -diff --git a/libevent/config.h.in b/libevent/config.h.in -new file mode 100644 -index 0000000..d151f87 ---- /dev/null -+++ b/libevent/config.h.in -@@ -0,0 +1,250 @@ -+/* config.h.in. Generated from configure.in by autoheader. */ -+ -+/* Define if clock_gettime is available in libc */ -+#undef DNS_USE_CPU_CLOCK_FOR_ID -+ -+/* Define is no secure id variant is available */ -+#undef DNS_USE_GETTIMEOFDAY_FOR_ID -+ -+/* Define to 1 if you have the `clock_gettime' function. */ -+#undef HAVE_CLOCK_GETTIME -+ -+/* Define if /dev/poll is available */ -+#undef HAVE_DEVPOLL -+ -+/* Define if your system supports the epoll system calls */ -+#undef HAVE_EPOLL -+ -+/* Define to 1 if you have the `epoll_ctl' function. */ -+#undef HAVE_EPOLL_CTL -+ -+/* Define if your system supports event ports */ -+#undef HAVE_EVENT_PORTS -+ -+/* Define to 1 if you have the `fcntl' function. */ -+#undef HAVE_FCNTL -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_FCNTL_H -+ -+/* Define to 1 if you have the `getaddrinfo' function. */ -+#undef HAVE_GETADDRINFO -+ -+/* Define to 1 if you have the `getnameinfo' function. */ -+#undef HAVE_GETNAMEINFO -+ -+/* Define to 1 if you have the `gettimeofday' function. */ -+#undef HAVE_GETTIMEOFDAY -+ -+/* Define to 1 if you have the `inet_ntop' function. */ -+#undef HAVE_INET_NTOP -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_INTTYPES_H -+ -+/* Define to 1 if you have the `kqueue' function. */ -+#undef HAVE_KQUEUE -+ -+/* Define to 1 if you have the `nsl' library (-lnsl). */ -+#undef HAVE_LIBNSL -+ -+/* Define to 1 if you have the `resolv' library (-lresolv). */ -+#undef HAVE_LIBRESOLV -+ -+/* Define to 1 if you have the `rt' library (-lrt). */ -+#undef HAVE_LIBRT -+ -+/* Define to 1 if you have the `socket' library (-lsocket). */ -+#undef HAVE_LIBSOCKET -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_MEMORY_H -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_NETINET_IN6_H -+ -+/* Define to 1 if you have the `poll' function. */ -+#undef HAVE_POLL -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_POLL_H -+ -+/* Define to 1 if you have the `port_create' function. */ -+#undef HAVE_PORT_CREATE -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_PORT_H -+ -+/* Define to 1 if you have the `select' function. */ -+#undef HAVE_SELECT -+ -+/* Define if F_SETFD is defined in */ -+#undef HAVE_SETFD -+ -+/* Define to 1 if you have the `sigaction' function. */ -+#undef HAVE_SIGACTION -+ -+/* Define to 1 if you have the `signal' function. */ -+#undef HAVE_SIGNAL -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_SIGNAL_H -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_STDARG_H -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_STDINT_H -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_STDLIB_H -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_STRINGS_H -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_STRING_H -+ -+/* Define to 1 if you have the `strlcpy' function. */ -+#undef HAVE_STRLCPY -+ -+/* Define to 1 if you have the `strsep' function. */ -+#undef HAVE_STRSEP -+ -+/* Define to 1 if you have the `strtok_r' function. */ -+#undef HAVE_STRTOK_R -+ -+/* Define to 1 if you have the `strtoll' function. */ -+#undef HAVE_STRTOLL -+ -+/* Define to 1 if the system has the type `struct in6_addr'. */ -+#undef HAVE_STRUCT_IN6_ADDR -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_SYS_DEVPOLL_H -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_SYS_EPOLL_H -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_SYS_EVENT_H -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_SYS_IOCTL_H -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_SYS_PARAM_H -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_SYS_QUEUE_H -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_SYS_SELECT_H -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_SYS_SOCKET_H -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_SYS_STAT_H -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_SYS_TIME_H -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_SYS_TYPES_H -+ -+/* Define if TAILQ_FOREACH is defined in */ -+#undef HAVE_TAILQFOREACH -+ -+/* Define if timeradd is defined in */ -+#undef HAVE_TIMERADD -+ -+/* Define if timerclear is defined in */ -+#undef HAVE_TIMERCLEAR -+ -+/* Define if timercmp is defined in */ -+#undef HAVE_TIMERCMP -+ -+/* Define if timerisset is defined in */ -+#undef HAVE_TIMERISSET -+ -+/* Define to 1 if the system has the type `uint16_t'. */ -+#undef HAVE_UINT16_T -+ -+/* Define to 1 if the system has the type `uint32_t'. */ -+#undef HAVE_UINT32_T -+ -+/* Define to 1 if the system has the type `uint64_t'. */ -+#undef HAVE_UINT64_T -+ -+/* Define to 1 if the system has the type `uint8_t'. */ -+#undef HAVE_UINT8_T -+ -+/* Define to 1 if you have the header file. */ -+#undef HAVE_UNISTD_H -+ -+/* Define to 1 if you have the `vasprintf' function. */ -+#undef HAVE_VASPRINTF -+ -+/* Define if kqueue works correctly with pipes */ -+#undef HAVE_WORKING_KQUEUE -+ -+/* Name of package */ -+#undef PACKAGE -+ -+/* Define to the address where bug reports for this package should be sent. */ -+#undef PACKAGE_BUGREPORT -+ -+/* Define to the full name of this package. */ -+#undef PACKAGE_NAME -+ -+/* Define to the full name and version of this package. */ -+#undef PACKAGE_STRING -+ -+/* Define to the one symbol short name of this package. */ -+#undef PACKAGE_TARNAME -+ -+/* Define to the version of this package. */ -+#undef PACKAGE_VERSION -+ -+/* The size of a `int', as computed by sizeof. */ -+#undef SIZEOF_INT -+ -+/* The size of a `long', as computed by sizeof. */ -+#undef SIZEOF_LONG -+ -+/* The size of a `long long', as computed by sizeof. */ -+#undef SIZEOF_LONG_LONG -+ -+/* The size of a `short', as computed by sizeof. */ -+#undef SIZEOF_SHORT -+ -+/* Define to 1 if you have the ANSI C header files. */ -+#undef STDC_HEADERS -+ -+/* Define to 1 if you can safely include both and . */ -+#undef TIME_WITH_SYS_TIME -+ -+/* Version number of package */ -+#undef VERSION -+ -+/* Define to appropriate substitue if compiler doesnt have __func__ */ -+#undef __func__ -+ -+/* Define to empty if `const' does not conform to ANSI C. */ -+#undef const -+ -+/* Define to `__inline__' or `__inline' if that's what the C compiler -+ calls it, or to nothing if 'inline' is not supported under any name. */ -+#ifndef __cplusplus -+#undef inline -+#endif -+ -+/* Define to `int' if does not define. */ -+#undef pid_t -+ -+/* Define to `unsigned' if does not define. */ -+#undef size_t -+ -+/* Define to unsigned int if you dont have it */ -+#undef socklen_t -diff --git a/libevent/configure b/libevent/configure -new file mode 100644 -index 0000000..0a74aec ---- /dev/null -+++ b/libevent/configure -@@ -0,0 +1,9730 @@ -+#! /bin/sh -+# Guess values for system-dependent variables and create Makefiles. -+# Generated by GNU Autoconf 2.59. -+# -+# Copyright (C) 2003 Free Software Foundation, Inc. -+# This configure script is free software; the Free Software Foundation -+# gives unlimited permission to copy, distribute and modify it. -+## --------------------- ## -+## M4sh Initialization. ## -+## --------------------- ## -+ -+# Be Bourne compatible -+if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then -+ emulate sh -+ NULLCMD=: -+ # Zsh 3.x and 4.x performs word splitting on ${1+"$@"}, which -+ # is contrary to our usage. Disable this feature. -+ alias -g '${1+"$@"}'='"$@"' -+elif test -n "${BASH_VERSION+set}" && (set -o posix) >/dev/null 2>&1; then -+ set -o posix -+fi -+DUALCASE=1; export DUALCASE # for MKS sh -+ -+# Support unset when possible. -+if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then -+ as_unset=unset -+else -+ as_unset=false -+fi -+ -+ -+# Work around bugs in pre-3.0 UWIN ksh. -+$as_unset ENV MAIL MAILPATH -+PS1='$ ' -+PS2='> ' -+PS4='+ ' -+ -+# NLS nuisances. -+for as_var in \ -+ LANG LANGUAGE LC_ADDRESS LC_ALL LC_COLLATE LC_CTYPE LC_IDENTIFICATION \ -+ LC_MEASUREMENT LC_MESSAGES LC_MONETARY LC_NAME LC_NUMERIC LC_PAPER \ -+ LC_TELEPHONE LC_TIME -+do -+ if (set +x; test -z "`(eval $as_var=C; export $as_var) 2>&1`"); then -+ eval $as_var=C; export $as_var -+ else -+ $as_unset $as_var -+ fi -+done -+ -+# Required to use basename. -+if expr a : '\(a\)' >/dev/null 2>&1; then -+ as_expr=expr -+else -+ as_expr=false -+fi -+ -+if (basename /) >/dev/null 2>&1 && test "X`basename / 2>&1`" = "X/"; then -+ as_basename=basename -+else -+ as_basename=false -+fi -+ -+ -+# Name of the executable. -+as_me=`$as_basename "$0" || -+$as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ -+ X"$0" : 'X\(//\)$' \| \ -+ X"$0" : 'X\(/\)$' \| \ -+ . : '\(.\)' 2>/dev/null || -+echo X/"$0" | -+ sed '/^.*\/\([^/][^/]*\)\/*$/{ s//\1/; q; } -+ /^X\/\(\/\/\)$/{ s//\1/; q; } -+ /^X\/\(\/\).*/{ s//\1/; q; } -+ s/.*/./; q'` -+ -+ -+# PATH needs CR, and LINENO needs CR and PATH. -+# Avoid depending upon Character Ranges. -+as_cr_letters='abcdefghijklmnopqrstuvwxyz' -+as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' -+as_cr_Letters=$as_cr_letters$as_cr_LETTERS -+as_cr_digits='0123456789' -+as_cr_alnum=$as_cr_Letters$as_cr_digits -+ -+# The user is always right. -+if test "${PATH_SEPARATOR+set}" != set; then -+ echo "#! /bin/sh" >conf$$.sh -+ echo "exit 0" >>conf$$.sh -+ chmod +x conf$$.sh -+ if (PATH="/nonexistent;."; conf$$.sh) >/dev/null 2>&1; then -+ PATH_SEPARATOR=';' -+ else -+ PATH_SEPARATOR=: -+ fi -+ rm -f conf$$.sh -+fi -+ -+ -+ as_lineno_1=$LINENO -+ as_lineno_2=$LINENO -+ as_lineno_3=`(expr $as_lineno_1 + 1) 2>/dev/null` -+ test "x$as_lineno_1" != "x$as_lineno_2" && -+ test "x$as_lineno_3" = "x$as_lineno_2" || { -+ # Find who we are. Look in the path if we contain no path at all -+ # relative or not. -+ case $0 in -+ *[\\/]* ) as_myself=$0 ;; -+ *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -+for as_dir in $PATH -+do -+ IFS=$as_save_IFS -+ test -z "$as_dir" && as_dir=. -+ test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break -+done -+ -+ ;; -+ esac -+ # We did not find ourselves, most probably we were run as `sh COMMAND' -+ # in which case we are not to be found in the path. -+ if test "x$as_myself" = x; then -+ as_myself=$0 -+ fi -+ if test ! -f "$as_myself"; then -+ { echo "$as_me: error: cannot find myself; rerun with an absolute path" >&2 -+ { (exit 1); exit 1; }; } -+ fi -+ case $CONFIG_SHELL in -+ '') -+ as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -+for as_dir in /bin$PATH_SEPARATOR/usr/bin$PATH_SEPARATOR$PATH -+do -+ IFS=$as_save_IFS -+ test -z "$as_dir" && as_dir=. -+ for as_base in sh bash ksh sh5; do -+ case $as_dir in -+ /*) -+ if ("$as_dir/$as_base" -c ' -+ as_lineno_1=$LINENO -+ as_lineno_2=$LINENO -+ as_lineno_3=`(expr $as_lineno_1 + 1) 2>/dev/null` -+ test "x$as_lineno_1" != "x$as_lineno_2" && -+ test "x$as_lineno_3" = "x$as_lineno_2" ') 2>/dev/null; then -+ $as_unset BASH_ENV || test "${BASH_ENV+set}" != set || { BASH_ENV=; export BASH_ENV; } -+ $as_unset ENV || test "${ENV+set}" != set || { ENV=; export ENV; } -+ CONFIG_SHELL=$as_dir/$as_base -+ export CONFIG_SHELL -+ exec "$CONFIG_SHELL" "$0" ${1+"$@"} -+ fi;; -+ esac -+ done -+done -+;; -+ esac -+ -+ # Create $as_me.lineno as a copy of $as_myself, but with $LINENO -+ # uniformly replaced by the line number. The first 'sed' inserts a -+ # line-number line before each line; the second 'sed' does the real -+ # work. The second script uses 'N' to pair each line-number line -+ # with the numbered line, and appends trailing '-' during -+ # substitution so that $LINENO is not a special case at line end. -+ # (Raja R Harinath suggested sed '=', and Paul Eggert wrote the -+ # second 'sed' script. Blame Lee E. McMahon for sed's syntax. :-) -+ sed '=' <$as_myself | -+ sed ' -+ N -+ s,$,-, -+ : loop -+ s,^\(['$as_cr_digits']*\)\(.*\)[$]LINENO\([^'$as_cr_alnum'_]\),\1\2\1\3, -+ t loop -+ s,-$,, -+ s,^['$as_cr_digits']*\n,, -+ ' >$as_me.lineno && -+ chmod +x $as_me.lineno || -+ { echo "$as_me: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&2 -+ { (exit 1); exit 1; }; } -+ -+ # Don't try to exec as it changes $[0], causing all sort of problems -+ # (the dirname of $[0] is not the place where we might find the -+ # original and so on. Autoconf is especially sensible to this). -+ . ./$as_me.lineno -+ # Exit status is that of the last command. -+ exit -+} -+ -+ -+case `echo "testing\c"; echo 1,2,3`,`echo -n testing; echo 1,2,3` in -+ *c*,-n*) ECHO_N= ECHO_C=' -+' ECHO_T=' ' ;; -+ *c*,* ) ECHO_N=-n ECHO_C= ECHO_T= ;; -+ *) ECHO_N= ECHO_C='\c' ECHO_T= ;; -+esac -+ -+if expr a : '\(a\)' >/dev/null 2>&1; then -+ as_expr=expr -+else -+ as_expr=false -+fi -+ -+rm -f conf$$ conf$$.exe conf$$.file -+echo >conf$$.file -+if ln -s conf$$.file conf$$ 2>/dev/null; then -+ # We could just check for DJGPP; but this test a) works b) is more generic -+ # and c) will remain valid once DJGPP supports symlinks (DJGPP 2.04). -+ if test -f conf$$.exe; then -+ # Don't use ln at all; we don't have any links -+ as_ln_s='cp -p' -+ else -+ as_ln_s='ln -s' -+ fi -+elif ln conf$$.file conf$$ 2>/dev/null; then -+ as_ln_s=ln -+else -+ as_ln_s='cp -p' -+fi -+rm -f conf$$ conf$$.exe conf$$.file -+ -+if mkdir -p . 2>/dev/null; then -+ as_mkdir_p=: -+else -+ test -d ./-p && rmdir ./-p -+ as_mkdir_p=false -+fi -+ -+as_executable_p="test -f" -+ -+# Sed expression to map a string onto a valid CPP name. -+as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" -+ -+# Sed expression to map a string onto a valid variable name. -+as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" -+ -+ -+# IFS -+# We need space, tab and new line, in precisely that order. -+as_nl=' -+' -+IFS=" $as_nl" -+ -+# CDPATH. -+$as_unset CDPATH -+ -+ -+# Name of the host. -+# hostname on some systems (SVR3.2, Linux) returns a bogus exit status, -+# so uname gets run too. -+ac_hostname=`(hostname || uname -n) 2>/dev/null | sed 1q` -+ -+exec 6>&1 -+ -+# -+# Initializations. -+# -+ac_default_prefix=/usr/local -+ac_config_libobj_dir=. -+cross_compiling=no -+subdirs= -+MFLAGS= -+MAKEFLAGS= -+SHELL=${CONFIG_SHELL-/bin/sh} -+ -+# Maximum number of lines to put in a shell here document. -+# This variable seems obsolete. It should probably be removed, and -+# only ac_max_sed_lines should be used. -+: ${ac_max_here_lines=38} -+ -+# Identity of this package. -+PACKAGE_NAME= -+PACKAGE_TARNAME= -+PACKAGE_VERSION= -+PACKAGE_STRING= -+PACKAGE_BUGREPORT= -+ -+ac_unique_file="event.c" -+# Factoring default headers for most tests. -+ac_includes_default="\ -+#include -+#if HAVE_SYS_TYPES_H -+# include -+#endif -+#if HAVE_SYS_STAT_H -+# include -+#endif -+#if STDC_HEADERS -+# include -+# include -+#else -+# if HAVE_STDLIB_H -+# include -+# endif -+#endif -+#if HAVE_STRING_H -+# if !STDC_HEADERS && HAVE_MEMORY_H -+# include -+# endif -+# include -+#endif -+#if HAVE_STRINGS_H -+# include -+#endif -+#if HAVE_INTTYPES_H -+# include -+#else -+# if HAVE_STDINT_H -+# include -+# endif -+#endif -+#if HAVE_UNISTD_H -+# include -+#endif" -+ -+ac_subst_vars='SHELL PATH_SEPARATOR PACKAGE_NAME PACKAGE_TARNAME PACKAGE_VERSION PACKAGE_STRING PACKAGE_BUGREPORT exec_prefix prefix program_transform_name bindir sbindir libexecdir datadir sysconfdir sharedstatedir localstatedir libdir includedir oldincludedir infodir mandir build_alias host_alias target_alias DEFS ECHO_C ECHO_N ECHO_T LIBS INSTALL_PROGRAM INSTALL_SCRIPT INSTALL_DATA CYGPATH_W PACKAGE VERSION ACLOCAL AUTOCONF AUTOMAKE AUTOHEADER MAKEINFO install_sh STRIP ac_ct_STRIP INSTALL_STRIP_PROGRAM mkdir_p AWK SET_MAKE am__leading_dot AMTAR am__tar am__untar CC CFLAGS LDFLAGS CPPFLAGS ac_ct_CC EXEEXT OBJEXT DEPDIR am__include am__quote AMDEP_TRUE AMDEP_FALSE AMDEPBACKSLASH CCDEPMODE am__fastdepCC_TRUE am__fastdepCC_FALSE LN_S CPP EGREP RANLIB ac_ct_RANLIB BUILD_WIN32_TRUE BUILD_WIN32_FALSE LIBOBJS LTLIBOBJS' -+ac_subst_files='' -+ -+# Initialize some variables set by options. -+ac_init_help= -+ac_init_version=false -+# The variables have the same names as the options, with -+# dashes changed to underlines. -+cache_file=/dev/null -+exec_prefix=NONE -+no_create= -+no_recursion= -+prefix=NONE -+program_prefix=NONE -+program_suffix=NONE -+program_transform_name=s,x,x, -+silent= -+site= -+srcdir= -+verbose= -+x_includes=NONE -+x_libraries=NONE -+ -+# Installation directory options. -+# These are left unexpanded so users can "make install exec_prefix=/foo" -+# and all the variables that are supposed to be based on exec_prefix -+# by default will actually change. -+# Use braces instead of parens because sh, perl, etc. also accept them. -+bindir='${exec_prefix}/bin' -+sbindir='${exec_prefix}/sbin' -+libexecdir='${exec_prefix}/libexec' -+datadir='${prefix}/share' -+sysconfdir='${prefix}/etc' -+sharedstatedir='${prefix}/com' -+localstatedir='${prefix}/var' -+libdir='${exec_prefix}/lib' -+includedir='${prefix}/include' -+oldincludedir='/usr/include' -+infodir='${prefix}/info' -+mandir='${prefix}/man' -+ -+ac_prev= -+for ac_option -+do -+ # If the previous option needs an argument, assign it. -+ if test -n "$ac_prev"; then -+ eval "$ac_prev=\$ac_option" -+ ac_prev= -+ continue -+ fi -+ -+ ac_optarg=`expr "x$ac_option" : 'x[^=]*=\(.*\)'` -+ -+ # Accept the important Cygnus configure options, so we can diagnose typos. -+ -+ case $ac_option in -+ -+ -bindir | --bindir | --bindi | --bind | --bin | --bi) -+ ac_prev=bindir ;; -+ -bindir=* | --bindir=* | --bindi=* | --bind=* | --bin=* | --bi=*) -+ bindir=$ac_optarg ;; -+ -+ -build | --build | --buil | --bui | --bu) -+ ac_prev=build_alias ;; -+ -build=* | --build=* | --buil=* | --bui=* | --bu=*) -+ build_alias=$ac_optarg ;; -+ -+ -cache-file | --cache-file | --cache-fil | --cache-fi \ -+ | --cache-f | --cache- | --cache | --cach | --cac | --ca | --c) -+ ac_prev=cache_file ;; -+ -cache-file=* | --cache-file=* | --cache-fil=* | --cache-fi=* \ -+ | --cache-f=* | --cache-=* | --cache=* | --cach=* | --cac=* | --ca=* | --c=*) -+ cache_file=$ac_optarg ;; -+ -+ --config-cache | -C) -+ cache_file=config.cache ;; -+ -+ -datadir | --datadir | --datadi | --datad | --data | --dat | --da) -+ ac_prev=datadir ;; -+ -datadir=* | --datadir=* | --datadi=* | --datad=* | --data=* | --dat=* \ -+ | --da=*) -+ datadir=$ac_optarg ;; -+ -+ -disable-* | --disable-*) -+ ac_feature=`expr "x$ac_option" : 'x-*disable-\(.*\)'` -+ # Reject names that are not valid shell variable names. -+ expr "x$ac_feature" : ".*[^-_$as_cr_alnum]" >/dev/null && -+ { echo "$as_me: error: invalid feature name: $ac_feature" >&2 -+ { (exit 1); exit 1; }; } -+ ac_feature=`echo $ac_feature | sed 's/-/_/g'` -+ eval "enable_$ac_feature=no" ;; -+ -+ -enable-* | --enable-*) -+ ac_feature=`expr "x$ac_option" : 'x-*enable-\([^=]*\)'` -+ # Reject names that are not valid shell variable names. -+ expr "x$ac_feature" : ".*[^-_$as_cr_alnum]" >/dev/null && -+ { echo "$as_me: error: invalid feature name: $ac_feature" >&2 -+ { (exit 1); exit 1; }; } -+ ac_feature=`echo $ac_feature | sed 's/-/_/g'` -+ case $ac_option in -+ *=*) ac_optarg=`echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"`;; -+ *) ac_optarg=yes ;; -+ esac -+ eval "enable_$ac_feature='$ac_optarg'" ;; -+ -+ -exec-prefix | --exec_prefix | --exec-prefix | --exec-prefi \ -+ | --exec-pref | --exec-pre | --exec-pr | --exec-p | --exec- \ -+ | --exec | --exe | --ex) -+ ac_prev=exec_prefix ;; -+ -exec-prefix=* | --exec_prefix=* | --exec-prefix=* | --exec-prefi=* \ -+ | --exec-pref=* | --exec-pre=* | --exec-pr=* | --exec-p=* | --exec-=* \ -+ | --exec=* | --exe=* | --ex=*) -+ exec_prefix=$ac_optarg ;; -+ -+ -gas | --gas | --ga | --g) -+ # Obsolete; use --with-gas. -+ with_gas=yes ;; -+ -+ -help | --help | --hel | --he | -h) -+ ac_init_help=long ;; -+ -help=r* | --help=r* | --hel=r* | --he=r* | -hr*) -+ ac_init_help=recursive ;; -+ -help=s* | --help=s* | --hel=s* | --he=s* | -hs*) -+ ac_init_help=short ;; -+ -+ -host | --host | --hos | --ho) -+ ac_prev=host_alias ;; -+ -host=* | --host=* | --hos=* | --ho=*) -+ host_alias=$ac_optarg ;; -+ -+ -includedir | --includedir | --includedi | --included | --include \ -+ | --includ | --inclu | --incl | --inc) -+ ac_prev=includedir ;; -+ -includedir=* | --includedir=* | --includedi=* | --included=* | --include=* \ -+ | --includ=* | --inclu=* | --incl=* | --inc=*) -+ includedir=$ac_optarg ;; -+ -+ -infodir | --infodir | --infodi | --infod | --info | --inf) -+ ac_prev=infodir ;; -+ -infodir=* | --infodir=* | --infodi=* | --infod=* | --info=* | --inf=*) -+ infodir=$ac_optarg ;; -+ -+ -libdir | --libdir | --libdi | --libd) -+ ac_prev=libdir ;; -+ -libdir=* | --libdir=* | --libdi=* | --libd=*) -+ libdir=$ac_optarg ;; -+ -+ -libexecdir | --libexecdir | --libexecdi | --libexecd | --libexec \ -+ | --libexe | --libex | --libe) -+ ac_prev=libexecdir ;; -+ -libexecdir=* | --libexecdir=* | --libexecdi=* | --libexecd=* | --libexec=* \ -+ | --libexe=* | --libex=* | --libe=*) -+ libexecdir=$ac_optarg ;; -+ -+ -localstatedir | --localstatedir | --localstatedi | --localstated \ -+ | --localstate | --localstat | --localsta | --localst \ -+ | --locals | --local | --loca | --loc | --lo) -+ ac_prev=localstatedir ;; -+ -localstatedir=* | --localstatedir=* | --localstatedi=* | --localstated=* \ -+ | --localstate=* | --localstat=* | --localsta=* | --localst=* \ -+ | --locals=* | --local=* | --loca=* | --loc=* | --lo=*) -+ localstatedir=$ac_optarg ;; -+ -+ -mandir | --mandir | --mandi | --mand | --man | --ma | --m) -+ ac_prev=mandir ;; -+ -mandir=* | --mandir=* | --mandi=* | --mand=* | --man=* | --ma=* | --m=*) -+ mandir=$ac_optarg ;; -+ -+ -nfp | --nfp | --nf) -+ # Obsolete; use --without-fp. -+ with_fp=no ;; -+ -+ -no-create | --no-create | --no-creat | --no-crea | --no-cre \ -+ | --no-cr | --no-c | -n) -+ no_create=yes ;; -+ -+ -no-recursion | --no-recursion | --no-recursio | --no-recursi \ -+ | --no-recurs | --no-recur | --no-recu | --no-rec | --no-re | --no-r) -+ no_recursion=yes ;; -+ -+ -oldincludedir | --oldincludedir | --oldincludedi | --oldincluded \ -+ | --oldinclude | --oldinclud | --oldinclu | --oldincl | --oldinc \ -+ | --oldin | --oldi | --old | --ol | --o) -+ ac_prev=oldincludedir ;; -+ -oldincludedir=* | --oldincludedir=* | --oldincludedi=* | --oldincluded=* \ -+ | --oldinclude=* | --oldinclud=* | --oldinclu=* | --oldincl=* | --oldinc=* \ -+ | --oldin=* | --oldi=* | --old=* | --ol=* | --o=*) -+ oldincludedir=$ac_optarg ;; -+ -+ -prefix | --prefix | --prefi | --pref | --pre | --pr | --p) -+ ac_prev=prefix ;; -+ -prefix=* | --prefix=* | --prefi=* | --pref=* | --pre=* | --pr=* | --p=*) -+ prefix=$ac_optarg ;; -+ -+ -program-prefix | --program-prefix | --program-prefi | --program-pref \ -+ | --program-pre | --program-pr | --program-p) -+ ac_prev=program_prefix ;; -+ -program-prefix=* | --program-prefix=* | --program-prefi=* \ -+ | --program-pref=* | --program-pre=* | --program-pr=* | --program-p=*) -+ program_prefix=$ac_optarg ;; -+ -+ -program-suffix | --program-suffix | --program-suffi | --program-suff \ -+ | --program-suf | --program-su | --program-s) -+ ac_prev=program_suffix ;; -+ -program-suffix=* | --program-suffix=* | --program-suffi=* \ -+ | --program-suff=* | --program-suf=* | --program-su=* | --program-s=*) -+ program_suffix=$ac_optarg ;; -+ -+ -program-transform-name | --program-transform-name \ -+ | --program-transform-nam | --program-transform-na \ -+ | --program-transform-n | --program-transform- \ -+ | --program-transform | --program-transfor \ -+ | --program-transfo | --program-transf \ -+ | --program-trans | --program-tran \ -+ | --progr-tra | --program-tr | --program-t) -+ ac_prev=program_transform_name ;; -+ -program-transform-name=* | --program-transform-name=* \ -+ | --program-transform-nam=* | --program-transform-na=* \ -+ | --program-transform-n=* | --program-transform-=* \ -+ | --program-transform=* | --program-transfor=* \ -+ | --program-transfo=* | --program-transf=* \ -+ | --program-trans=* | --program-tran=* \ -+ | --progr-tra=* | --program-tr=* | --program-t=*) -+ program_transform_name=$ac_optarg ;; -+ -+ -q | -quiet | --quiet | --quie | --qui | --qu | --q \ -+ | -silent | --silent | --silen | --sile | --sil) -+ silent=yes ;; -+ -+ -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb) -+ ac_prev=sbindir ;; -+ -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \ -+ | --sbi=* | --sb=*) -+ sbindir=$ac_optarg ;; -+ -+ -sharedstatedir | --sharedstatedir | --sharedstatedi \ -+ | --sharedstated | --sharedstate | --sharedstat | --sharedsta \ -+ | --sharedst | --shareds | --shared | --share | --shar \ -+ | --sha | --sh) -+ ac_prev=sharedstatedir ;; -+ -sharedstatedir=* | --sharedstatedir=* | --sharedstatedi=* \ -+ | --sharedstated=* | --sharedstate=* | --sharedstat=* | --sharedsta=* \ -+ | --sharedst=* | --shareds=* | --shared=* | --share=* | --shar=* \ -+ | --sha=* | --sh=*) -+ sharedstatedir=$ac_optarg ;; -+ -+ -site | --site | --sit) -+ ac_prev=site ;; -+ -site=* | --site=* | --sit=*) -+ site=$ac_optarg ;; -+ -+ -srcdir | --srcdir | --srcdi | --srcd | --src | --sr) -+ ac_prev=srcdir ;; -+ -srcdir=* | --srcdir=* | --srcdi=* | --srcd=* | --src=* | --sr=*) -+ srcdir=$ac_optarg ;; -+ -+ -sysconfdir | --sysconfdir | --sysconfdi | --sysconfd | --sysconf \ -+ | --syscon | --sysco | --sysc | --sys | --sy) -+ ac_prev=sysconfdir ;; -+ -sysconfdir=* | --sysconfdir=* | --sysconfdi=* | --sysconfd=* | --sysconf=* \ -+ | --syscon=* | --sysco=* | --sysc=* | --sys=* | --sy=*) -+ sysconfdir=$ac_optarg ;; -+ -+ -target | --target | --targe | --targ | --tar | --ta | --t) -+ ac_prev=target_alias ;; -+ -target=* | --target=* | --targe=* | --targ=* | --tar=* | --ta=* | --t=*) -+ target_alias=$ac_optarg ;; -+ -+ -v | -verbose | --verbose | --verbos | --verbo | --verb) -+ verbose=yes ;; -+ -+ -version | --version | --versio | --versi | --vers | -V) -+ ac_init_version=: ;; -+ -+ -with-* | --with-*) -+ ac_package=`expr "x$ac_option" : 'x-*with-\([^=]*\)'` -+ # Reject names that are not valid shell variable names. -+ expr "x$ac_package" : ".*[^-_$as_cr_alnum]" >/dev/null && -+ { echo "$as_me: error: invalid package name: $ac_package" >&2 -+ { (exit 1); exit 1; }; } -+ ac_package=`echo $ac_package| sed 's/-/_/g'` -+ case $ac_option in -+ *=*) ac_optarg=`echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"`;; -+ *) ac_optarg=yes ;; -+ esac -+ eval "with_$ac_package='$ac_optarg'" ;; -+ -+ -without-* | --without-*) -+ ac_package=`expr "x$ac_option" : 'x-*without-\(.*\)'` -+ # Reject names that are not valid shell variable names. -+ expr "x$ac_package" : ".*[^-_$as_cr_alnum]" >/dev/null && -+ { echo "$as_me: error: invalid package name: $ac_package" >&2 -+ { (exit 1); exit 1; }; } -+ ac_package=`echo $ac_package | sed 's/-/_/g'` -+ eval "with_$ac_package=no" ;; -+ -+ --x) -+ # Obsolete; use --with-x. -+ with_x=yes ;; -+ -+ -x-includes | --x-includes | --x-include | --x-includ | --x-inclu \ -+ | --x-incl | --x-inc | --x-in | --x-i) -+ ac_prev=x_includes ;; -+ -x-includes=* | --x-includes=* | --x-include=* | --x-includ=* | --x-inclu=* \ -+ | --x-incl=* | --x-inc=* | --x-in=* | --x-i=*) -+ x_includes=$ac_optarg ;; -+ -+ -x-libraries | --x-libraries | --x-librarie | --x-librari \ -+ | --x-librar | --x-libra | --x-libr | --x-lib | --x-li | --x-l) -+ ac_prev=x_libraries ;; -+ -x-libraries=* | --x-libraries=* | --x-librarie=* | --x-librari=* \ -+ | --x-librar=* | --x-libra=* | --x-libr=* | --x-lib=* | --x-li=* | --x-l=*) -+ x_libraries=$ac_optarg ;; -+ -+ -*) { echo "$as_me: error: unrecognized option: $ac_option -+Try \`$0 --help' for more information." >&2 -+ { (exit 1); exit 1; }; } -+ ;; -+ -+ *=*) -+ ac_envvar=`expr "x$ac_option" : 'x\([^=]*\)='` -+ # Reject names that are not valid shell variable names. -+ expr "x$ac_envvar" : ".*[^_$as_cr_alnum]" >/dev/null && -+ { echo "$as_me: error: invalid variable name: $ac_envvar" >&2 -+ { (exit 1); exit 1; }; } -+ ac_optarg=`echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"` -+ eval "$ac_envvar='$ac_optarg'" -+ export $ac_envvar ;; -+ -+ *) -+ # FIXME: should be removed in autoconf 3.0. -+ echo "$as_me: WARNING: you should use --build, --host, --target" >&2 -+ expr "x$ac_option" : ".*[^-._$as_cr_alnum]" >/dev/null && -+ echo "$as_me: WARNING: invalid host type: $ac_option" >&2 -+ : ${build_alias=$ac_option} ${host_alias=$ac_option} ${target_alias=$ac_option} -+ ;; -+ -+ esac -+done -+ -+if test -n "$ac_prev"; then -+ ac_option=--`echo $ac_prev | sed 's/_/-/g'` -+ { echo "$as_me: error: missing argument to $ac_option" >&2 -+ { (exit 1); exit 1; }; } -+fi -+ -+# Be sure to have absolute paths. -+for ac_var in exec_prefix prefix -+do -+ eval ac_val=$`echo $ac_var` -+ case $ac_val in -+ [\\/$]* | ?:[\\/]* | NONE | '' ) ;; -+ *) { echo "$as_me: error: expected an absolute directory name for --$ac_var: $ac_val" >&2 -+ { (exit 1); exit 1; }; };; -+ esac -+done -+ -+# Be sure to have absolute paths. -+for ac_var in bindir sbindir libexecdir datadir sysconfdir sharedstatedir \ -+ localstatedir libdir includedir oldincludedir infodir mandir -+do -+ eval ac_val=$`echo $ac_var` -+ case $ac_val in -+ [\\/$]* | ?:[\\/]* ) ;; -+ *) { echo "$as_me: error: expected an absolute directory name for --$ac_var: $ac_val" >&2 -+ { (exit 1); exit 1; }; };; -+ esac -+done -+ -+# There might be people who depend on the old broken behavior: `$host' -+# used to hold the argument of --host etc. -+# FIXME: To remove some day. -+build=$build_alias -+host=$host_alias -+target=$target_alias -+ -+# FIXME: To remove some day. -+if test "x$host_alias" != x; then -+ if test "x$build_alias" = x; then -+ cross_compiling=maybe -+ echo "$as_me: WARNING: If you wanted to set the --build type, don't use --host. -+ If a cross compiler is detected then cross compile mode will be used." >&2 -+ elif test "x$build_alias" != "x$host_alias"; then -+ cross_compiling=yes -+ fi -+fi -+ -+ac_tool_prefix= -+test -n "$host_alias" && ac_tool_prefix=$host_alias- -+ -+test "$silent" = yes && exec 6>/dev/null -+ -+ -+# Find the source files, if location was not specified. -+if test -z "$srcdir"; then -+ ac_srcdir_defaulted=yes -+ # Try the directory containing this script, then its parent. -+ ac_confdir=`(dirname "$0") 2>/dev/null || -+$as_expr X"$0" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ -+ X"$0" : 'X\(//\)[^/]' \| \ -+ X"$0" : 'X\(//\)$' \| \ -+ X"$0" : 'X\(/\)' \| \ -+ . : '\(.\)' 2>/dev/null || -+echo X"$0" | -+ sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } -+ /^X\(\/\/\)[^/].*/{ s//\1/; q; } -+ /^X\(\/\/\)$/{ s//\1/; q; } -+ /^X\(\/\).*/{ s//\1/; q; } -+ s/.*/./; q'` -+ srcdir=$ac_confdir -+ if test ! -r $srcdir/$ac_unique_file; then -+ srcdir=.. -+ fi -+else -+ ac_srcdir_defaulted=no -+fi -+if test ! -r $srcdir/$ac_unique_file; then -+ if test "$ac_srcdir_defaulted" = yes; then -+ { echo "$as_me: error: cannot find sources ($ac_unique_file) in $ac_confdir or .." >&2 -+ { (exit 1); exit 1; }; } -+ else -+ { echo "$as_me: error: cannot find sources ($ac_unique_file) in $srcdir" >&2 -+ { (exit 1); exit 1; }; } -+ fi -+fi -+(cd $srcdir && test -r ./$ac_unique_file) 2>/dev/null || -+ { echo "$as_me: error: sources are in $srcdir, but \`cd $srcdir' does not work" >&2 -+ { (exit 1); exit 1; }; } -+srcdir=`echo "$srcdir" | sed 's%\([^\\/]\)[\\/]*$%\1%'` -+ac_env_build_alias_set=${build_alias+set} -+ac_env_build_alias_value=$build_alias -+ac_cv_env_build_alias_set=${build_alias+set} -+ac_cv_env_build_alias_value=$build_alias -+ac_env_host_alias_set=${host_alias+set} -+ac_env_host_alias_value=$host_alias -+ac_cv_env_host_alias_set=${host_alias+set} -+ac_cv_env_host_alias_value=$host_alias -+ac_env_target_alias_set=${target_alias+set} -+ac_env_target_alias_value=$target_alias -+ac_cv_env_target_alias_set=${target_alias+set} -+ac_cv_env_target_alias_value=$target_alias -+ac_env_CC_set=${CC+set} -+ac_env_CC_value=$CC -+ac_cv_env_CC_set=${CC+set} -+ac_cv_env_CC_value=$CC -+ac_env_CFLAGS_set=${CFLAGS+set} -+ac_env_CFLAGS_value=$CFLAGS -+ac_cv_env_CFLAGS_set=${CFLAGS+set} -+ac_cv_env_CFLAGS_value=$CFLAGS -+ac_env_LDFLAGS_set=${LDFLAGS+set} -+ac_env_LDFLAGS_value=$LDFLAGS -+ac_cv_env_LDFLAGS_set=${LDFLAGS+set} -+ac_cv_env_LDFLAGS_value=$LDFLAGS -+ac_env_CPPFLAGS_set=${CPPFLAGS+set} -+ac_env_CPPFLAGS_value=$CPPFLAGS -+ac_cv_env_CPPFLAGS_set=${CPPFLAGS+set} -+ac_cv_env_CPPFLAGS_value=$CPPFLAGS -+ac_env_CPP_set=${CPP+set} -+ac_env_CPP_value=$CPP -+ac_cv_env_CPP_set=${CPP+set} -+ac_cv_env_CPP_value=$CPP -+ -+# -+# Report the --help message. -+# -+if test "$ac_init_help" = "long"; then -+ # Omit some internal or obsolete options to make the list less imposing. -+ # This message is too long to be a string in the A/UX 3.1 sh. -+ cat <<_ACEOF -+\`configure' configures this package to adapt to many kinds of systems. -+ -+Usage: $0 [OPTION]... [VAR=VALUE]... -+ -+To assign environment variables (e.g., CC, CFLAGS...), specify them as -+VAR=VALUE. See below for descriptions of some of the useful variables. -+ -+Defaults for the options are specified in brackets. -+ -+Configuration: -+ -h, --help display this help and exit -+ --help=short display options specific to this package -+ --help=recursive display the short help of all the included packages -+ -V, --version display version information and exit -+ -q, --quiet, --silent do not print \`checking...' messages -+ --cache-file=FILE cache test results in FILE [disabled] -+ -C, --config-cache alias for \`--cache-file=config.cache' -+ -n, --no-create do not create output files -+ --srcdir=DIR find the sources in DIR [configure dir or \`..'] -+ -+_ACEOF -+ -+ cat <<_ACEOF -+Installation directories: -+ --prefix=PREFIX install architecture-independent files in PREFIX -+ [$ac_default_prefix] -+ --exec-prefix=EPREFIX install architecture-dependent files in EPREFIX -+ [PREFIX] -+ -+By default, \`make install' will install all the files in -+\`$ac_default_prefix/bin', \`$ac_default_prefix/lib' etc. You can specify -+an installation prefix other than \`$ac_default_prefix' using \`--prefix', -+for instance \`--prefix=\$HOME'. -+ -+For better control, use the options below. -+ -+Fine tuning of the installation directories: -+ --bindir=DIR user executables [EPREFIX/bin] -+ --sbindir=DIR system admin executables [EPREFIX/sbin] -+ --libexecdir=DIR program executables [EPREFIX/libexec] -+ --datadir=DIR read-only architecture-independent data [PREFIX/share] -+ --sysconfdir=DIR read-only single-machine data [PREFIX/etc] -+ --sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com] -+ --localstatedir=DIR modifiable single-machine data [PREFIX/var] -+ --libdir=DIR object code libraries [EPREFIX/lib] -+ --includedir=DIR C header files [PREFIX/include] -+ --oldincludedir=DIR C header files for non-gcc [/usr/include] -+ --infodir=DIR info documentation [PREFIX/info] -+ --mandir=DIR man documentation [PREFIX/man] -+_ACEOF -+ -+ cat <<\_ACEOF -+ -+Program names: -+ --program-prefix=PREFIX prepend PREFIX to installed program names -+ --program-suffix=SUFFIX append SUFFIX to installed program names -+ --program-transform-name=PROGRAM run sed PROGRAM on installed program names -+_ACEOF -+fi -+ -+if test -n "$ac_init_help"; then -+ -+ cat <<\_ACEOF -+ -+Optional Features: -+ --disable-FEATURE do not include FEATURE (same as --enable-FEATURE=no) -+ --enable-FEATURE[=ARG] include FEATURE [ARG=yes] -+ --disable-dependency-tracking speeds up one-time build -+ --enable-dependency-tracking do not reject slow dependency extractors -+ --enable-gcc-warnings enable verbose warnings with GCC -+ -+Some influential environment variables: -+ CC C compiler command -+ CFLAGS C compiler flags -+ LDFLAGS linker flags, e.g. -L if you have libraries in a -+ nonstandard directory -+ CPPFLAGS C/C++ preprocessor flags, e.g. -I if you have -+ headers in a nonstandard directory -+ CPP C preprocessor -+ -+Use these variables to override the choices made by `configure' or to help -+it to find libraries and programs with nonstandard names/locations. -+ -+_ACEOF -+fi -+ -+if test "$ac_init_help" = "recursive"; then -+ # If there are subdirs, report their specific --help. -+ ac_popdir=`pwd` -+ for ac_dir in : $ac_subdirs_all; do test "x$ac_dir" = x: && continue -+ test -d $ac_dir || continue -+ ac_builddir=. -+ -+if test "$ac_dir" != .; then -+ ac_dir_suffix=/`echo "$ac_dir" | sed 's,^\.[\\/],,'` -+ # A "../" for each directory in $ac_dir_suffix. -+ ac_top_builddir=`echo "$ac_dir_suffix" | sed 's,/[^\\/]*,../,g'` -+else -+ ac_dir_suffix= ac_top_builddir= -+fi -+ -+case $srcdir in -+ .) # No --srcdir option. We are building in place. -+ ac_srcdir=. -+ if test -z "$ac_top_builddir"; then -+ ac_top_srcdir=. -+ else -+ ac_top_srcdir=`echo $ac_top_builddir | sed 's,/$,,'` -+ fi ;; -+ [\\/]* | ?:[\\/]* ) # Absolute path. -+ ac_srcdir=$srcdir$ac_dir_suffix; -+ ac_top_srcdir=$srcdir ;; -+ *) # Relative path. -+ ac_srcdir=$ac_top_builddir$srcdir$ac_dir_suffix -+ ac_top_srcdir=$ac_top_builddir$srcdir ;; -+esac -+ -+# Do not use `cd foo && pwd` to compute absolute paths, because -+# the directories may not exist. -+case `pwd` in -+.) ac_abs_builddir="$ac_dir";; -+*) -+ case "$ac_dir" in -+ .) ac_abs_builddir=`pwd`;; -+ [\\/]* | ?:[\\/]* ) ac_abs_builddir="$ac_dir";; -+ *) ac_abs_builddir=`pwd`/"$ac_dir";; -+ esac;; -+esac -+case $ac_abs_builddir in -+.) ac_abs_top_builddir=${ac_top_builddir}.;; -+*) -+ case ${ac_top_builddir}. in -+ .) ac_abs_top_builddir=$ac_abs_builddir;; -+ [\\/]* | ?:[\\/]* ) ac_abs_top_builddir=${ac_top_builddir}.;; -+ *) ac_abs_top_builddir=$ac_abs_builddir/${ac_top_builddir}.;; -+ esac;; -+esac -+case $ac_abs_builddir in -+.) ac_abs_srcdir=$ac_srcdir;; -+*) -+ case $ac_srcdir in -+ .) ac_abs_srcdir=$ac_abs_builddir;; -+ [\\/]* | ?:[\\/]* ) ac_abs_srcdir=$ac_srcdir;; -+ *) ac_abs_srcdir=$ac_abs_builddir/$ac_srcdir;; -+ esac;; -+esac -+case $ac_abs_builddir in -+.) ac_abs_top_srcdir=$ac_top_srcdir;; -+*) -+ case $ac_top_srcdir in -+ .) ac_abs_top_srcdir=$ac_abs_builddir;; -+ [\\/]* | ?:[\\/]* ) ac_abs_top_srcdir=$ac_top_srcdir;; -+ *) ac_abs_top_srcdir=$ac_abs_builddir/$ac_top_srcdir;; -+ esac;; -+esac -+ -+ cd $ac_dir -+ # Check for guested configure; otherwise get Cygnus style configure. -+ if test -f $ac_srcdir/configure.gnu; then -+ echo -+ $SHELL $ac_srcdir/configure.gnu --help=recursive -+ elif test -f $ac_srcdir/configure; then -+ echo -+ $SHELL $ac_srcdir/configure --help=recursive -+ elif test -f $ac_srcdir/configure.ac || -+ test -f $ac_srcdir/configure.in; then -+ echo -+ $ac_configure --help -+ else -+ echo "$as_me: WARNING: no configuration information is in $ac_dir" >&2 -+ fi -+ cd $ac_popdir -+ done -+fi -+ -+test -n "$ac_init_help" && exit 0 -+if $ac_init_version; then -+ cat <<\_ACEOF -+ -+Copyright (C) 2003 Free Software Foundation, Inc. -+This configure script is free software; the Free Software Foundation -+gives unlimited permission to copy, distribute and modify it. -+_ACEOF -+ exit 0 -+fi -+exec 5>config.log -+cat >&5 <<_ACEOF -+This file contains any messages produced by compilers while -+running configure, to aid debugging if configure makes a mistake. -+ -+It was created by $as_me, which was -+generated by GNU Autoconf 2.59. Invocation command line was -+ -+ $ $0 $@ -+ -+_ACEOF -+{ -+cat <<_ASUNAME -+## --------- ## -+## Platform. ## -+## --------- ## -+ -+hostname = `(hostname || uname -n) 2>/dev/null | sed 1q` -+uname -m = `(uname -m) 2>/dev/null || echo unknown` -+uname -r = `(uname -r) 2>/dev/null || echo unknown` -+uname -s = `(uname -s) 2>/dev/null || echo unknown` -+uname -v = `(uname -v) 2>/dev/null || echo unknown` -+ -+/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null || echo unknown` -+/bin/uname -X = `(/bin/uname -X) 2>/dev/null || echo unknown` -+ -+/bin/arch = `(/bin/arch) 2>/dev/null || echo unknown` -+/usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null || echo unknown` -+/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null || echo unknown` -+hostinfo = `(hostinfo) 2>/dev/null || echo unknown` -+/bin/machine = `(/bin/machine) 2>/dev/null || echo unknown` -+/usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null || echo unknown` -+/bin/universe = `(/bin/universe) 2>/dev/null || echo unknown` -+ -+_ASUNAME -+ -+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -+for as_dir in $PATH -+do -+ IFS=$as_save_IFS -+ test -z "$as_dir" && as_dir=. -+ echo "PATH: $as_dir" -+done -+ -+} >&5 -+ -+cat >&5 <<_ACEOF -+ -+ -+## ----------- ## -+## Core tests. ## -+## ----------- ## -+ -+_ACEOF -+ -+ -+# Keep a trace of the command line. -+# Strip out --no-create and --no-recursion so they do not pile up. -+# Strip out --silent because we don't want to record it for future runs. -+# Also quote any args containing shell meta-characters. -+# Make two passes to allow for proper duplicate-argument suppression. -+ac_configure_args= -+ac_configure_args0= -+ac_configure_args1= -+ac_sep= -+ac_must_keep_next=false -+for ac_pass in 1 2 -+do -+ for ac_arg -+ do -+ case $ac_arg in -+ -no-create | --no-c* | -n | -no-recursion | --no-r*) continue ;; -+ -q | -quiet | --quiet | --quie | --qui | --qu | --q \ -+ | -silent | --silent | --silen | --sile | --sil) -+ continue ;; -+ *" "*|*" "*|*[\[\]\~\#\$\^\&\*\(\)\{\}\\\|\;\<\>\?\"\']*) -+ ac_arg=`echo "$ac_arg" | sed "s/'/'\\\\\\\\''/g"` ;; -+ esac -+ case $ac_pass in -+ 1) ac_configure_args0="$ac_configure_args0 '$ac_arg'" ;; -+ 2) -+ ac_configure_args1="$ac_configure_args1 '$ac_arg'" -+ if test $ac_must_keep_next = true; then -+ ac_must_keep_next=false # Got value, back to normal. -+ else -+ case $ac_arg in -+ *=* | --config-cache | -C | -disable-* | --disable-* \ -+ | -enable-* | --enable-* | -gas | --g* | -nfp | --nf* \ -+ | -q | -quiet | --q* | -silent | --sil* | -v | -verb* \ -+ | -with-* | --with-* | -without-* | --without-* | --x) -+ case "$ac_configure_args0 " in -+ "$ac_configure_args1"*" '$ac_arg' "* ) continue ;; -+ esac -+ ;; -+ -* ) ac_must_keep_next=true ;; -+ esac -+ fi -+ ac_configure_args="$ac_configure_args$ac_sep'$ac_arg'" -+ # Get rid of the leading space. -+ ac_sep=" " -+ ;; -+ esac -+ done -+done -+$as_unset ac_configure_args0 || test "${ac_configure_args0+set}" != set || { ac_configure_args0=; export ac_configure_args0; } -+$as_unset ac_configure_args1 || test "${ac_configure_args1+set}" != set || { ac_configure_args1=; export ac_configure_args1; } -+ -+# When interrupted or exit'd, cleanup temporary files, and complete -+# config.log. We remove comments because anyway the quotes in there -+# would cause problems or look ugly. -+# WARNING: Be sure not to use single quotes in there, as some shells, -+# such as our DU 5.0 friend, will then `close' the trap. -+trap 'exit_status=$? -+ # Save into config.log some information that might help in debugging. -+ { -+ echo -+ -+ cat <<\_ASBOX -+## ---------------- ## -+## Cache variables. ## -+## ---------------- ## -+_ASBOX -+ echo -+ # The following way of writing the cache mishandles newlines in values, -+{ -+ (set) 2>&1 | -+ case `(ac_space='"'"' '"'"'; set | grep ac_space) 2>&1` in -+ *ac_space=\ *) -+ sed -n \ -+ "s/'"'"'/'"'"'\\\\'"'"''"'"'/g; -+ s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='"'"'\\2'"'"'/p" -+ ;; -+ *) -+ sed -n \ -+ "s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1=\\2/p" -+ ;; -+ esac; -+} -+ echo -+ -+ cat <<\_ASBOX -+## ----------------- ## -+## Output variables. ## -+## ----------------- ## -+_ASBOX -+ echo -+ for ac_var in $ac_subst_vars -+ do -+ eval ac_val=$`echo $ac_var` -+ echo "$ac_var='"'"'$ac_val'"'"'" -+ done | sort -+ echo -+ -+ if test -n "$ac_subst_files"; then -+ cat <<\_ASBOX -+## ------------- ## -+## Output files. ## -+## ------------- ## -+_ASBOX -+ echo -+ for ac_var in $ac_subst_files -+ do -+ eval ac_val=$`echo $ac_var` -+ echo "$ac_var='"'"'$ac_val'"'"'" -+ done | sort -+ echo -+ fi -+ -+ if test -s confdefs.h; then -+ cat <<\_ASBOX -+## ----------- ## -+## confdefs.h. ## -+## ----------- ## -+_ASBOX -+ echo -+ sed "/^$/d" confdefs.h | sort -+ echo -+ fi -+ test "$ac_signal" != 0 && -+ echo "$as_me: caught signal $ac_signal" -+ echo "$as_me: exit $exit_status" -+ } >&5 -+ rm -f core *.core && -+ rm -rf conftest* confdefs* conf$$* $ac_clean_files && -+ exit $exit_status -+ ' 0 -+for ac_signal in 1 2 13 15; do -+ trap 'ac_signal='$ac_signal'; { (exit 1); exit 1; }' $ac_signal -+done -+ac_signal=0 -+ -+# confdefs.h avoids OS command line length limits that DEFS can exceed. -+rm -rf conftest* confdefs.h -+# AIX cpp loses on an empty file, so make sure it contains at least a newline. -+echo >confdefs.h -+ -+# Predefined preprocessor variables. -+ -+cat >>confdefs.h <<_ACEOF -+#define PACKAGE_NAME "$PACKAGE_NAME" -+_ACEOF -+ -+ -+cat >>confdefs.h <<_ACEOF -+#define PACKAGE_TARNAME "$PACKAGE_TARNAME" -+_ACEOF -+ -+ -+cat >>confdefs.h <<_ACEOF -+#define PACKAGE_VERSION "$PACKAGE_VERSION" -+_ACEOF -+ -+ -+cat >>confdefs.h <<_ACEOF -+#define PACKAGE_STRING "$PACKAGE_STRING" -+_ACEOF -+ -+ -+cat >>confdefs.h <<_ACEOF -+#define PACKAGE_BUGREPORT "$PACKAGE_BUGREPORT" -+_ACEOF -+ -+ -+# Let the site file select an alternate cache file if it wants to. -+# Prefer explicitly selected file to automatically selected ones. -+if test -z "$CONFIG_SITE"; then -+ if test "x$prefix" != xNONE; then -+ CONFIG_SITE="$prefix/share/config.site $prefix/etc/config.site" -+ else -+ CONFIG_SITE="$ac_default_prefix/share/config.site $ac_default_prefix/etc/config.site" -+ fi -+fi -+for ac_site_file in $CONFIG_SITE; do -+ if test -r "$ac_site_file"; then -+ { echo "$as_me:$LINENO: loading site script $ac_site_file" >&5 -+echo "$as_me: loading site script $ac_site_file" >&6;} -+ sed 's/^/| /' "$ac_site_file" >&5 -+ . "$ac_site_file" -+ fi -+done -+ -+if test -r "$cache_file"; then -+ # Some versions of bash will fail to source /dev/null (special -+ # files actually), so we avoid doing that. -+ if test -f "$cache_file"; then -+ { echo "$as_me:$LINENO: loading cache $cache_file" >&5 -+echo "$as_me: loading cache $cache_file" >&6;} -+ case $cache_file in -+ [\\/]* | ?:[\\/]* ) . $cache_file;; -+ *) . ./$cache_file;; -+ esac -+ fi -+else -+ { echo "$as_me:$LINENO: creating cache $cache_file" >&5 -+echo "$as_me: creating cache $cache_file" >&6;} -+ >$cache_file -+fi -+ -+# Check that the precious variables saved in the cache have kept the same -+# value. -+ac_cache_corrupted=false -+for ac_var in `(set) 2>&1 | -+ sed -n 's/^ac_env_\([a-zA-Z_0-9]*\)_set=.*/\1/p'`; do -+ eval ac_old_set=\$ac_cv_env_${ac_var}_set -+ eval ac_new_set=\$ac_env_${ac_var}_set -+ eval ac_old_val="\$ac_cv_env_${ac_var}_value" -+ eval ac_new_val="\$ac_env_${ac_var}_value" -+ case $ac_old_set,$ac_new_set in -+ set,) -+ { echo "$as_me:$LINENO: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&5 -+echo "$as_me: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&2;} -+ ac_cache_corrupted=: ;; -+ ,set) -+ { echo "$as_me:$LINENO: error: \`$ac_var' was not set in the previous run" >&5 -+echo "$as_me: error: \`$ac_var' was not set in the previous run" >&2;} -+ ac_cache_corrupted=: ;; -+ ,);; -+ *) -+ if test "x$ac_old_val" != "x$ac_new_val"; then -+ { echo "$as_me:$LINENO: error: \`$ac_var' has changed since the previous run:" >&5 -+echo "$as_me: error: \`$ac_var' has changed since the previous run:" >&2;} -+ { echo "$as_me:$LINENO: former value: $ac_old_val" >&5 -+echo "$as_me: former value: $ac_old_val" >&2;} -+ { echo "$as_me:$LINENO: current value: $ac_new_val" >&5 -+echo "$as_me: current value: $ac_new_val" >&2;} -+ ac_cache_corrupted=: -+ fi;; -+ esac -+ # Pass precious variables to config.status. -+ if test "$ac_new_set" = set; then -+ case $ac_new_val in -+ *" "*|*" "*|*[\[\]\~\#\$\^\&\*\(\)\{\}\\\|\;\<\>\?\"\']*) -+ ac_arg=$ac_var=`echo "$ac_new_val" | sed "s/'/'\\\\\\\\''/g"` ;; -+ *) ac_arg=$ac_var=$ac_new_val ;; -+ esac -+ case " $ac_configure_args " in -+ *" '$ac_arg' "*) ;; # Avoid dups. Use of quotes ensures accuracy. -+ *) ac_configure_args="$ac_configure_args '$ac_arg'" ;; -+ esac -+ fi -+done -+if $ac_cache_corrupted; then -+ { echo "$as_me:$LINENO: error: changes in the environment can compromise the build" >&5 -+echo "$as_me: error: changes in the environment can compromise the build" >&2;} -+ { { echo "$as_me:$LINENO: error: run \`make distclean' and/or \`rm $cache_file' and start over" >&5 -+echo "$as_me: error: run \`make distclean' and/or \`rm $cache_file' and start over" >&2;} -+ { (exit 1); exit 1; }; } -+fi -+ -+ac_ext=c -+ac_cpp='$CPP $CPPFLAGS' -+ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -+ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -+ac_compiler_gnu=$ac_cv_c_compiler_gnu -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+am__api_version="1.9" -+ac_aux_dir= -+for ac_dir in $srcdir $srcdir/.. $srcdir/../..; do -+ if test -f $ac_dir/install-sh; then -+ ac_aux_dir=$ac_dir -+ ac_install_sh="$ac_aux_dir/install-sh -c" -+ break -+ elif test -f $ac_dir/install.sh; then -+ ac_aux_dir=$ac_dir -+ ac_install_sh="$ac_aux_dir/install.sh -c" -+ break -+ elif test -f $ac_dir/shtool; then -+ ac_aux_dir=$ac_dir -+ ac_install_sh="$ac_aux_dir/shtool install -c" -+ break -+ fi -+done -+if test -z "$ac_aux_dir"; then -+ { { echo "$as_me:$LINENO: error: cannot find install-sh or install.sh in $srcdir $srcdir/.. $srcdir/../.." >&5 -+echo "$as_me: error: cannot find install-sh or install.sh in $srcdir $srcdir/.. $srcdir/../.." >&2;} -+ { (exit 1); exit 1; }; } -+fi -+ac_config_guess="$SHELL $ac_aux_dir/config.guess" -+ac_config_sub="$SHELL $ac_aux_dir/config.sub" -+ac_configure="$SHELL $ac_aux_dir/configure" # This should be Cygnus configure. -+ -+# Find a good install program. We prefer a C program (faster), -+# so one script is as good as another. But avoid the broken or -+# incompatible versions: -+# SysV /etc/install, /usr/sbin/install -+# SunOS /usr/etc/install -+# IRIX /sbin/install -+# AIX /bin/install -+# AmigaOS /C/install, which installs bootblocks on floppy discs -+# AIX 4 /usr/bin/installbsd, which doesn't work without a -g flag -+# AFS /usr/afsws/bin/install, which mishandles nonexistent args -+# SVR4 /usr/ucb/install, which tries to use the nonexistent group "staff" -+# OS/2's system install, which has a completely different semantic -+# ./install, which can be erroneously created by make from ./install.sh. -+echo "$as_me:$LINENO: checking for a BSD-compatible install" >&5 -+echo $ECHO_N "checking for a BSD-compatible install... $ECHO_C" >&6 -+if test -z "$INSTALL"; then -+if test "${ac_cv_path_install+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -+for as_dir in $PATH -+do -+ IFS=$as_save_IFS -+ test -z "$as_dir" && as_dir=. -+ # Account for people who put trailing slashes in PATH elements. -+case $as_dir/ in -+ ./ | .// | /cC/* | \ -+ /etc/* | /usr/sbin/* | /usr/etc/* | /sbin/* | /usr/afsws/bin/* | \ -+ ?:\\/os2\\/install\\/* | ?:\\/OS2\\/INSTALL\\/* | \ -+ /usr/ucb/* ) ;; -+ *) -+ # OSF1 and SCO ODT 3.0 have their own names for install. -+ # Don't use installbsd from OSF since it installs stuff as root -+ # by default. -+ for ac_prog in ginstall scoinst install; do -+ for ac_exec_ext in '' $ac_executable_extensions; do -+ if $as_executable_p "$as_dir/$ac_prog$ac_exec_ext"; then -+ if test $ac_prog = install && -+ grep dspmsg "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then -+ # AIX install. It has an incompatible calling convention. -+ : -+ elif test $ac_prog = install && -+ grep pwplus "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then -+ # program-specific install script used by HP pwplus--don't use. -+ : -+ else -+ ac_cv_path_install="$as_dir/$ac_prog$ac_exec_ext -c" -+ break 3 -+ fi -+ fi -+ done -+ done -+ ;; -+esac -+done -+ -+ -+fi -+ if test "${ac_cv_path_install+set}" = set; then -+ INSTALL=$ac_cv_path_install -+ else -+ # As a last resort, use the slow shell script. We don't cache a -+ # path for INSTALL within a source directory, because that will -+ # break other packages using the cache if that directory is -+ # removed, or if the path is relative. -+ INSTALL=$ac_install_sh -+ fi -+fi -+echo "$as_me:$LINENO: result: $INSTALL" >&5 -+echo "${ECHO_T}$INSTALL" >&6 -+ -+# Use test -z because SunOS4 sh mishandles braces in ${var-val}. -+# It thinks the first close brace ends the variable substitution. -+test -z "$INSTALL_PROGRAM" && INSTALL_PROGRAM='${INSTALL}' -+ -+test -z "$INSTALL_SCRIPT" && INSTALL_SCRIPT='${INSTALL}' -+ -+test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644' -+ -+echo "$as_me:$LINENO: checking whether build environment is sane" >&5 -+echo $ECHO_N "checking whether build environment is sane... $ECHO_C" >&6 -+# Just in case -+sleep 1 -+echo timestamp > conftest.file -+# Do `set' in a subshell so we don't clobber the current shell's -+# arguments. Must try -L first in case configure is actually a -+# symlink; some systems play weird games with the mod time of symlinks -+# (eg FreeBSD returns the mod time of the symlink's containing -+# directory). -+if ( -+ set X `ls -Lt $srcdir/configure conftest.file 2> /dev/null` -+ if test "$*" = "X"; then -+ # -L didn't work. -+ set X `ls -t $srcdir/configure conftest.file` -+ fi -+ rm -f conftest.file -+ if test "$*" != "X $srcdir/configure conftest.file" \ -+ && test "$*" != "X conftest.file $srcdir/configure"; then -+ -+ # If neither matched, then we have a broken ls. This can happen -+ # if, for instance, CONFIG_SHELL is bash and it inherits a -+ # broken ls alias from the environment. This has actually -+ # happened. Such a system could not be considered "sane". -+ { { echo "$as_me:$LINENO: error: ls -t appears to fail. Make sure there is not a broken -+alias in your environment" >&5 -+echo "$as_me: error: ls -t appears to fail. Make sure there is not a broken -+alias in your environment" >&2;} -+ { (exit 1); exit 1; }; } -+ fi -+ -+ test "$2" = conftest.file -+ ) -+then -+ # Ok. -+ : -+else -+ { { echo "$as_me:$LINENO: error: newly created file is older than distributed files! -+Check your system clock" >&5 -+echo "$as_me: error: newly created file is older than distributed files! -+Check your system clock" >&2;} -+ { (exit 1); exit 1; }; } -+fi -+echo "$as_me:$LINENO: result: yes" >&5 -+echo "${ECHO_T}yes" >&6 -+test "$program_prefix" != NONE && -+ program_transform_name="s,^,$program_prefix,;$program_transform_name" -+# Use a double $ so make ignores it. -+test "$program_suffix" != NONE && -+ program_transform_name="s,\$,$program_suffix,;$program_transform_name" -+# Double any \ or $. echo might interpret backslashes. -+# By default was `s,x,x', remove it if useless. -+cat <<\_ACEOF >conftest.sed -+s/[\\$]/&&/g;s/;s,x,x,$// -+_ACEOF -+program_transform_name=`echo $program_transform_name | sed -f conftest.sed` -+rm conftest.sed -+ -+# expand $ac_aux_dir to an absolute path -+am_aux_dir=`cd $ac_aux_dir && pwd` -+ -+test x"${MISSING+set}" = xset || MISSING="\${SHELL} $am_aux_dir/missing" -+# Use eval to expand $SHELL -+if eval "$MISSING --run true"; then -+ am_missing_run="$MISSING --run " -+else -+ am_missing_run= -+ { echo "$as_me:$LINENO: WARNING: \`missing' script is too old or missing" >&5 -+echo "$as_me: WARNING: \`missing' script is too old or missing" >&2;} -+fi -+ -+if mkdir -p --version . >/dev/null 2>&1 && test ! -d ./--version; then -+ # We used to keeping the `.' as first argument, in order to -+ # allow $(mkdir_p) to be used without argument. As in -+ # $(mkdir_p) $(somedir) -+ # where $(somedir) is conditionally defined. However this is wrong -+ # for two reasons: -+ # 1. if the package is installed by a user who cannot write `.' -+ # make install will fail, -+ # 2. the above comment should most certainly read -+ # $(mkdir_p) $(DESTDIR)$(somedir) -+ # so it does not work when $(somedir) is undefined and -+ # $(DESTDIR) is not. -+ # To support the latter case, we have to write -+ # test -z "$(somedir)" || $(mkdir_p) $(DESTDIR)$(somedir), -+ # so the `.' trick is pointless. -+ mkdir_p='mkdir -p --' -+else -+ # On NextStep and OpenStep, the `mkdir' command does not -+ # recognize any option. It will interpret all options as -+ # directories to create, and then abort because `.' already -+ # exists. -+ for d in ./-p ./--version; -+ do -+ test -d $d && rmdir $d -+ done -+ # $(mkinstalldirs) is defined by Automake if mkinstalldirs exists. -+ if test -f "$ac_aux_dir/mkinstalldirs"; then -+ mkdir_p='$(mkinstalldirs)' -+ else -+ mkdir_p='$(install_sh) -d' -+ fi -+fi -+ -+for ac_prog in gawk mawk nawk awk -+do -+ # Extract the first word of "$ac_prog", so it can be a program name with args. -+set dummy $ac_prog; ac_word=$2 -+echo "$as_me:$LINENO: checking for $ac_word" >&5 -+echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 -+if test "${ac_cv_prog_AWK+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ if test -n "$AWK"; then -+ ac_cv_prog_AWK="$AWK" # Let the user override the test. -+else -+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -+for as_dir in $PATH -+do -+ IFS=$as_save_IFS -+ test -z "$as_dir" && as_dir=. -+ for ac_exec_ext in '' $ac_executable_extensions; do -+ if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then -+ ac_cv_prog_AWK="$ac_prog" -+ echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 -+ break 2 -+ fi -+done -+done -+ -+fi -+fi -+AWK=$ac_cv_prog_AWK -+if test -n "$AWK"; then -+ echo "$as_me:$LINENO: result: $AWK" >&5 -+echo "${ECHO_T}$AWK" >&6 -+else -+ echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+fi -+ -+ test -n "$AWK" && break -+done -+ -+echo "$as_me:$LINENO: checking whether ${MAKE-make} sets \$(MAKE)" >&5 -+echo $ECHO_N "checking whether ${MAKE-make} sets \$(MAKE)... $ECHO_C" >&6 -+set dummy ${MAKE-make}; ac_make=`echo "$2" | sed 'y,:./+-,___p_,'` -+if eval "test \"\${ac_cv_prog_make_${ac_make}_set+set}\" = set"; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.make <<\_ACEOF -+all: -+ @echo 'ac_maketemp="$(MAKE)"' -+_ACEOF -+# GNU make sometimes prints "make[1]: Entering...", which would confuse us. -+eval `${MAKE-make} -f conftest.make 2>/dev/null | grep temp=` -+if test -n "$ac_maketemp"; then -+ eval ac_cv_prog_make_${ac_make}_set=yes -+else -+ eval ac_cv_prog_make_${ac_make}_set=no -+fi -+rm -f conftest.make -+fi -+if eval "test \"`echo '$ac_cv_prog_make_'${ac_make}_set`\" = yes"; then -+ echo "$as_me:$LINENO: result: yes" >&5 -+echo "${ECHO_T}yes" >&6 -+ SET_MAKE= -+else -+ echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+ SET_MAKE="MAKE=${MAKE-make}" -+fi -+ -+rm -rf .tst 2>/dev/null -+mkdir .tst 2>/dev/null -+if test -d .tst; then -+ am__leading_dot=. -+else -+ am__leading_dot=_ -+fi -+rmdir .tst 2>/dev/null -+ -+# test to see if srcdir already configured -+if test "`cd $srcdir && pwd`" != "`pwd`" && -+ test -f $srcdir/config.status; then -+ { { echo "$as_me:$LINENO: error: source directory already configured; run \"make distclean\" there first" >&5 -+echo "$as_me: error: source directory already configured; run \"make distclean\" there first" >&2;} -+ { (exit 1); exit 1; }; } -+fi -+ -+# test whether we have cygpath -+if test -z "$CYGPATH_W"; then -+ if (cygpath --version) >/dev/null 2>/dev/null; then -+ CYGPATH_W='cygpath -w' -+ else -+ CYGPATH_W=echo -+ fi -+fi -+ -+ -+# Define the identity of the package. -+ PACKAGE=libevent -+ VERSION=1.4.8-stable -+ -+ -+cat >>confdefs.h <<_ACEOF -+#define PACKAGE "$PACKAGE" -+_ACEOF -+ -+ -+cat >>confdefs.h <<_ACEOF -+#define VERSION "$VERSION" -+_ACEOF -+ -+# Some tools Automake needs. -+ -+ACLOCAL=${ACLOCAL-"${am_missing_run}aclocal-${am__api_version}"} -+ -+ -+AUTOCONF=${AUTOCONF-"${am_missing_run}autoconf"} -+ -+ -+AUTOMAKE=${AUTOMAKE-"${am_missing_run}automake-${am__api_version}"} -+ -+ -+AUTOHEADER=${AUTOHEADER-"${am_missing_run}autoheader"} -+ -+ -+MAKEINFO=${MAKEINFO-"${am_missing_run}makeinfo"} -+ -+install_sh=${install_sh-"$am_aux_dir/install-sh"} -+ -+# Installed binaries are usually stripped using `strip' when the user -+# run `make install-strip'. However `strip' might not be the right -+# tool to use in cross-compilation environments, therefore Automake -+# will honor the `STRIP' environment variable to overrule this program. -+if test "$cross_compiling" != no; then -+ if test -n "$ac_tool_prefix"; then -+ # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args. -+set dummy ${ac_tool_prefix}strip; ac_word=$2 -+echo "$as_me:$LINENO: checking for $ac_word" >&5 -+echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 -+if test "${ac_cv_prog_STRIP+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ if test -n "$STRIP"; then -+ ac_cv_prog_STRIP="$STRIP" # Let the user override the test. -+else -+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -+for as_dir in $PATH -+do -+ IFS=$as_save_IFS -+ test -z "$as_dir" && as_dir=. -+ for ac_exec_ext in '' $ac_executable_extensions; do -+ if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then -+ ac_cv_prog_STRIP="${ac_tool_prefix}strip" -+ echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 -+ break 2 -+ fi -+done -+done -+ -+fi -+fi -+STRIP=$ac_cv_prog_STRIP -+if test -n "$STRIP"; then -+ echo "$as_me:$LINENO: result: $STRIP" >&5 -+echo "${ECHO_T}$STRIP" >&6 -+else -+ echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+fi -+ -+fi -+if test -z "$ac_cv_prog_STRIP"; then -+ ac_ct_STRIP=$STRIP -+ # Extract the first word of "strip", so it can be a program name with args. -+set dummy strip; ac_word=$2 -+echo "$as_me:$LINENO: checking for $ac_word" >&5 -+echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 -+if test "${ac_cv_prog_ac_ct_STRIP+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ if test -n "$ac_ct_STRIP"; then -+ ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test. -+else -+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -+for as_dir in $PATH -+do -+ IFS=$as_save_IFS -+ test -z "$as_dir" && as_dir=. -+ for ac_exec_ext in '' $ac_executable_extensions; do -+ if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then -+ ac_cv_prog_ac_ct_STRIP="strip" -+ echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 -+ break 2 -+ fi -+done -+done -+ -+ test -z "$ac_cv_prog_ac_ct_STRIP" && ac_cv_prog_ac_ct_STRIP=":" -+fi -+fi -+ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP -+if test -n "$ac_ct_STRIP"; then -+ echo "$as_me:$LINENO: result: $ac_ct_STRIP" >&5 -+echo "${ECHO_T}$ac_ct_STRIP" >&6 -+else -+ echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+fi -+ -+ STRIP=$ac_ct_STRIP -+else -+ STRIP="$ac_cv_prog_STRIP" -+fi -+ -+fi -+INSTALL_STRIP_PROGRAM="\${SHELL} \$(install_sh) -c -s" -+ -+# We need awk for the "check" target. The system "awk" is bad on -+# some platforms. -+# Always define AMTAR for backward compatibility. -+ -+AMTAR=${AMTAR-"${am_missing_run}tar"} -+ -+am__tar='${AMTAR} chof - "$$tardir"'; am__untar='${AMTAR} xf -' -+ -+ -+ -+ -+ -+ ac_config_headers="$ac_config_headers config.h" -+ -+ -+if test "$prefix" = "NONE"; then -+ prefix="/usr/local" -+fi -+ -+ac_ext=c -+ac_cpp='$CPP $CPPFLAGS' -+ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -+ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -+ac_compiler_gnu=$ac_cv_c_compiler_gnu -+if test -n "$ac_tool_prefix"; then -+ # Extract the first word of "${ac_tool_prefix}gcc", so it can be a program name with args. -+set dummy ${ac_tool_prefix}gcc; ac_word=$2 -+echo "$as_me:$LINENO: checking for $ac_word" >&5 -+echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 -+if test "${ac_cv_prog_CC+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ if test -n "$CC"; then -+ ac_cv_prog_CC="$CC" # Let the user override the test. -+else -+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -+for as_dir in $PATH -+do -+ IFS=$as_save_IFS -+ test -z "$as_dir" && as_dir=. -+ for ac_exec_ext in '' $ac_executable_extensions; do -+ if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then -+ ac_cv_prog_CC="${ac_tool_prefix}gcc" -+ echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 -+ break 2 -+ fi -+done -+done -+ -+fi -+fi -+CC=$ac_cv_prog_CC -+if test -n "$CC"; then -+ echo "$as_me:$LINENO: result: $CC" >&5 -+echo "${ECHO_T}$CC" >&6 -+else -+ echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+fi -+ -+fi -+if test -z "$ac_cv_prog_CC"; then -+ ac_ct_CC=$CC -+ # Extract the first word of "gcc", so it can be a program name with args. -+set dummy gcc; ac_word=$2 -+echo "$as_me:$LINENO: checking for $ac_word" >&5 -+echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 -+if test "${ac_cv_prog_ac_ct_CC+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ if test -n "$ac_ct_CC"; then -+ ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. -+else -+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -+for as_dir in $PATH -+do -+ IFS=$as_save_IFS -+ test -z "$as_dir" && as_dir=. -+ for ac_exec_ext in '' $ac_executable_extensions; do -+ if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then -+ ac_cv_prog_ac_ct_CC="gcc" -+ echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 -+ break 2 -+ fi -+done -+done -+ -+fi -+fi -+ac_ct_CC=$ac_cv_prog_ac_ct_CC -+if test -n "$ac_ct_CC"; then -+ echo "$as_me:$LINENO: result: $ac_ct_CC" >&5 -+echo "${ECHO_T}$ac_ct_CC" >&6 -+else -+ echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+fi -+ -+ CC=$ac_ct_CC -+else -+ CC="$ac_cv_prog_CC" -+fi -+ -+if test -z "$CC"; then -+ if test -n "$ac_tool_prefix"; then -+ # Extract the first word of "${ac_tool_prefix}cc", so it can be a program name with args. -+set dummy ${ac_tool_prefix}cc; ac_word=$2 -+echo "$as_me:$LINENO: checking for $ac_word" >&5 -+echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 -+if test "${ac_cv_prog_CC+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ if test -n "$CC"; then -+ ac_cv_prog_CC="$CC" # Let the user override the test. -+else -+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -+for as_dir in $PATH -+do -+ IFS=$as_save_IFS -+ test -z "$as_dir" && as_dir=. -+ for ac_exec_ext in '' $ac_executable_extensions; do -+ if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then -+ ac_cv_prog_CC="${ac_tool_prefix}cc" -+ echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 -+ break 2 -+ fi -+done -+done -+ -+fi -+fi -+CC=$ac_cv_prog_CC -+if test -n "$CC"; then -+ echo "$as_me:$LINENO: result: $CC" >&5 -+echo "${ECHO_T}$CC" >&6 -+else -+ echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+fi -+ -+fi -+if test -z "$ac_cv_prog_CC"; then -+ ac_ct_CC=$CC -+ # Extract the first word of "cc", so it can be a program name with args. -+set dummy cc; ac_word=$2 -+echo "$as_me:$LINENO: checking for $ac_word" >&5 -+echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 -+if test "${ac_cv_prog_ac_ct_CC+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ if test -n "$ac_ct_CC"; then -+ ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. -+else -+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -+for as_dir in $PATH -+do -+ IFS=$as_save_IFS -+ test -z "$as_dir" && as_dir=. -+ for ac_exec_ext in '' $ac_executable_extensions; do -+ if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then -+ ac_cv_prog_ac_ct_CC="cc" -+ echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 -+ break 2 -+ fi -+done -+done -+ -+fi -+fi -+ac_ct_CC=$ac_cv_prog_ac_ct_CC -+if test -n "$ac_ct_CC"; then -+ echo "$as_me:$LINENO: result: $ac_ct_CC" >&5 -+echo "${ECHO_T}$ac_ct_CC" >&6 -+else -+ echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+fi -+ -+ CC=$ac_ct_CC -+else -+ CC="$ac_cv_prog_CC" -+fi -+ -+fi -+if test -z "$CC"; then -+ # Extract the first word of "cc", so it can be a program name with args. -+set dummy cc; ac_word=$2 -+echo "$as_me:$LINENO: checking for $ac_word" >&5 -+echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 -+if test "${ac_cv_prog_CC+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ if test -n "$CC"; then -+ ac_cv_prog_CC="$CC" # Let the user override the test. -+else -+ ac_prog_rejected=no -+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -+for as_dir in $PATH -+do -+ IFS=$as_save_IFS -+ test -z "$as_dir" && as_dir=. -+ for ac_exec_ext in '' $ac_executable_extensions; do -+ if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then -+ if test "$as_dir/$ac_word$ac_exec_ext" = "/usr/ucb/cc"; then -+ ac_prog_rejected=yes -+ continue -+ fi -+ ac_cv_prog_CC="cc" -+ echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 -+ break 2 -+ fi -+done -+done -+ -+if test $ac_prog_rejected = yes; then -+ # We found a bogon in the path, so make sure we never use it. -+ set dummy $ac_cv_prog_CC -+ shift -+ if test $# != 0; then -+ # We chose a different compiler from the bogus one. -+ # However, it has the same basename, so the bogon will be chosen -+ # first if we set CC to just the basename; use the full file name. -+ shift -+ ac_cv_prog_CC="$as_dir/$ac_word${1+' '}$@" -+ fi -+fi -+fi -+fi -+CC=$ac_cv_prog_CC -+if test -n "$CC"; then -+ echo "$as_me:$LINENO: result: $CC" >&5 -+echo "${ECHO_T}$CC" >&6 -+else -+ echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+fi -+ -+fi -+if test -z "$CC"; then -+ if test -n "$ac_tool_prefix"; then -+ for ac_prog in cl -+ do -+ # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. -+set dummy $ac_tool_prefix$ac_prog; ac_word=$2 -+echo "$as_me:$LINENO: checking for $ac_word" >&5 -+echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 -+if test "${ac_cv_prog_CC+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ if test -n "$CC"; then -+ ac_cv_prog_CC="$CC" # Let the user override the test. -+else -+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -+for as_dir in $PATH -+do -+ IFS=$as_save_IFS -+ test -z "$as_dir" && as_dir=. -+ for ac_exec_ext in '' $ac_executable_extensions; do -+ if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then -+ ac_cv_prog_CC="$ac_tool_prefix$ac_prog" -+ echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 -+ break 2 -+ fi -+done -+done -+ -+fi -+fi -+CC=$ac_cv_prog_CC -+if test -n "$CC"; then -+ echo "$as_me:$LINENO: result: $CC" >&5 -+echo "${ECHO_T}$CC" >&6 -+else -+ echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+fi -+ -+ test -n "$CC" && break -+ done -+fi -+if test -z "$CC"; then -+ ac_ct_CC=$CC -+ for ac_prog in cl -+do -+ # Extract the first word of "$ac_prog", so it can be a program name with args. -+set dummy $ac_prog; ac_word=$2 -+echo "$as_me:$LINENO: checking for $ac_word" >&5 -+echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 -+if test "${ac_cv_prog_ac_ct_CC+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ if test -n "$ac_ct_CC"; then -+ ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. -+else -+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -+for as_dir in $PATH -+do -+ IFS=$as_save_IFS -+ test -z "$as_dir" && as_dir=. -+ for ac_exec_ext in '' $ac_executable_extensions; do -+ if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then -+ ac_cv_prog_ac_ct_CC="$ac_prog" -+ echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 -+ break 2 -+ fi -+done -+done -+ -+fi -+fi -+ac_ct_CC=$ac_cv_prog_ac_ct_CC -+if test -n "$ac_ct_CC"; then -+ echo "$as_me:$LINENO: result: $ac_ct_CC" >&5 -+echo "${ECHO_T}$ac_ct_CC" >&6 -+else -+ echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+fi -+ -+ test -n "$ac_ct_CC" && break -+done -+ -+ CC=$ac_ct_CC -+fi -+ -+fi -+ -+ -+test -z "$CC" && { { echo "$as_me:$LINENO: error: no acceptable C compiler found in \$PATH -+See \`config.log' for more details." >&5 -+echo "$as_me: error: no acceptable C compiler found in \$PATH -+See \`config.log' for more details." >&2;} -+ { (exit 1); exit 1; }; } -+ -+# Provide some information about the compiler. -+echo "$as_me:$LINENO:" \ -+ "checking for C compiler version" >&5 -+ac_compiler=`set X $ac_compile; echo $2` -+{ (eval echo "$as_me:$LINENO: \"$ac_compiler --version &5\"") >&5 -+ (eval $ac_compiler --version &5) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } -+{ (eval echo "$as_me:$LINENO: \"$ac_compiler -v &5\"") >&5 -+ (eval $ac_compiler -v &5) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } -+{ (eval echo "$as_me:$LINENO: \"$ac_compiler -V &5\"") >&5 -+ (eval $ac_compiler -V &5) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } -+ -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+int -+main () -+{ -+ -+ ; -+ return 0; -+} -+_ACEOF -+ac_clean_files_save=$ac_clean_files -+ac_clean_files="$ac_clean_files a.out a.exe b.out" -+# Try to create an executable without -o first, disregard a.out. -+# It will help us diagnose broken compilers, and finding out an intuition -+# of exeext. -+echo "$as_me:$LINENO: checking for C compiler default output file name" >&5 -+echo $ECHO_N "checking for C compiler default output file name... $ECHO_C" >&6 -+ac_link_default=`echo "$ac_link" | sed 's/ -o *conftest[^ ]*//'` -+if { (eval echo "$as_me:$LINENO: \"$ac_link_default\"") >&5 -+ (eval $ac_link_default) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; then -+ # Find the output, starting from the most likely. This scheme is -+# not robust to junk in `.', hence go to wildcards (a.*) only as a last -+# resort. -+ -+# Be careful to initialize this variable, since it used to be cached. -+# Otherwise an old cache value of `no' led to `EXEEXT = no' in a Makefile. -+ac_cv_exeext= -+# b.out is created by i960 compilers. -+for ac_file in a_out.exe a.exe conftest.exe a.out conftest a.* conftest.* b.out -+do -+ test -f "$ac_file" || continue -+ case $ac_file in -+ *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.o | *.obj ) -+ ;; -+ conftest.$ac_ext ) -+ # This is the source file. -+ ;; -+ [ab].out ) -+ # We found the default executable, but exeext='' is most -+ # certainly right. -+ break;; -+ *.* ) -+ ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` -+ # FIXME: I believe we export ac_cv_exeext for Libtool, -+ # but it would be cool to find out if it's true. Does anybody -+ # maintain Libtool? --akim. -+ export ac_cv_exeext -+ break;; -+ * ) -+ break;; -+ esac -+done -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+{ { echo "$as_me:$LINENO: error: C compiler cannot create executables -+See \`config.log' for more details." >&5 -+echo "$as_me: error: C compiler cannot create executables -+See \`config.log' for more details." >&2;} -+ { (exit 77); exit 77; }; } -+fi -+ -+ac_exeext=$ac_cv_exeext -+echo "$as_me:$LINENO: result: $ac_file" >&5 -+echo "${ECHO_T}$ac_file" >&6 -+ -+# Check the compiler produces executables we can run. If not, either -+# the compiler is broken, or we cross compile. -+echo "$as_me:$LINENO: checking whether the C compiler works" >&5 -+echo $ECHO_N "checking whether the C compiler works... $ECHO_C" >&6 -+# FIXME: These cross compiler hacks should be removed for Autoconf 3.0 -+# If not cross compiling, check that we can run a simple program. -+if test "$cross_compiling" != yes; then -+ if { ac_try='./$ac_file' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ cross_compiling=no -+ else -+ if test "$cross_compiling" = maybe; then -+ cross_compiling=yes -+ else -+ { { echo "$as_me:$LINENO: error: cannot run C compiled programs. -+If you meant to cross compile, use \`--host'. -+See \`config.log' for more details." >&5 -+echo "$as_me: error: cannot run C compiled programs. -+If you meant to cross compile, use \`--host'. -+See \`config.log' for more details." >&2;} -+ { (exit 1); exit 1; }; } -+ fi -+ fi -+fi -+echo "$as_me:$LINENO: result: yes" >&5 -+echo "${ECHO_T}yes" >&6 -+ -+rm -f a.out a.exe conftest$ac_cv_exeext b.out -+ac_clean_files=$ac_clean_files_save -+# Check the compiler produces executables we can run. If not, either -+# the compiler is broken, or we cross compile. -+echo "$as_me:$LINENO: checking whether we are cross compiling" >&5 -+echo $ECHO_N "checking whether we are cross compiling... $ECHO_C" >&6 -+echo "$as_me:$LINENO: result: $cross_compiling" >&5 -+echo "${ECHO_T}$cross_compiling" >&6 -+ -+echo "$as_me:$LINENO: checking for suffix of executables" >&5 -+echo $ECHO_N "checking for suffix of executables... $ECHO_C" >&6 -+if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 -+ (eval $ac_link) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; then -+ # If both `conftest.exe' and `conftest' are `present' (well, observable) -+# catch `conftest.exe'. For instance with Cygwin, `ls conftest' will -+# work properly (i.e., refer to `conftest.exe'), while it won't with -+# `rm'. -+for ac_file in conftest.exe conftest conftest.*; do -+ test -f "$ac_file" || continue -+ case $ac_file in -+ *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.o | *.obj ) ;; -+ *.* ) ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` -+ export ac_cv_exeext -+ break;; -+ * ) break;; -+ esac -+done -+else -+ { { echo "$as_me:$LINENO: error: cannot compute suffix of executables: cannot compile and link -+See \`config.log' for more details." >&5 -+echo "$as_me: error: cannot compute suffix of executables: cannot compile and link -+See \`config.log' for more details." >&2;} -+ { (exit 1); exit 1; }; } -+fi -+ -+rm -f conftest$ac_cv_exeext -+echo "$as_me:$LINENO: result: $ac_cv_exeext" >&5 -+echo "${ECHO_T}$ac_cv_exeext" >&6 -+ -+rm -f conftest.$ac_ext -+EXEEXT=$ac_cv_exeext -+ac_exeext=$EXEEXT -+echo "$as_me:$LINENO: checking for suffix of object files" >&5 -+echo $ECHO_N "checking for suffix of object files... $ECHO_C" >&6 -+if test "${ac_cv_objext+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+int -+main () -+{ -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.o conftest.obj -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; then -+ for ac_file in `(ls conftest.o conftest.obj; ls conftest.*) 2>/dev/null`; do -+ case $ac_file in -+ *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg ) ;; -+ *) ac_cv_objext=`expr "$ac_file" : '.*\.\(.*\)'` -+ break;; -+ esac -+done -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+{ { echo "$as_me:$LINENO: error: cannot compute suffix of object files: cannot compile -+See \`config.log' for more details." >&5 -+echo "$as_me: error: cannot compute suffix of object files: cannot compile -+See \`config.log' for more details." >&2;} -+ { (exit 1); exit 1; }; } -+fi -+ -+rm -f conftest.$ac_cv_objext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: $ac_cv_objext" >&5 -+echo "${ECHO_T}$ac_cv_objext" >&6 -+OBJEXT=$ac_cv_objext -+ac_objext=$OBJEXT -+echo "$as_me:$LINENO: checking whether we are using the GNU C compiler" >&5 -+echo $ECHO_N "checking whether we are using the GNU C compiler... $ECHO_C" >&6 -+if test "${ac_cv_c_compiler_gnu+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+int -+main () -+{ -+#ifndef __GNUC__ -+ choke me -+#endif -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_compiler_gnu=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_compiler_gnu=no -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+ac_cv_c_compiler_gnu=$ac_compiler_gnu -+ -+fi -+echo "$as_me:$LINENO: result: $ac_cv_c_compiler_gnu" >&5 -+echo "${ECHO_T}$ac_cv_c_compiler_gnu" >&6 -+GCC=`test $ac_compiler_gnu = yes && echo yes` -+ac_test_CFLAGS=${CFLAGS+set} -+ac_save_CFLAGS=$CFLAGS -+CFLAGS="-g" -+echo "$as_me:$LINENO: checking whether $CC accepts -g" >&5 -+echo $ECHO_N "checking whether $CC accepts -g... $ECHO_C" >&6 -+if test "${ac_cv_prog_cc_g+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+int -+main () -+{ -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_prog_cc_g=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_cv_prog_cc_g=no -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: $ac_cv_prog_cc_g" >&5 -+echo "${ECHO_T}$ac_cv_prog_cc_g" >&6 -+if test "$ac_test_CFLAGS" = set; then -+ CFLAGS=$ac_save_CFLAGS -+elif test $ac_cv_prog_cc_g = yes; then -+ if test "$GCC" = yes; then -+ CFLAGS="-g -O2" -+ else -+ CFLAGS="-g" -+ fi -+else -+ if test "$GCC" = yes; then -+ CFLAGS="-O2" -+ else -+ CFLAGS= -+ fi -+fi -+echo "$as_me:$LINENO: checking for $CC option to accept ANSI C" >&5 -+echo $ECHO_N "checking for $CC option to accept ANSI C... $ECHO_C" >&6 -+if test "${ac_cv_prog_cc_stdc+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ ac_cv_prog_cc_stdc=no -+ac_save_CC=$CC -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+#include -+#include -+#include -+#include -+/* Most of the following tests are stolen from RCS 5.7's src/conf.sh. */ -+struct buf { int x; }; -+FILE * (*rcsopen) (struct buf *, struct stat *, int); -+static char *e (p, i) -+ char **p; -+ int i; -+{ -+ return p[i]; -+} -+static char *f (char * (*g) (char **, int), char **p, ...) -+{ -+ char *s; -+ va_list v; -+ va_start (v,p); -+ s = g (p, va_arg (v,int)); -+ va_end (v); -+ return s; -+} -+ -+/* OSF 4.0 Compaq cc is some sort of almost-ANSI by default. It has -+ function prototypes and stuff, but not '\xHH' hex character constants. -+ These don't provoke an error unfortunately, instead are silently treated -+ as 'x'. The following induces an error, until -std1 is added to get -+ proper ANSI mode. Curiously '\x00'!='x' always comes out true, for an -+ array size at least. It's necessary to write '\x00'==0 to get something -+ that's true only with -std1. */ -+int osf4_cc_array ['\x00' == 0 ? 1 : -1]; -+ -+int test (int i, double x); -+struct s1 {int (*f) (int a);}; -+struct s2 {int (*f) (double a);}; -+int pairnames (int, char **, FILE *(*)(struct buf *, struct stat *, int), int, int); -+int argc; -+char **argv; -+int -+main () -+{ -+return f (e, argv, 0) != argv[0] || f (e, argv, 1) != argv[1]; -+ ; -+ return 0; -+} -+_ACEOF -+# Don't try gcc -ansi; that turns off useful extensions and -+# breaks some systems' header files. -+# AIX -qlanglvl=ansi -+# Ultrix and OSF/1 -std1 -+# HP-UX 10.20 and later -Ae -+# HP-UX older versions -Aa -D_HPUX_SOURCE -+# SVR4 -Xc -D__EXTENSIONS__ -+for ac_arg in "" -qlanglvl=ansi -std1 -Ae "-Aa -D_HPUX_SOURCE" "-Xc -D__EXTENSIONS__" -+do -+ CC="$ac_save_CC $ac_arg" -+ rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_prog_cc_stdc=$ac_arg -+break -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+fi -+rm -f conftest.err conftest.$ac_objext -+done -+rm -f conftest.$ac_ext conftest.$ac_objext -+CC=$ac_save_CC -+ -+fi -+ -+case "x$ac_cv_prog_cc_stdc" in -+ x|xno) -+ echo "$as_me:$LINENO: result: none needed" >&5 -+echo "${ECHO_T}none needed" >&6 ;; -+ *) -+ echo "$as_me:$LINENO: result: $ac_cv_prog_cc_stdc" >&5 -+echo "${ECHO_T}$ac_cv_prog_cc_stdc" >&6 -+ CC="$CC $ac_cv_prog_cc_stdc" ;; -+esac -+ -+# Some people use a C++ compiler to compile C. Since we use `exit', -+# in C++ we need to declare it. In case someone uses the same compiler -+# for both compiling C and C++ we need to have the C++ compiler decide -+# the declaration of exit, since it's the most demanding environment. -+cat >conftest.$ac_ext <<_ACEOF -+#ifndef __cplusplus -+ choke me -+#endif -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ for ac_declaration in \ -+ '' \ -+ 'extern "C" void std::exit (int) throw (); using std::exit;' \ -+ 'extern "C" void std::exit (int); using std::exit;' \ -+ 'extern "C" void exit (int) throw ();' \ -+ 'extern "C" void exit (int);' \ -+ 'void exit (int);' -+do -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_declaration -+#include -+int -+main () -+{ -+exit (42); -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ : -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+continue -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_declaration -+int -+main () -+{ -+exit (42); -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ break -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+done -+rm -f conftest* -+if test -n "$ac_declaration"; then -+ echo '#ifdef __cplusplus' >>confdefs.h -+ echo $ac_declaration >>confdefs.h -+ echo '#endif' >>confdefs.h -+fi -+ -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+ac_ext=c -+ac_cpp='$CPP $CPPFLAGS' -+ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -+ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -+ac_compiler_gnu=$ac_cv_c_compiler_gnu -+DEPDIR="${am__leading_dot}deps" -+ -+ ac_config_commands="$ac_config_commands depfiles" -+ -+ -+am_make=${MAKE-make} -+cat > confinc << 'END' -+am__doit: -+ @echo done -+.PHONY: am__doit -+END -+# If we don't find an include directive, just comment out the code. -+echo "$as_me:$LINENO: checking for style of include used by $am_make" >&5 -+echo $ECHO_N "checking for style of include used by $am_make... $ECHO_C" >&6 -+am__include="#" -+am__quote= -+_am_result=none -+# First try GNU make style include. -+echo "include confinc" > confmf -+# We grep out `Entering directory' and `Leaving directory' -+# messages which can occur if `w' ends up in MAKEFLAGS. -+# In particular we don't look at `^make:' because GNU make might -+# be invoked under some other name (usually "gmake"), in which -+# case it prints its new name instead of `make'. -+if test "`$am_make -s -f confmf 2> /dev/null | grep -v 'ing directory'`" = "done"; then -+ am__include=include -+ am__quote= -+ _am_result=GNU -+fi -+# Now try BSD make style include. -+if test "$am__include" = "#"; then -+ echo '.include "confinc"' > confmf -+ if test "`$am_make -s -f confmf 2> /dev/null`" = "done"; then -+ am__include=.include -+ am__quote="\"" -+ _am_result=BSD -+ fi -+fi -+ -+ -+echo "$as_me:$LINENO: result: $_am_result" >&5 -+echo "${ECHO_T}$_am_result" >&6 -+rm -f confinc confmf -+ -+# Check whether --enable-dependency-tracking or --disable-dependency-tracking was given. -+if test "${enable_dependency_tracking+set}" = set; then -+ enableval="$enable_dependency_tracking" -+ -+fi; -+if test "x$enable_dependency_tracking" != xno; then -+ am_depcomp="$ac_aux_dir/depcomp" -+ AMDEPBACKSLASH='\' -+fi -+ -+ -+if test "x$enable_dependency_tracking" != xno; then -+ AMDEP_TRUE= -+ AMDEP_FALSE='#' -+else -+ AMDEP_TRUE='#' -+ AMDEP_FALSE= -+fi -+ -+ -+ -+ -+depcc="$CC" am_compiler_list= -+ -+echo "$as_me:$LINENO: checking dependency style of $depcc" >&5 -+echo $ECHO_N "checking dependency style of $depcc... $ECHO_C" >&6 -+if test "${am_cv_CC_dependencies_compiler_type+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then -+ # We make a subdir and do the tests there. Otherwise we can end up -+ # making bogus files that we don't know about and never remove. For -+ # instance it was reported that on HP-UX the gcc test will end up -+ # making a dummy file named `D' -- because `-MD' means `put the output -+ # in D'. -+ mkdir conftest.dir -+ # Copy depcomp to subdir because otherwise we won't find it if we're -+ # using a relative directory. -+ cp "$am_depcomp" conftest.dir -+ cd conftest.dir -+ # We will build objects and dependencies in a subdirectory because -+ # it helps to detect inapplicable dependency modes. For instance -+ # both Tru64's cc and ICC support -MD to output dependencies as a -+ # side effect of compilation, but ICC will put the dependencies in -+ # the current directory while Tru64 will put them in the object -+ # directory. -+ mkdir sub -+ -+ am_cv_CC_dependencies_compiler_type=none -+ if test "$am_compiler_list" = ""; then -+ am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp` -+ fi -+ for depmode in $am_compiler_list; do -+ # Setup a source with many dependencies, because some compilers -+ # like to wrap large dependency lists on column 80 (with \), and -+ # we should not choose a depcomp mode which is confused by this. -+ # -+ # We need to recreate these files for each test, as the compiler may -+ # overwrite some of them when testing with obscure command lines. -+ # This happens at least with the AIX C compiler. -+ : > sub/conftest.c -+ for i in 1 2 3 4 5 6; do -+ echo '#include "conftst'$i'.h"' >> sub/conftest.c -+ # Using `: > sub/conftst$i.h' creates only sub/conftst1.h with -+ # Solaris 8's {/usr,}/bin/sh. -+ touch sub/conftst$i.h -+ done -+ echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf -+ -+ case $depmode in -+ nosideeffect) -+ # after this tag, mechanisms are not by side-effect, so they'll -+ # only be used when explicitly requested -+ if test "x$enable_dependency_tracking" = xyes; then -+ continue -+ else -+ break -+ fi -+ ;; -+ none) break ;; -+ esac -+ # We check with `-c' and `-o' for the sake of the "dashmstdout" -+ # mode. It turns out that the SunPro C++ compiler does not properly -+ # handle `-M -o', and we need to detect this. -+ if depmode=$depmode \ -+ source=sub/conftest.c object=sub/conftest.${OBJEXT-o} \ -+ depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ -+ $SHELL ./depcomp $depcc -c -o sub/conftest.${OBJEXT-o} sub/conftest.c \ -+ >/dev/null 2>conftest.err && -+ grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && -+ grep sub/conftest.${OBJEXT-o} sub/conftest.Po > /dev/null 2>&1 && -+ ${MAKE-make} -s -f confmf > /dev/null 2>&1; then -+ # icc doesn't choke on unknown options, it will just issue warnings -+ # or remarks (even with -Werror). So we grep stderr for any message -+ # that says an option was ignored or not supported. -+ # When given -MP, icc 7.0 and 7.1 complain thusly: -+ # icc: Command line warning: ignoring option '-M'; no argument required -+ # The diagnosis changed in icc 8.0: -+ # icc: Command line remark: option '-MP' not supported -+ if (grep 'ignoring option' conftest.err || -+ grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else -+ am_cv_CC_dependencies_compiler_type=$depmode -+ break -+ fi -+ fi -+ done -+ -+ cd .. -+ rm -rf conftest.dir -+else -+ am_cv_CC_dependencies_compiler_type=none -+fi -+ -+fi -+echo "$as_me:$LINENO: result: $am_cv_CC_dependencies_compiler_type" >&5 -+echo "${ECHO_T}$am_cv_CC_dependencies_compiler_type" >&6 -+CCDEPMODE=depmode=$am_cv_CC_dependencies_compiler_type -+ -+ -+ -+if -+ test "x$enable_dependency_tracking" != xno \ -+ && test "$am_cv_CC_dependencies_compiler_type" = gcc3; then -+ am__fastdepCC_TRUE= -+ am__fastdepCC_FALSE='#' -+else -+ am__fastdepCC_TRUE='#' -+ am__fastdepCC_FALSE= -+fi -+ -+ -+# Find a good install program. We prefer a C program (faster), -+# so one script is as good as another. But avoid the broken or -+# incompatible versions: -+# SysV /etc/install, /usr/sbin/install -+# SunOS /usr/etc/install -+# IRIX /sbin/install -+# AIX /bin/install -+# AmigaOS /C/install, which installs bootblocks on floppy discs -+# AIX 4 /usr/bin/installbsd, which doesn't work without a -g flag -+# AFS /usr/afsws/bin/install, which mishandles nonexistent args -+# SVR4 /usr/ucb/install, which tries to use the nonexistent group "staff" -+# OS/2's system install, which has a completely different semantic -+# ./install, which can be erroneously created by make from ./install.sh. -+echo "$as_me:$LINENO: checking for a BSD-compatible install" >&5 -+echo $ECHO_N "checking for a BSD-compatible install... $ECHO_C" >&6 -+if test -z "$INSTALL"; then -+if test "${ac_cv_path_install+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -+for as_dir in $PATH -+do -+ IFS=$as_save_IFS -+ test -z "$as_dir" && as_dir=. -+ # Account for people who put trailing slashes in PATH elements. -+case $as_dir/ in -+ ./ | .// | /cC/* | \ -+ /etc/* | /usr/sbin/* | /usr/etc/* | /sbin/* | /usr/afsws/bin/* | \ -+ ?:\\/os2\\/install\\/* | ?:\\/OS2\\/INSTALL\\/* | \ -+ /usr/ucb/* ) ;; -+ *) -+ # OSF1 and SCO ODT 3.0 have their own names for install. -+ # Don't use installbsd from OSF since it installs stuff as root -+ # by default. -+ for ac_prog in ginstall scoinst install; do -+ for ac_exec_ext in '' $ac_executable_extensions; do -+ if $as_executable_p "$as_dir/$ac_prog$ac_exec_ext"; then -+ if test $ac_prog = install && -+ grep dspmsg "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then -+ # AIX install. It has an incompatible calling convention. -+ : -+ elif test $ac_prog = install && -+ grep pwplus "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then -+ # program-specific install script used by HP pwplus--don't use. -+ : -+ else -+ ac_cv_path_install="$as_dir/$ac_prog$ac_exec_ext -c" -+ break 3 -+ fi -+ fi -+ done -+ done -+ ;; -+esac -+done -+ -+ -+fi -+ if test "${ac_cv_path_install+set}" = set; then -+ INSTALL=$ac_cv_path_install -+ else -+ # As a last resort, use the slow shell script. We don't cache a -+ # path for INSTALL within a source directory, because that will -+ # break other packages using the cache if that directory is -+ # removed, or if the path is relative. -+ INSTALL=$ac_install_sh -+ fi -+fi -+echo "$as_me:$LINENO: result: $INSTALL" >&5 -+echo "${ECHO_T}$INSTALL" >&6 -+ -+# Use test -z because SunOS4 sh mishandles braces in ${var-val}. -+# It thinks the first close brace ends the variable substitution. -+test -z "$INSTALL_PROGRAM" && INSTALL_PROGRAM='${INSTALL}' -+ -+test -z "$INSTALL_SCRIPT" && INSTALL_SCRIPT='${INSTALL}' -+ -+test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644' -+ -+echo "$as_me:$LINENO: checking whether ln -s works" >&5 -+echo $ECHO_N "checking whether ln -s works... $ECHO_C" >&6 -+LN_S=$as_ln_s -+if test "$LN_S" = "ln -s"; then -+ echo "$as_me:$LINENO: result: yes" >&5 -+echo "${ECHO_T}yes" >&6 -+else -+ echo "$as_me:$LINENO: result: no, using $LN_S" >&5 -+echo "${ECHO_T}no, using $LN_S" >&6 -+fi -+ -+ -+ -+ac_ext=c -+ac_cpp='$CPP $CPPFLAGS' -+ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -+ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -+ac_compiler_gnu=$ac_cv_c_compiler_gnu -+echo "$as_me:$LINENO: checking how to run the C preprocessor" >&5 -+echo $ECHO_N "checking how to run the C preprocessor... $ECHO_C" >&6 -+# On Suns, sometimes $CPP names a directory. -+if test -n "$CPP" && test -d "$CPP"; then -+ CPP= -+fi -+if test -z "$CPP"; then -+ if test "${ac_cv_prog_CPP+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ # Double quotes because CPP needs to be expanded -+ for CPP in "$CC -E" "$CC -E -traditional-cpp" "/lib/cpp" -+ do -+ ac_preproc_ok=false -+for ac_c_preproc_warn_flag in '' yes -+do -+ # Use a header file that comes with gcc, so configuring glibc -+ # with a fresh cross-compiler works. -+ # Prefer to if __STDC__ is defined, since -+ # exists even on freestanding compilers. -+ # On the NeXT, cc -E runs the code through the compiler's parser, -+ # not just through cpp. "Syntax error" is here to catch this case. -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+#ifdef __STDC__ -+# include -+#else -+# include -+#endif -+ Syntax error -+_ACEOF -+if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 -+ (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } >/dev/null; then -+ if test -s conftest.err; then -+ ac_cpp_err=$ac_c_preproc_warn_flag -+ ac_cpp_err=$ac_cpp_err$ac_c_werror_flag -+ else -+ ac_cpp_err= -+ fi -+else -+ ac_cpp_err=yes -+fi -+if test -z "$ac_cpp_err"; then -+ : -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ # Broken: fails on valid input. -+continue -+fi -+rm -f conftest.err conftest.$ac_ext -+ -+ # OK, works on sane cases. Now check whether non-existent headers -+ # can be detected and how. -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+#include -+_ACEOF -+if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 -+ (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } >/dev/null; then -+ if test -s conftest.err; then -+ ac_cpp_err=$ac_c_preproc_warn_flag -+ ac_cpp_err=$ac_cpp_err$ac_c_werror_flag -+ else -+ ac_cpp_err= -+ fi -+else -+ ac_cpp_err=yes -+fi -+if test -z "$ac_cpp_err"; then -+ # Broken: success on invalid input. -+continue -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ # Passes both tests. -+ac_preproc_ok=: -+break -+fi -+rm -f conftest.err conftest.$ac_ext -+ -+done -+# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. -+rm -f conftest.err conftest.$ac_ext -+if $ac_preproc_ok; then -+ break -+fi -+ -+ done -+ ac_cv_prog_CPP=$CPP -+ -+fi -+ CPP=$ac_cv_prog_CPP -+else -+ ac_cv_prog_CPP=$CPP -+fi -+echo "$as_me:$LINENO: result: $CPP" >&5 -+echo "${ECHO_T}$CPP" >&6 -+ac_preproc_ok=false -+for ac_c_preproc_warn_flag in '' yes -+do -+ # Use a header file that comes with gcc, so configuring glibc -+ # with a fresh cross-compiler works. -+ # Prefer to if __STDC__ is defined, since -+ # exists even on freestanding compilers. -+ # On the NeXT, cc -E runs the code through the compiler's parser, -+ # not just through cpp. "Syntax error" is here to catch this case. -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+#ifdef __STDC__ -+# include -+#else -+# include -+#endif -+ Syntax error -+_ACEOF -+if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 -+ (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } >/dev/null; then -+ if test -s conftest.err; then -+ ac_cpp_err=$ac_c_preproc_warn_flag -+ ac_cpp_err=$ac_cpp_err$ac_c_werror_flag -+ else -+ ac_cpp_err= -+ fi -+else -+ ac_cpp_err=yes -+fi -+if test -z "$ac_cpp_err"; then -+ : -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ # Broken: fails on valid input. -+continue -+fi -+rm -f conftest.err conftest.$ac_ext -+ -+ # OK, works on sane cases. Now check whether non-existent headers -+ # can be detected and how. -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+#include -+_ACEOF -+if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 -+ (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } >/dev/null; then -+ if test -s conftest.err; then -+ ac_cpp_err=$ac_c_preproc_warn_flag -+ ac_cpp_err=$ac_cpp_err$ac_c_werror_flag -+ else -+ ac_cpp_err= -+ fi -+else -+ ac_cpp_err=yes -+fi -+if test -z "$ac_cpp_err"; then -+ # Broken: success on invalid input. -+continue -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ # Passes both tests. -+ac_preproc_ok=: -+break -+fi -+rm -f conftest.err conftest.$ac_ext -+ -+done -+# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. -+rm -f conftest.err conftest.$ac_ext -+if $ac_preproc_ok; then -+ : -+else -+ { { echo "$as_me:$LINENO: error: C preprocessor \"$CPP\" fails sanity check -+See \`config.log' for more details." >&5 -+echo "$as_me: error: C preprocessor \"$CPP\" fails sanity check -+See \`config.log' for more details." >&2;} -+ { (exit 1); exit 1; }; } -+fi -+ -+ac_ext=c -+ac_cpp='$CPP $CPPFLAGS' -+ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' -+ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' -+ac_compiler_gnu=$ac_cv_c_compiler_gnu -+ -+ -+echo "$as_me:$LINENO: checking for egrep" >&5 -+echo $ECHO_N "checking for egrep... $ECHO_C" >&6 -+if test "${ac_cv_prog_egrep+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ if echo a | (grep -E '(a|b)') >/dev/null 2>&1 -+ then ac_cv_prog_egrep='grep -E' -+ else ac_cv_prog_egrep='egrep' -+ fi -+fi -+echo "$as_me:$LINENO: result: $ac_cv_prog_egrep" >&5 -+echo "${ECHO_T}$ac_cv_prog_egrep" >&6 -+ EGREP=$ac_cv_prog_egrep -+ -+ -+if test $ac_cv_c_compiler_gnu = yes; then -+ echo "$as_me:$LINENO: checking whether $CC needs -traditional" >&5 -+echo $ECHO_N "checking whether $CC needs -traditional... $ECHO_C" >&6 -+if test "${ac_cv_prog_gcc_traditional+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ ac_pattern="Autoconf.*'x'" -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+#include -+Autoconf TIOCGETP -+_ACEOF -+if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | -+ $EGREP "$ac_pattern" >/dev/null 2>&1; then -+ ac_cv_prog_gcc_traditional=yes -+else -+ ac_cv_prog_gcc_traditional=no -+fi -+rm -f conftest* -+ -+ -+ if test $ac_cv_prog_gcc_traditional = no; then -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+#include -+Autoconf TCGETA -+_ACEOF -+if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | -+ $EGREP "$ac_pattern" >/dev/null 2>&1; then -+ ac_cv_prog_gcc_traditional=yes -+fi -+rm -f conftest* -+ -+ fi -+fi -+echo "$as_me:$LINENO: result: $ac_cv_prog_gcc_traditional" >&5 -+echo "${ECHO_T}$ac_cv_prog_gcc_traditional" >&6 -+ if test $ac_cv_prog_gcc_traditional = yes; then -+ CC="$CC -traditional" -+ fi -+fi -+ -+#if test "$GCC" = yes ; then -+# CFLAGS="$CFLAGS -Wall" -+#fi -+ -+# Check whether --enable-gcc-warnings or --disable-gcc-warnings was given. -+if test "${enable_gcc_warnings+set}" = set; then -+ enableval="$enable_gcc_warnings" -+ -+fi; -+ -+if test -n "$ac_tool_prefix"; then -+ # Extract the first word of "${ac_tool_prefix}ranlib", so it can be a program name with args. -+set dummy ${ac_tool_prefix}ranlib; ac_word=$2 -+echo "$as_me:$LINENO: checking for $ac_word" >&5 -+echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 -+if test "${ac_cv_prog_RANLIB+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ if test -n "$RANLIB"; then -+ ac_cv_prog_RANLIB="$RANLIB" # Let the user override the test. -+else -+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -+for as_dir in $PATH -+do -+ IFS=$as_save_IFS -+ test -z "$as_dir" && as_dir=. -+ for ac_exec_ext in '' $ac_executable_extensions; do -+ if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then -+ ac_cv_prog_RANLIB="${ac_tool_prefix}ranlib" -+ echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 -+ break 2 -+ fi -+done -+done -+ -+fi -+fi -+RANLIB=$ac_cv_prog_RANLIB -+if test -n "$RANLIB"; then -+ echo "$as_me:$LINENO: result: $RANLIB" >&5 -+echo "${ECHO_T}$RANLIB" >&6 -+else -+ echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+fi -+ -+fi -+if test -z "$ac_cv_prog_RANLIB"; then -+ ac_ct_RANLIB=$RANLIB -+ # Extract the first word of "ranlib", so it can be a program name with args. -+set dummy ranlib; ac_word=$2 -+echo "$as_me:$LINENO: checking for $ac_word" >&5 -+echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6 -+if test "${ac_cv_prog_ac_ct_RANLIB+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ if test -n "$ac_ct_RANLIB"; then -+ ac_cv_prog_ac_ct_RANLIB="$ac_ct_RANLIB" # Let the user override the test. -+else -+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -+for as_dir in $PATH -+do -+ IFS=$as_save_IFS -+ test -z "$as_dir" && as_dir=. -+ for ac_exec_ext in '' $ac_executable_extensions; do -+ if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then -+ ac_cv_prog_ac_ct_RANLIB="ranlib" -+ echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 -+ break 2 -+ fi -+done -+done -+ -+ test -z "$ac_cv_prog_ac_ct_RANLIB" && ac_cv_prog_ac_ct_RANLIB=":" -+fi -+fi -+ac_ct_RANLIB=$ac_cv_prog_ac_ct_RANLIB -+if test -n "$ac_ct_RANLIB"; then -+ echo "$as_me:$LINENO: result: $ac_ct_RANLIB" >&5 -+echo "${ECHO_T}$ac_ct_RANLIB" >&6 -+else -+ echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+fi -+ -+ RANLIB=$ac_ct_RANLIB -+else -+ RANLIB="$ac_cv_prog_RANLIB" -+fi -+ -+ -+ -+ -+echo "$as_me:$LINENO: checking for socket in -lsocket" >&5 -+echo $ECHO_N "checking for socket in -lsocket... $ECHO_C" >&6 -+if test "${ac_cv_lib_socket_socket+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ ac_check_lib_save_LIBS=$LIBS -+LIBS="-lsocket $LIBS" -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+/* Override any gcc2 internal prototype to avoid an error. */ -+#ifdef __cplusplus -+extern "C" -+#endif -+/* We use char because int might match the return type of a gcc2 -+ builtin and then its argument prototype would still apply. */ -+char socket (); -+int -+main () -+{ -+socket (); -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext conftest$ac_exeext -+if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 -+ (eval $ac_link) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest$ac_exeext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_lib_socket_socket=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_cv_lib_socket_socket=no -+fi -+rm -f conftest.err conftest.$ac_objext \ -+ conftest$ac_exeext conftest.$ac_ext -+LIBS=$ac_check_lib_save_LIBS -+fi -+echo "$as_me:$LINENO: result: $ac_cv_lib_socket_socket" >&5 -+echo "${ECHO_T}$ac_cv_lib_socket_socket" >&6 -+if test $ac_cv_lib_socket_socket = yes; then -+ cat >>confdefs.h <<_ACEOF -+#define HAVE_LIBSOCKET 1 -+_ACEOF -+ -+ LIBS="-lsocket $LIBS" -+ -+fi -+ -+ -+echo "$as_me:$LINENO: checking for inet_aton in -lresolv" >&5 -+echo $ECHO_N "checking for inet_aton in -lresolv... $ECHO_C" >&6 -+if test "${ac_cv_lib_resolv_inet_aton+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ ac_check_lib_save_LIBS=$LIBS -+LIBS="-lresolv $LIBS" -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+/* Override any gcc2 internal prototype to avoid an error. */ -+#ifdef __cplusplus -+extern "C" -+#endif -+/* We use char because int might match the return type of a gcc2 -+ builtin and then its argument prototype would still apply. */ -+char inet_aton (); -+int -+main () -+{ -+inet_aton (); -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext conftest$ac_exeext -+if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 -+ (eval $ac_link) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest$ac_exeext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_lib_resolv_inet_aton=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_cv_lib_resolv_inet_aton=no -+fi -+rm -f conftest.err conftest.$ac_objext \ -+ conftest$ac_exeext conftest.$ac_ext -+LIBS=$ac_check_lib_save_LIBS -+fi -+echo "$as_me:$LINENO: result: $ac_cv_lib_resolv_inet_aton" >&5 -+echo "${ECHO_T}$ac_cv_lib_resolv_inet_aton" >&6 -+if test $ac_cv_lib_resolv_inet_aton = yes; then -+ cat >>confdefs.h <<_ACEOF -+#define HAVE_LIBRESOLV 1 -+_ACEOF -+ -+ LIBS="-lresolv $LIBS" -+ -+fi -+ -+ -+echo "$as_me:$LINENO: checking for clock_gettime in -lrt" >&5 -+echo $ECHO_N "checking for clock_gettime in -lrt... $ECHO_C" >&6 -+if test "${ac_cv_lib_rt_clock_gettime+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ ac_check_lib_save_LIBS=$LIBS -+LIBS="-lrt $LIBS" -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+/* Override any gcc2 internal prototype to avoid an error. */ -+#ifdef __cplusplus -+extern "C" -+#endif -+/* We use char because int might match the return type of a gcc2 -+ builtin and then its argument prototype would still apply. */ -+char clock_gettime (); -+int -+main () -+{ -+clock_gettime (); -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext conftest$ac_exeext -+if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 -+ (eval $ac_link) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest$ac_exeext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_lib_rt_clock_gettime=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_cv_lib_rt_clock_gettime=no -+fi -+rm -f conftest.err conftest.$ac_objext \ -+ conftest$ac_exeext conftest.$ac_ext -+LIBS=$ac_check_lib_save_LIBS -+fi -+echo "$as_me:$LINENO: result: $ac_cv_lib_rt_clock_gettime" >&5 -+echo "${ECHO_T}$ac_cv_lib_rt_clock_gettime" >&6 -+if test $ac_cv_lib_rt_clock_gettime = yes; then -+ cat >>confdefs.h <<_ACEOF -+#define HAVE_LIBRT 1 -+_ACEOF -+ -+ LIBS="-lrt $LIBS" -+ -+fi -+ -+ -+echo "$as_me:$LINENO: checking for inet_ntoa in -lnsl" >&5 -+echo $ECHO_N "checking for inet_ntoa in -lnsl... $ECHO_C" >&6 -+if test "${ac_cv_lib_nsl_inet_ntoa+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ ac_check_lib_save_LIBS=$LIBS -+LIBS="-lnsl $LIBS" -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+/* Override any gcc2 internal prototype to avoid an error. */ -+#ifdef __cplusplus -+extern "C" -+#endif -+/* We use char because int might match the return type of a gcc2 -+ builtin and then its argument prototype would still apply. */ -+char inet_ntoa (); -+int -+main () -+{ -+inet_ntoa (); -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext conftest$ac_exeext -+if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 -+ (eval $ac_link) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest$ac_exeext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_lib_nsl_inet_ntoa=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_cv_lib_nsl_inet_ntoa=no -+fi -+rm -f conftest.err conftest.$ac_objext \ -+ conftest$ac_exeext conftest.$ac_ext -+LIBS=$ac_check_lib_save_LIBS -+fi -+echo "$as_me:$LINENO: result: $ac_cv_lib_nsl_inet_ntoa" >&5 -+echo "${ECHO_T}$ac_cv_lib_nsl_inet_ntoa" >&6 -+if test $ac_cv_lib_nsl_inet_ntoa = yes; then -+ cat >>confdefs.h <<_ACEOF -+#define HAVE_LIBNSL 1 -+_ACEOF -+ -+ LIBS="-lnsl $LIBS" -+ -+fi -+ -+ -+echo "$as_me:$LINENO: checking for ANSI C header files" >&5 -+echo $ECHO_N "checking for ANSI C header files... $ECHO_C" >&6 -+if test "${ac_cv_header_stdc+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+#include -+#include -+#include -+#include -+ -+int -+main () -+{ -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_header_stdc=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_cv_header_stdc=no -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+ -+if test $ac_cv_header_stdc = yes; then -+ # SunOS 4.x string.h does not declare mem*, contrary to ANSI. -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+#include -+ -+_ACEOF -+if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | -+ $EGREP "memchr" >/dev/null 2>&1; then -+ : -+else -+ ac_cv_header_stdc=no -+fi -+rm -f conftest* -+ -+fi -+ -+if test $ac_cv_header_stdc = yes; then -+ # ISC 2.0.2 stdlib.h does not declare free, contrary to ANSI. -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+#include -+ -+_ACEOF -+if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | -+ $EGREP "free" >/dev/null 2>&1; then -+ : -+else -+ ac_cv_header_stdc=no -+fi -+rm -f conftest* -+ -+fi -+ -+if test $ac_cv_header_stdc = yes; then -+ # /bin/cc in Irix-4.0.5 gets non-ANSI ctype macros unless using -ansi. -+ if test "$cross_compiling" = yes; then -+ : -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+#include -+#if ((' ' & 0x0FF) == 0x020) -+# define ISLOWER(c) ('a' <= (c) && (c) <= 'z') -+# define TOUPPER(c) (ISLOWER(c) ? 'A' + ((c) - 'a') : (c)) -+#else -+# define ISLOWER(c) \ -+ (('a' <= (c) && (c) <= 'i') \ -+ || ('j' <= (c) && (c) <= 'r') \ -+ || ('s' <= (c) && (c) <= 'z')) -+# define TOUPPER(c) (ISLOWER(c) ? ((c) | 0x40) : (c)) -+#endif -+ -+#define XOR(e, f) (((e) && !(f)) || (!(e) && (f))) -+int -+main () -+{ -+ int i; -+ for (i = 0; i < 256; i++) -+ if (XOR (islower (i), ISLOWER (i)) -+ || toupper (i) != TOUPPER (i)) -+ exit(2); -+ exit (0); -+} -+_ACEOF -+rm -f conftest$ac_exeext -+if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 -+ (eval $ac_link) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && { ac_try='./conftest$ac_exeext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ : -+else -+ echo "$as_me: program exited with status $ac_status" >&5 -+echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+( exit $ac_status ) -+ac_cv_header_stdc=no -+fi -+rm -f core *.core gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext -+fi -+fi -+fi -+echo "$as_me:$LINENO: result: $ac_cv_header_stdc" >&5 -+echo "${ECHO_T}$ac_cv_header_stdc" >&6 -+if test $ac_cv_header_stdc = yes; then -+ -+cat >>confdefs.h <<\_ACEOF -+#define STDC_HEADERS 1 -+_ACEOF -+ -+fi -+ -+# On IRIX 5.3, sys/types and inttypes.h are conflicting. -+ -+ -+ -+ -+ -+ -+ -+ -+ -+for ac_header in sys/types.h sys/stat.h stdlib.h string.h memory.h strings.h \ -+ inttypes.h stdint.h unistd.h -+do -+as_ac_Header=`echo "ac_cv_header_$ac_header" | $as_tr_sh` -+echo "$as_me:$LINENO: checking for $ac_header" >&5 -+echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6 -+if eval "test \"\${$as_ac_Header+set}\" = set"; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+ -+#include <$ac_header> -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ eval "$as_ac_Header=yes" -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+eval "$as_ac_Header=no" -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5 -+echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6 -+if test `eval echo '${'$as_ac_Header'}'` = yes; then -+ cat >>confdefs.h <<_ACEOF -+#define `echo "HAVE_$ac_header" | $as_tr_cpp` 1 -+_ACEOF -+ -+fi -+ -+done -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+for ac_header in fcntl.h stdarg.h inttypes.h stdint.h poll.h signal.h unistd.h sys/epoll.h sys/time.h sys/queue.h sys/event.h sys/param.h sys/ioctl.h sys/select.h sys/devpoll.h port.h netinet/in6.h sys/socket.h -+do -+as_ac_Header=`echo "ac_cv_header_$ac_header" | $as_tr_sh` -+if eval "test \"\${$as_ac_Header+set}\" = set"; then -+ echo "$as_me:$LINENO: checking for $ac_header" >&5 -+echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6 -+if eval "test \"\${$as_ac_Header+set}\" = set"; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+fi -+echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5 -+echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6 -+else -+ # Is the header compilable? -+echo "$as_me:$LINENO: checking $ac_header usability" >&5 -+echo $ECHO_N "checking $ac_header usability... $ECHO_C" >&6 -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+#include <$ac_header> -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_header_compiler=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_header_compiler=no -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+echo "$as_me:$LINENO: result: $ac_header_compiler" >&5 -+echo "${ECHO_T}$ac_header_compiler" >&6 -+ -+# Is the header present? -+echo "$as_me:$LINENO: checking $ac_header presence" >&5 -+echo $ECHO_N "checking $ac_header presence... $ECHO_C" >&6 -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+#include <$ac_header> -+_ACEOF -+if { (eval echo "$as_me:$LINENO: \"$ac_cpp conftest.$ac_ext\"") >&5 -+ (eval $ac_cpp conftest.$ac_ext) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } >/dev/null; then -+ if test -s conftest.err; then -+ ac_cpp_err=$ac_c_preproc_warn_flag -+ ac_cpp_err=$ac_cpp_err$ac_c_werror_flag -+ else -+ ac_cpp_err= -+ fi -+else -+ ac_cpp_err=yes -+fi -+if test -z "$ac_cpp_err"; then -+ ac_header_preproc=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ ac_header_preproc=no -+fi -+rm -f conftest.err conftest.$ac_ext -+echo "$as_me:$LINENO: result: $ac_header_preproc" >&5 -+echo "${ECHO_T}$ac_header_preproc" >&6 -+ -+# So? What about this header? -+case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in -+ yes:no: ) -+ { echo "$as_me:$LINENO: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&5 -+echo "$as_me: WARNING: $ac_header: accepted by the compiler, rejected by the preprocessor!" >&2;} -+ { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the compiler's result" >&5 -+echo "$as_me: WARNING: $ac_header: proceeding with the compiler's result" >&2;} -+ ac_header_preproc=yes -+ ;; -+ no:yes:* ) -+ { echo "$as_me:$LINENO: WARNING: $ac_header: present but cannot be compiled" >&5 -+echo "$as_me: WARNING: $ac_header: present but cannot be compiled" >&2;} -+ { echo "$as_me:$LINENO: WARNING: $ac_header: check for missing prerequisite headers?" >&5 -+echo "$as_me: WARNING: $ac_header: check for missing prerequisite headers?" >&2;} -+ { echo "$as_me:$LINENO: WARNING: $ac_header: see the Autoconf documentation" >&5 -+echo "$as_me: WARNING: $ac_header: see the Autoconf documentation" >&2;} -+ { echo "$as_me:$LINENO: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&5 -+echo "$as_me: WARNING: $ac_header: section \"Present But Cannot Be Compiled\"" >&2;} -+ { echo "$as_me:$LINENO: WARNING: $ac_header: proceeding with the preprocessor's result" >&5 -+echo "$as_me: WARNING: $ac_header: proceeding with the preprocessor's result" >&2;} -+ { echo "$as_me:$LINENO: WARNING: $ac_header: in the future, the compiler will take precedence" >&5 -+echo "$as_me: WARNING: $ac_header: in the future, the compiler will take precedence" >&2;} -+ ( -+ cat <<\_ASBOX -+## ------------------------------------------ ## -+## Report this to the AC_PACKAGE_NAME lists. ## -+## ------------------------------------------ ## -+_ASBOX -+ ) | -+ sed "s/^/$as_me: WARNING: /" >&2 -+ ;; -+esac -+echo "$as_me:$LINENO: checking for $ac_header" >&5 -+echo $ECHO_N "checking for $ac_header... $ECHO_C" >&6 -+if eval "test \"\${$as_ac_Header+set}\" = set"; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ eval "$as_ac_Header=\$ac_header_preproc" -+fi -+echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_Header'}'`" >&5 -+echo "${ECHO_T}`eval echo '${'$as_ac_Header'}'`" >&6 -+ -+fi -+if test `eval echo '${'$as_ac_Header'}'` = yes; then -+ cat >>confdefs.h <<_ACEOF -+#define `echo "HAVE_$ac_header" | $as_tr_cpp` 1 -+_ACEOF -+ -+fi -+ -+done -+ -+if test "x$ac_cv_header_sys_queue_h" = "xyes"; then -+ echo "$as_me:$LINENO: checking for TAILQ_FOREACH in sys/queue.h" >&5 -+echo $ECHO_N "checking for TAILQ_FOREACH in sys/queue.h... $ECHO_C" >&6 -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+#include -+#ifdef TAILQ_FOREACH -+ yes -+#endif -+ -+_ACEOF -+if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | -+ $EGREP "yes" >/dev/null 2>&1; then -+ echo "$as_me:$LINENO: result: yes" >&5 -+echo "${ECHO_T}yes" >&6 -+ -+cat >>confdefs.h <<\_ACEOF -+#define HAVE_TAILQFOREACH 1 -+_ACEOF -+ -+else -+ echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+ -+fi -+rm -f conftest* -+ -+fi -+ -+if test "x$ac_cv_header_sys_time_h" = "xyes"; then -+ echo "$as_me:$LINENO: checking for timeradd in sys/time.h" >&5 -+echo $ECHO_N "checking for timeradd in sys/time.h... $ECHO_C" >&6 -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+#include -+#ifdef timeradd -+ yes -+#endif -+ -+_ACEOF -+if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | -+ $EGREP "yes" >/dev/null 2>&1; then -+ -+cat >>confdefs.h <<\_ACEOF -+#define HAVE_TIMERADD 1 -+_ACEOF -+ -+ echo "$as_me:$LINENO: result: yes" >&5 -+echo "${ECHO_T}yes" >&6 -+else -+ echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+ -+fi -+rm -f conftest* -+ -+fi -+ -+if test "x$ac_cv_header_sys_time_h" = "xyes"; then -+ echo "$as_me:$LINENO: checking for timercmp in sys/time.h" >&5 -+echo $ECHO_N "checking for timercmp in sys/time.h... $ECHO_C" >&6 -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+#include -+#ifdef timercmp -+ yes -+#endif -+ -+_ACEOF -+if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | -+ $EGREP "yes" >/dev/null 2>&1; then -+ -+cat >>confdefs.h <<\_ACEOF -+#define HAVE_TIMERCMP 1 -+_ACEOF -+ -+ echo "$as_me:$LINENO: result: yes" >&5 -+echo "${ECHO_T}yes" >&6 -+else -+ echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+ -+fi -+rm -f conftest* -+ -+fi -+ -+if test "x$ac_cv_header_sys_time_h" = "xyes"; then -+ echo "$as_me:$LINENO: checking for timerclear in sys/time.h" >&5 -+echo $ECHO_N "checking for timerclear in sys/time.h... $ECHO_C" >&6 -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+#include -+#ifdef timerclear -+ yes -+#endif -+ -+_ACEOF -+if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | -+ $EGREP "yes" >/dev/null 2>&1; then -+ -+cat >>confdefs.h <<\_ACEOF -+#define HAVE_TIMERCLEAR 1 -+_ACEOF -+ -+ echo "$as_me:$LINENO: result: yes" >&5 -+echo "${ECHO_T}yes" >&6 -+else -+ echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+ -+fi -+rm -f conftest* -+ -+fi -+ -+if test "x$ac_cv_header_sys_time_h" = "xyes"; then -+ echo "$as_me:$LINENO: checking for timerisset in sys/time.h" >&5 -+echo $ECHO_N "checking for timerisset in sys/time.h... $ECHO_C" >&6 -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+#include -+#ifdef timerisset -+ yes -+#endif -+ -+_ACEOF -+if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | -+ $EGREP "yes" >/dev/null 2>&1; then -+ -+cat >>confdefs.h <<\_ACEOF -+#define HAVE_TIMERISSET 1 -+_ACEOF -+ -+ echo "$as_me:$LINENO: result: yes" >&5 -+echo "${ECHO_T}yes" >&6 -+else -+ echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+ -+fi -+rm -f conftest* -+ -+fi -+ -+echo "$as_me:$LINENO: checking for WIN32" >&5 -+echo $ECHO_N "checking for WIN32... $ECHO_C" >&6 -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+int -+main () -+{ -+ -+#ifndef WIN32 -+die horribly -+#endif -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ bwin32=true; echo "$as_me:$LINENO: result: yes" >&5 -+echo "${ECHO_T}yes" >&6 -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+bwin32=false; echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+ -+ -+ -+if test x$bwin32 = xtrue; then -+ BUILD_WIN32_TRUE= -+ BUILD_WIN32_FALSE='#' -+else -+ BUILD_WIN32_TRUE='#' -+ BUILD_WIN32_FALSE= -+fi -+ -+ -+echo "$as_me:$LINENO: checking for an ANSI C-conforming const" >&5 -+echo $ECHO_N "checking for an ANSI C-conforming const... $ECHO_C" >&6 -+if test "${ac_cv_c_const+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+int -+main () -+{ -+/* FIXME: Include the comments suggested by Paul. */ -+#ifndef __cplusplus -+ /* Ultrix mips cc rejects this. */ -+ typedef int charset[2]; -+ const charset x; -+ /* SunOS 4.1.1 cc rejects this. */ -+ char const *const *ccp; -+ char **p; -+ /* NEC SVR4.0.2 mips cc rejects this. */ -+ struct point {int x, y;}; -+ static struct point const zero = {0,0}; -+ /* AIX XL C 1.02.0.0 rejects this. -+ It does not let you subtract one const X* pointer from another in -+ an arm of an if-expression whose if-part is not a constant -+ expression */ -+ const char *g = "string"; -+ ccp = &g + (g ? g-g : 0); -+ /* HPUX 7.0 cc rejects these. */ -+ ++ccp; -+ p = (char**) ccp; -+ ccp = (char const *const *) p; -+ { /* SCO 3.2v4 cc rejects this. */ -+ char *t; -+ char const *s = 0 ? (char *) 0 : (char const *) 0; -+ -+ *t++ = 0; -+ } -+ { /* Someone thinks the Sun supposedly-ANSI compiler will reject this. */ -+ int x[] = {25, 17}; -+ const int *foo = &x[0]; -+ ++foo; -+ } -+ { /* Sun SC1.0 ANSI compiler rejects this -- but not the above. */ -+ typedef const int *iptr; -+ iptr p = 0; -+ ++p; -+ } -+ { /* AIX XL C 1.02.0.0 rejects this saying -+ "k.c", line 2.27: 1506-025 (S) Operand must be a modifiable lvalue. */ -+ struct s { int j; const int *ap[3]; }; -+ struct s *b; b->j = 5; -+ } -+ { /* ULTRIX-32 V3.1 (Rev 9) vcc rejects this */ -+ const int foo = 10; -+ } -+#endif -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_c_const=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_cv_c_const=no -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: $ac_cv_c_const" >&5 -+echo "${ECHO_T}$ac_cv_c_const" >&6 -+if test $ac_cv_c_const = no; then -+ -+cat >>confdefs.h <<\_ACEOF -+#define const -+_ACEOF -+ -+fi -+ -+echo "$as_me:$LINENO: checking for inline" >&5 -+echo $ECHO_N "checking for inline... $ECHO_C" >&6 -+if test "${ac_cv_c_inline+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ ac_cv_c_inline=no -+for ac_kw in inline __inline__ __inline; do -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+#ifndef __cplusplus -+typedef int foo_t; -+static $ac_kw foo_t static_foo () {return 0; } -+$ac_kw foo_t foo () {return 0; } -+#endif -+ -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_c_inline=$ac_kw; break -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+done -+ -+fi -+echo "$as_me:$LINENO: result: $ac_cv_c_inline" >&5 -+echo "${ECHO_T}$ac_cv_c_inline" >&6 -+ -+ -+case $ac_cv_c_inline in -+ inline | yes) ;; -+ *) -+ case $ac_cv_c_inline in -+ no) ac_val=;; -+ *) ac_val=$ac_cv_c_inline;; -+ esac -+ cat >>confdefs.h <<_ACEOF -+#ifndef __cplusplus -+#define inline $ac_val -+#endif -+_ACEOF -+ ;; -+esac -+ -+echo "$as_me:$LINENO: checking whether time.h and sys/time.h may both be included" >&5 -+echo $ECHO_N "checking whether time.h and sys/time.h may both be included... $ECHO_C" >&6 -+if test "${ac_cv_header_time+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+#include -+#include -+#include -+ -+int -+main () -+{ -+if ((struct tm *) 0) -+return 0; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_header_time=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_cv_header_time=no -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: $ac_cv_header_time" >&5 -+echo "${ECHO_T}$ac_cv_header_time" >&6 -+if test $ac_cv_header_time = yes; then -+ -+cat >>confdefs.h <<\_ACEOF -+#define TIME_WITH_SYS_TIME 1 -+_ACEOF -+ -+fi -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+ -+for ac_func in gettimeofday vasprintf fcntl clock_gettime strtok_r strsep getaddrinfo getnameinfo strlcpy inet_ntop signal sigaction strtoll -+do -+as_ac_var=`echo "ac_cv_func_$ac_func" | $as_tr_sh` -+echo "$as_me:$LINENO: checking for $ac_func" >&5 -+echo $ECHO_N "checking for $ac_func... $ECHO_C" >&6 -+if eval "test \"\${$as_ac_var+set}\" = set"; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+/* Define $ac_func to an innocuous variant, in case declares $ac_func. -+ For example, HP-UX 11i declares gettimeofday. */ -+#define $ac_func innocuous_$ac_func -+ -+/* System header to define __stub macros and hopefully few prototypes, -+ which can conflict with char $ac_func (); below. -+ Prefer to if __STDC__ is defined, since -+ exists even on freestanding compilers. */ -+ -+#ifdef __STDC__ -+# include -+#else -+# include -+#endif -+ -+#undef $ac_func -+ -+/* Override any gcc2 internal prototype to avoid an error. */ -+#ifdef __cplusplus -+extern "C" -+{ -+#endif -+/* We use char because int might match the return type of a gcc2 -+ builtin and then its argument prototype would still apply. */ -+char $ac_func (); -+/* The GNU C library defines this for functions which it implements -+ to always fail with ENOSYS. Some functions are actually named -+ something starting with __ and the normal name is an alias. */ -+#if defined (__stub_$ac_func) || defined (__stub___$ac_func) -+choke me -+#else -+char (*f) () = $ac_func; -+#endif -+#ifdef __cplusplus -+} -+#endif -+ -+int -+main () -+{ -+return f != $ac_func; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext conftest$ac_exeext -+if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 -+ (eval $ac_link) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest$ac_exeext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ eval "$as_ac_var=yes" -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+eval "$as_ac_var=no" -+fi -+rm -f conftest.err conftest.$ac_objext \ -+ conftest$ac_exeext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_var'}'`" >&5 -+echo "${ECHO_T}`eval echo '${'$as_ac_var'}'`" >&6 -+if test `eval echo '${'$as_ac_var'}'` = yes; then -+ cat >>confdefs.h <<_ACEOF -+#define `echo "HAVE_$ac_func" | $as_tr_cpp` 1 -+_ACEOF -+ -+fi -+done -+ -+ -+echo "$as_me:$LINENO: checking for long" >&5 -+echo $ECHO_N "checking for long... $ECHO_C" >&6 -+if test "${ac_cv_type_long+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+if ((long *) 0) -+ return 0; -+if (sizeof (long)) -+ return 0; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_type_long=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_cv_type_long=no -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: $ac_cv_type_long" >&5 -+echo "${ECHO_T}$ac_cv_type_long" >&6 -+ -+echo "$as_me:$LINENO: checking size of long" >&5 -+echo $ECHO_N "checking size of long... $ECHO_C" >&6 -+if test "${ac_cv_sizeof_long+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ if test "$ac_cv_type_long" = yes; then -+ # The cast to unsigned long works around a bug in the HP C Compiler -+ # version HP92453-01 B.11.11.23709.GP, which incorrectly rejects -+ # declarations like `int a3[[(sizeof (unsigned char)) >= 0]];'. -+ # This bug is HP SR number 8606223364. -+ if test "$cross_compiling" = yes; then -+ # Depending upon the size, compute the lo and hi bounds. -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (long))) >= 0)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_lo=0 ac_mid=0 -+ while :; do -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (long))) <= $ac_mid)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_hi=$ac_mid; break -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_lo=`expr $ac_mid + 1` -+ if test $ac_lo -le $ac_mid; then -+ ac_lo= ac_hi= -+ break -+ fi -+ ac_mid=`expr 2 '*' $ac_mid + 1` -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+ done -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (long))) < 0)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_hi=-1 ac_mid=-1 -+ while :; do -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (long))) >= $ac_mid)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_lo=$ac_mid; break -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_hi=`expr '(' $ac_mid ')' - 1` -+ if test $ac_mid -le $ac_hi; then -+ ac_lo= ac_hi= -+ break -+ fi -+ ac_mid=`expr 2 '*' $ac_mid` -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+ done -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_lo= ac_hi= -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+# Binary search between lo and hi bounds. -+while test "x$ac_lo" != "x$ac_hi"; do -+ ac_mid=`expr '(' $ac_hi - $ac_lo ')' / 2 + $ac_lo` -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (long))) <= $ac_mid)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_hi=$ac_mid -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_lo=`expr '(' $ac_mid ')' + 1` -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+done -+case $ac_lo in -+?*) ac_cv_sizeof_long=$ac_lo;; -+'') { { echo "$as_me:$LINENO: error: cannot compute sizeof (long), 77 -+See \`config.log' for more details." >&5 -+echo "$as_me: error: cannot compute sizeof (long), 77 -+See \`config.log' for more details." >&2;} -+ { (exit 1); exit 1; }; } ;; -+esac -+else -+ if test "$cross_compiling" = yes; then -+ { { echo "$as_me:$LINENO: error: cannot run test program while cross compiling -+See \`config.log' for more details." >&5 -+echo "$as_me: error: cannot run test program while cross compiling -+See \`config.log' for more details." >&2;} -+ { (exit 1); exit 1; }; } -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+long longval () { return (long) (sizeof (long)); } -+unsigned long ulongval () { return (long) (sizeof (long)); } -+#include -+#include -+int -+main () -+{ -+ -+ FILE *f = fopen ("conftest.val", "w"); -+ if (! f) -+ exit (1); -+ if (((long) (sizeof (long))) < 0) -+ { -+ long i = longval (); -+ if (i != ((long) (sizeof (long)))) -+ exit (1); -+ fprintf (f, "%ld\n", i); -+ } -+ else -+ { -+ unsigned long i = ulongval (); -+ if (i != ((long) (sizeof (long)))) -+ exit (1); -+ fprintf (f, "%lu\n", i); -+ } -+ exit (ferror (f) || fclose (f) != 0); -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest$ac_exeext -+if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 -+ (eval $ac_link) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && { ac_try='./conftest$ac_exeext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_sizeof_long=`cat conftest.val` -+else -+ echo "$as_me: program exited with status $ac_status" >&5 -+echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+( exit $ac_status ) -+{ { echo "$as_me:$LINENO: error: cannot compute sizeof (long), 77 -+See \`config.log' for more details." >&5 -+echo "$as_me: error: cannot compute sizeof (long), 77 -+See \`config.log' for more details." >&2;} -+ { (exit 1); exit 1; }; } -+fi -+rm -f core *.core gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext -+fi -+fi -+rm -f conftest.val -+else -+ ac_cv_sizeof_long=0 -+fi -+fi -+echo "$as_me:$LINENO: result: $ac_cv_sizeof_long" >&5 -+echo "${ECHO_T}$ac_cv_sizeof_long" >&6 -+cat >>confdefs.h <<_ACEOF -+#define SIZEOF_LONG $ac_cv_sizeof_long -+_ACEOF -+ -+ -+ -+if test "x$ac_cv_func_clock_gettime" = "xyes"; then -+ -+cat >>confdefs.h <<\_ACEOF -+#define DNS_USE_CPU_CLOCK_FOR_ID 1 -+_ACEOF -+ -+else -+ -+cat >>confdefs.h <<\_ACEOF -+#define DNS_USE_GETTIMEOFDAY_FOR_ID 1 -+_ACEOF -+ -+fi -+ -+echo "$as_me:$LINENO: checking for F_SETFD in fcntl.h" >&5 -+echo $ECHO_N "checking for F_SETFD in fcntl.h... $ECHO_C" >&6 -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+#define _GNU_SOURCE -+#include -+#ifdef F_SETFD -+yes -+#endif -+ -+_ACEOF -+if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | -+ $EGREP "yes" >/dev/null 2>&1; then -+ -+cat >>confdefs.h <<\_ACEOF -+#define HAVE_SETFD 1 -+_ACEOF -+ -+ echo "$as_me:$LINENO: result: yes" >&5 -+echo "${ECHO_T}yes" >&6 -+else -+ echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+fi -+rm -f conftest* -+ -+ -+needsignal=no -+haveselect=no -+ -+for ac_func in select -+do -+as_ac_var=`echo "ac_cv_func_$ac_func" | $as_tr_sh` -+echo "$as_me:$LINENO: checking for $ac_func" >&5 -+echo $ECHO_N "checking for $ac_func... $ECHO_C" >&6 -+if eval "test \"\${$as_ac_var+set}\" = set"; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+/* Define $ac_func to an innocuous variant, in case declares $ac_func. -+ For example, HP-UX 11i declares gettimeofday. */ -+#define $ac_func innocuous_$ac_func -+ -+/* System header to define __stub macros and hopefully few prototypes, -+ which can conflict with char $ac_func (); below. -+ Prefer to if __STDC__ is defined, since -+ exists even on freestanding compilers. */ -+ -+#ifdef __STDC__ -+# include -+#else -+# include -+#endif -+ -+#undef $ac_func -+ -+/* Override any gcc2 internal prototype to avoid an error. */ -+#ifdef __cplusplus -+extern "C" -+{ -+#endif -+/* We use char because int might match the return type of a gcc2 -+ builtin and then its argument prototype would still apply. */ -+char $ac_func (); -+/* The GNU C library defines this for functions which it implements -+ to always fail with ENOSYS. Some functions are actually named -+ something starting with __ and the normal name is an alias. */ -+#if defined (__stub_$ac_func) || defined (__stub___$ac_func) -+choke me -+#else -+char (*f) () = $ac_func; -+#endif -+#ifdef __cplusplus -+} -+#endif -+ -+int -+main () -+{ -+return f != $ac_func; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext conftest$ac_exeext -+if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 -+ (eval $ac_link) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest$ac_exeext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ eval "$as_ac_var=yes" -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+eval "$as_ac_var=no" -+fi -+rm -f conftest.err conftest.$ac_objext \ -+ conftest$ac_exeext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_var'}'`" >&5 -+echo "${ECHO_T}`eval echo '${'$as_ac_var'}'`" >&6 -+if test `eval echo '${'$as_ac_var'}'` = yes; then -+ cat >>confdefs.h <<_ACEOF -+#define `echo "HAVE_$ac_func" | $as_tr_cpp` 1 -+_ACEOF -+ haveselect=yes -+fi -+done -+ -+if test "x$haveselect" = "xyes" ; then -+ case $LIBOBJS in -+ "select.$ac_objext" | \ -+ *" select.$ac_objext" | \ -+ "select.$ac_objext "* | \ -+ *" select.$ac_objext "* ) ;; -+ *) LIBOBJS="$LIBOBJS select.$ac_objext" ;; -+esac -+ -+ needsignal=yes -+fi -+ -+havepoll=no -+ -+for ac_func in poll -+do -+as_ac_var=`echo "ac_cv_func_$ac_func" | $as_tr_sh` -+echo "$as_me:$LINENO: checking for $ac_func" >&5 -+echo $ECHO_N "checking for $ac_func... $ECHO_C" >&6 -+if eval "test \"\${$as_ac_var+set}\" = set"; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+/* Define $ac_func to an innocuous variant, in case declares $ac_func. -+ For example, HP-UX 11i declares gettimeofday. */ -+#define $ac_func innocuous_$ac_func -+ -+/* System header to define __stub macros and hopefully few prototypes, -+ which can conflict with char $ac_func (); below. -+ Prefer to if __STDC__ is defined, since -+ exists even on freestanding compilers. */ -+ -+#ifdef __STDC__ -+# include -+#else -+# include -+#endif -+ -+#undef $ac_func -+ -+/* Override any gcc2 internal prototype to avoid an error. */ -+#ifdef __cplusplus -+extern "C" -+{ -+#endif -+/* We use char because int might match the return type of a gcc2 -+ builtin and then its argument prototype would still apply. */ -+char $ac_func (); -+/* The GNU C library defines this for functions which it implements -+ to always fail with ENOSYS. Some functions are actually named -+ something starting with __ and the normal name is an alias. */ -+#if defined (__stub_$ac_func) || defined (__stub___$ac_func) -+choke me -+#else -+char (*f) () = $ac_func; -+#endif -+#ifdef __cplusplus -+} -+#endif -+ -+int -+main () -+{ -+return f != $ac_func; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext conftest$ac_exeext -+if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 -+ (eval $ac_link) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest$ac_exeext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ eval "$as_ac_var=yes" -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+eval "$as_ac_var=no" -+fi -+rm -f conftest.err conftest.$ac_objext \ -+ conftest$ac_exeext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_var'}'`" >&5 -+echo "${ECHO_T}`eval echo '${'$as_ac_var'}'`" >&6 -+if test `eval echo '${'$as_ac_var'}'` = yes; then -+ cat >>confdefs.h <<_ACEOF -+#define `echo "HAVE_$ac_func" | $as_tr_cpp` 1 -+_ACEOF -+ havepoll=yes -+fi -+done -+ -+if test "x$havepoll" = "xyes" ; then -+ case $LIBOBJS in -+ "poll.$ac_objext" | \ -+ *" poll.$ac_objext" | \ -+ "poll.$ac_objext "* | \ -+ *" poll.$ac_objext "* ) ;; -+ *) LIBOBJS="$LIBOBJS poll.$ac_objext" ;; -+esac -+ -+ needsignal=yes -+fi -+ -+haveepoll=no -+ -+for ac_func in epoll_ctl -+do -+as_ac_var=`echo "ac_cv_func_$ac_func" | $as_tr_sh` -+echo "$as_me:$LINENO: checking for $ac_func" >&5 -+echo $ECHO_N "checking for $ac_func... $ECHO_C" >&6 -+if eval "test \"\${$as_ac_var+set}\" = set"; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+/* Define $ac_func to an innocuous variant, in case declares $ac_func. -+ For example, HP-UX 11i declares gettimeofday. */ -+#define $ac_func innocuous_$ac_func -+ -+/* System header to define __stub macros and hopefully few prototypes, -+ which can conflict with char $ac_func (); below. -+ Prefer to if __STDC__ is defined, since -+ exists even on freestanding compilers. */ -+ -+#ifdef __STDC__ -+# include -+#else -+# include -+#endif -+ -+#undef $ac_func -+ -+/* Override any gcc2 internal prototype to avoid an error. */ -+#ifdef __cplusplus -+extern "C" -+{ -+#endif -+/* We use char because int might match the return type of a gcc2 -+ builtin and then its argument prototype would still apply. */ -+char $ac_func (); -+/* The GNU C library defines this for functions which it implements -+ to always fail with ENOSYS. Some functions are actually named -+ something starting with __ and the normal name is an alias. */ -+#if defined (__stub_$ac_func) || defined (__stub___$ac_func) -+choke me -+#else -+char (*f) () = $ac_func; -+#endif -+#ifdef __cplusplus -+} -+#endif -+ -+int -+main () -+{ -+return f != $ac_func; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext conftest$ac_exeext -+if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 -+ (eval $ac_link) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest$ac_exeext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ eval "$as_ac_var=yes" -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+eval "$as_ac_var=no" -+fi -+rm -f conftest.err conftest.$ac_objext \ -+ conftest$ac_exeext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_var'}'`" >&5 -+echo "${ECHO_T}`eval echo '${'$as_ac_var'}'`" >&6 -+if test `eval echo '${'$as_ac_var'}'` = yes; then -+ cat >>confdefs.h <<_ACEOF -+#define `echo "HAVE_$ac_func" | $as_tr_cpp` 1 -+_ACEOF -+ haveepoll=yes -+fi -+done -+ -+if test "x$haveepoll" = "xyes" ; then -+ -+cat >>confdefs.h <<\_ACEOF -+#define HAVE_EPOLL 1 -+_ACEOF -+ -+ case $LIBOBJS in -+ "epoll.$ac_objext" | \ -+ *" epoll.$ac_objext" | \ -+ "epoll.$ac_objext "* | \ -+ *" epoll.$ac_objext "* ) ;; -+ *) LIBOBJS="$LIBOBJS epoll.$ac_objext" ;; -+esac -+ -+ needsignal=yes -+fi -+ -+havedevpoll=no -+if test "x$ac_cv_header_sys_devpoll_h" = "xyes"; then -+ -+cat >>confdefs.h <<\_ACEOF -+#define HAVE_DEVPOLL 1 -+_ACEOF -+ -+ case $LIBOBJS in -+ "devpoll.$ac_objext" | \ -+ *" devpoll.$ac_objext" | \ -+ "devpoll.$ac_objext "* | \ -+ *" devpoll.$ac_objext "* ) ;; -+ *) LIBOBJS="$LIBOBJS devpoll.$ac_objext" ;; -+esac -+ -+fi -+ -+havekqueue=no -+if test "x$ac_cv_header_sys_event_h" = "xyes"; then -+ -+for ac_func in kqueue -+do -+as_ac_var=`echo "ac_cv_func_$ac_func" | $as_tr_sh` -+echo "$as_me:$LINENO: checking for $ac_func" >&5 -+echo $ECHO_N "checking for $ac_func... $ECHO_C" >&6 -+if eval "test \"\${$as_ac_var+set}\" = set"; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+/* Define $ac_func to an innocuous variant, in case declares $ac_func. -+ For example, HP-UX 11i declares gettimeofday. */ -+#define $ac_func innocuous_$ac_func -+ -+/* System header to define __stub macros and hopefully few prototypes, -+ which can conflict with char $ac_func (); below. -+ Prefer to if __STDC__ is defined, since -+ exists even on freestanding compilers. */ -+ -+#ifdef __STDC__ -+# include -+#else -+# include -+#endif -+ -+#undef $ac_func -+ -+/* Override any gcc2 internal prototype to avoid an error. */ -+#ifdef __cplusplus -+extern "C" -+{ -+#endif -+/* We use char because int might match the return type of a gcc2 -+ builtin and then its argument prototype would still apply. */ -+char $ac_func (); -+/* The GNU C library defines this for functions which it implements -+ to always fail with ENOSYS. Some functions are actually named -+ something starting with __ and the normal name is an alias. */ -+#if defined (__stub_$ac_func) || defined (__stub___$ac_func) -+choke me -+#else -+char (*f) () = $ac_func; -+#endif -+#ifdef __cplusplus -+} -+#endif -+ -+int -+main () -+{ -+return f != $ac_func; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext conftest$ac_exeext -+if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 -+ (eval $ac_link) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest$ac_exeext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ eval "$as_ac_var=yes" -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+eval "$as_ac_var=no" -+fi -+rm -f conftest.err conftest.$ac_objext \ -+ conftest$ac_exeext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_var'}'`" >&5 -+echo "${ECHO_T}`eval echo '${'$as_ac_var'}'`" >&6 -+if test `eval echo '${'$as_ac_var'}'` = yes; then -+ cat >>confdefs.h <<_ACEOF -+#define `echo "HAVE_$ac_func" | $as_tr_cpp` 1 -+_ACEOF -+ havekqueue=yes -+fi -+done -+ -+ if test "x$havekqueue" = "xyes" ; then -+ echo "$as_me:$LINENO: checking for working kqueue" >&5 -+echo $ECHO_N "checking for working kqueue... $ECHO_C" >&6 -+ if test "$cross_compiling" = yes; then -+ echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+#include -+#include -+#include -+#include -+#include -+#include -+ -+int -+main(int argc, char **argv) -+{ -+ int kq; -+ int n; -+ int fd[2]; -+ struct kevent ev; -+ struct timespec ts; -+ char buf[8000]; -+ -+ if (pipe(fd) == -1) -+ exit(1); -+ if (fcntl(fd[1], F_SETFL, O_NONBLOCK) == -1) -+ exit(1); -+ -+ while ((n = write(fd[1], buf, sizeof(buf))) == sizeof(buf)) -+ ; -+ -+ if ((kq = kqueue()) == -1) -+ exit(1); -+ -+ ev.ident = fd[1]; -+ ev.filter = EVFILT_WRITE; -+ ev.flags = EV_ADD | EV_ENABLE; -+ n = kevent(kq, &ev, 1, NULL, 0, NULL); -+ if (n == -1) -+ exit(1); -+ -+ read(fd[0], buf, sizeof(buf)); -+ -+ ts.tv_sec = 0; -+ ts.tv_nsec = 0; -+ n = kevent(kq, NULL, 0, &ev, 1, &ts); -+ if (n == -1 || n == 0) -+ exit(1); -+ -+ exit(0); -+} -+_ACEOF -+rm -f conftest$ac_exeext -+if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 -+ (eval $ac_link) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && { ac_try='./conftest$ac_exeext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ echo "$as_me:$LINENO: result: yes" >&5 -+echo "${ECHO_T}yes" >&6 -+ -+cat >>confdefs.h <<\_ACEOF -+#define HAVE_WORKING_KQUEUE 1 -+_ACEOF -+ -+ case $LIBOBJS in -+ "kqueue.$ac_objext" | \ -+ *" kqueue.$ac_objext" | \ -+ "kqueue.$ac_objext "* | \ -+ *" kqueue.$ac_objext "* ) ;; -+ *) LIBOBJS="$LIBOBJS kqueue.$ac_objext" ;; -+esac -+ -+else -+ echo "$as_me: program exited with status $ac_status" >&5 -+echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+( exit $ac_status ) -+echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+fi -+rm -f core *.core gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext -+fi -+ fi -+fi -+ -+haveepollsyscall=no -+if test "x$ac_cv_header_sys_epoll_h" = "xyes"; then -+ if test "x$haveepoll" = "xno" ; then -+ echo "$as_me:$LINENO: checking for epoll system call" >&5 -+echo $ECHO_N "checking for epoll system call... $ECHO_C" >&6 -+ if test "$cross_compiling" = yes; then -+ echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+#include -+#include -+#include -+#include -+#include -+#include -+ -+int -+epoll_create(int size) -+{ -+ return (syscall(__NR_epoll_create, size)); -+} -+ -+int -+main(int argc, char **argv) -+{ -+ int epfd; -+ -+ epfd = epoll_create(256); -+ exit (epfd == -1 ? 1 : 0); -+} -+_ACEOF -+rm -f conftest$ac_exeext -+if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 -+ (eval $ac_link) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && { ac_try='./conftest$ac_exeext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ echo "$as_me:$LINENO: result: yes" >&5 -+echo "${ECHO_T}yes" >&6 -+ -+cat >>confdefs.h <<\_ACEOF -+#define HAVE_EPOLL 1 -+_ACEOF -+ -+ needsignal=yes -+ case $LIBOBJS in -+ "epoll_sub.$ac_objext" | \ -+ *" epoll_sub.$ac_objext" | \ -+ "epoll_sub.$ac_objext "* | \ -+ *" epoll_sub.$ac_objext "* ) ;; -+ *) LIBOBJS="$LIBOBJS epoll_sub.$ac_objext" ;; -+esac -+ -+ case $LIBOBJS in -+ "epoll.$ac_objext" | \ -+ *" epoll.$ac_objext" | \ -+ "epoll.$ac_objext "* | \ -+ *" epoll.$ac_objext "* ) ;; -+ *) LIBOBJS="$LIBOBJS epoll.$ac_objext" ;; -+esac -+ -+else -+ echo "$as_me: program exited with status $ac_status" >&5 -+echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+( exit $ac_status ) -+echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+fi -+rm -f core *.core gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext -+fi -+ fi -+fi -+ -+haveeventports=no -+ -+for ac_func in port_create -+do -+as_ac_var=`echo "ac_cv_func_$ac_func" | $as_tr_sh` -+echo "$as_me:$LINENO: checking for $ac_func" >&5 -+echo $ECHO_N "checking for $ac_func... $ECHO_C" >&6 -+if eval "test \"\${$as_ac_var+set}\" = set"; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+/* Define $ac_func to an innocuous variant, in case declares $ac_func. -+ For example, HP-UX 11i declares gettimeofday. */ -+#define $ac_func innocuous_$ac_func -+ -+/* System header to define __stub macros and hopefully few prototypes, -+ which can conflict with char $ac_func (); below. -+ Prefer to if __STDC__ is defined, since -+ exists even on freestanding compilers. */ -+ -+#ifdef __STDC__ -+# include -+#else -+# include -+#endif -+ -+#undef $ac_func -+ -+/* Override any gcc2 internal prototype to avoid an error. */ -+#ifdef __cplusplus -+extern "C" -+{ -+#endif -+/* We use char because int might match the return type of a gcc2 -+ builtin and then its argument prototype would still apply. */ -+char $ac_func (); -+/* The GNU C library defines this for functions which it implements -+ to always fail with ENOSYS. Some functions are actually named -+ something starting with __ and the normal name is an alias. */ -+#if defined (__stub_$ac_func) || defined (__stub___$ac_func) -+choke me -+#else -+char (*f) () = $ac_func; -+#endif -+#ifdef __cplusplus -+} -+#endif -+ -+int -+main () -+{ -+return f != $ac_func; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext conftest$ac_exeext -+if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 -+ (eval $ac_link) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest$ac_exeext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ eval "$as_ac_var=yes" -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+eval "$as_ac_var=no" -+fi -+rm -f conftest.err conftest.$ac_objext \ -+ conftest$ac_exeext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: `eval echo '${'$as_ac_var'}'`" >&5 -+echo "${ECHO_T}`eval echo '${'$as_ac_var'}'`" >&6 -+if test `eval echo '${'$as_ac_var'}'` = yes; then -+ cat >>confdefs.h <<_ACEOF -+#define `echo "HAVE_$ac_func" | $as_tr_cpp` 1 -+_ACEOF -+ haveeventports=yes -+fi -+done -+ -+if test "x$haveeventports" = "xyes" ; then -+ -+cat >>confdefs.h <<\_ACEOF -+#define HAVE_EVENT_PORTS 1 -+_ACEOF -+ -+ case $LIBOBJS in -+ "evport.$ac_objext" | \ -+ *" evport.$ac_objext" | \ -+ "evport.$ac_objext "* | \ -+ *" evport.$ac_objext "* ) ;; -+ *) LIBOBJS="$LIBOBJS evport.$ac_objext" ;; -+esac -+ -+ needsignal=yes -+fi -+if test "x$bwin32" = "xtrue"; then -+ needsignal=yes -+fi -+if test "x$bwin32" = "xtrue"; then -+ needsignal=yes -+fi -+if test "x$needsignal" = "xyes" ; then -+ case $LIBOBJS in -+ "signal.$ac_objext" | \ -+ *" signal.$ac_objext" | \ -+ "signal.$ac_objext "* | \ -+ *" signal.$ac_objext "* ) ;; -+ *) LIBOBJS="$LIBOBJS signal.$ac_objext" ;; -+esac -+ -+fi -+ -+echo "$as_me:$LINENO: checking for pid_t" >&5 -+echo $ECHO_N "checking for pid_t... $ECHO_C" >&6 -+if test "${ac_cv_type_pid_t+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+if ((pid_t *) 0) -+ return 0; -+if (sizeof (pid_t)) -+ return 0; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_type_pid_t=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_cv_type_pid_t=no -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: $ac_cv_type_pid_t" >&5 -+echo "${ECHO_T}$ac_cv_type_pid_t" >&6 -+if test $ac_cv_type_pid_t = yes; then -+ : -+else -+ -+cat >>confdefs.h <<_ACEOF -+#define pid_t int -+_ACEOF -+ -+fi -+ -+echo "$as_me:$LINENO: checking for size_t" >&5 -+echo $ECHO_N "checking for size_t... $ECHO_C" >&6 -+if test "${ac_cv_type_size_t+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+if ((size_t *) 0) -+ return 0; -+if (sizeof (size_t)) -+ return 0; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_type_size_t=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_cv_type_size_t=no -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: $ac_cv_type_size_t" >&5 -+echo "${ECHO_T}$ac_cv_type_size_t" >&6 -+if test $ac_cv_type_size_t = yes; then -+ : -+else -+ -+cat >>confdefs.h <<_ACEOF -+#define size_t unsigned -+_ACEOF -+ -+fi -+ -+echo "$as_me:$LINENO: checking for uint64_t" >&5 -+echo $ECHO_N "checking for uint64_t... $ECHO_C" >&6 -+if test "${ac_cv_type_uint64_t+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+#ifdef HAVE_STDINT_H -+#include -+#elif defined(HAVE_INTTYPES_H) -+#include -+#endif -+#ifdef HAVE_SYS_TYPES_H -+#include -+#endif -+ -+int -+main () -+{ -+if ((uint64_t *) 0) -+ return 0; -+if (sizeof (uint64_t)) -+ return 0; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_type_uint64_t=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_cv_type_uint64_t=no -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: $ac_cv_type_uint64_t" >&5 -+echo "${ECHO_T}$ac_cv_type_uint64_t" >&6 -+if test $ac_cv_type_uint64_t = yes; then -+ -+cat >>confdefs.h <<_ACEOF -+#define HAVE_UINT64_T 1 -+_ACEOF -+ -+ -+fi -+echo "$as_me:$LINENO: checking for uint32_t" >&5 -+echo $ECHO_N "checking for uint32_t... $ECHO_C" >&6 -+if test "${ac_cv_type_uint32_t+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+#ifdef HAVE_STDINT_H -+#include -+#elif defined(HAVE_INTTYPES_H) -+#include -+#endif -+#ifdef HAVE_SYS_TYPES_H -+#include -+#endif -+ -+int -+main () -+{ -+if ((uint32_t *) 0) -+ return 0; -+if (sizeof (uint32_t)) -+ return 0; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_type_uint32_t=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_cv_type_uint32_t=no -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: $ac_cv_type_uint32_t" >&5 -+echo "${ECHO_T}$ac_cv_type_uint32_t" >&6 -+if test $ac_cv_type_uint32_t = yes; then -+ -+cat >>confdefs.h <<_ACEOF -+#define HAVE_UINT32_T 1 -+_ACEOF -+ -+ -+fi -+echo "$as_me:$LINENO: checking for uint16_t" >&5 -+echo $ECHO_N "checking for uint16_t... $ECHO_C" >&6 -+if test "${ac_cv_type_uint16_t+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+#ifdef HAVE_STDINT_H -+#include -+#elif defined(HAVE_INTTYPES_H) -+#include -+#endif -+#ifdef HAVE_SYS_TYPES_H -+#include -+#endif -+ -+int -+main () -+{ -+if ((uint16_t *) 0) -+ return 0; -+if (sizeof (uint16_t)) -+ return 0; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_type_uint16_t=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_cv_type_uint16_t=no -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: $ac_cv_type_uint16_t" >&5 -+echo "${ECHO_T}$ac_cv_type_uint16_t" >&6 -+if test $ac_cv_type_uint16_t = yes; then -+ -+cat >>confdefs.h <<_ACEOF -+#define HAVE_UINT16_T 1 -+_ACEOF -+ -+ -+fi -+echo "$as_me:$LINENO: checking for uint8_t" >&5 -+echo $ECHO_N "checking for uint8_t... $ECHO_C" >&6 -+if test "${ac_cv_type_uint8_t+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+#ifdef HAVE_STDINT_H -+#include -+#elif defined(HAVE_INTTYPES_H) -+#include -+#endif -+#ifdef HAVE_SYS_TYPES_H -+#include -+#endif -+ -+int -+main () -+{ -+if ((uint8_t *) 0) -+ return 0; -+if (sizeof (uint8_t)) -+ return 0; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_type_uint8_t=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_cv_type_uint8_t=no -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: $ac_cv_type_uint8_t" >&5 -+echo "${ECHO_T}$ac_cv_type_uint8_t" >&6 -+if test $ac_cv_type_uint8_t = yes; then -+ -+cat >>confdefs.h <<_ACEOF -+#define HAVE_UINT8_T 1 -+_ACEOF -+ -+ -+fi -+ -+echo "$as_me:$LINENO: checking for long long" >&5 -+echo $ECHO_N "checking for long long... $ECHO_C" >&6 -+if test "${ac_cv_type_long_long+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+if ((long long *) 0) -+ return 0; -+if (sizeof (long long)) -+ return 0; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_type_long_long=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_cv_type_long_long=no -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: $ac_cv_type_long_long" >&5 -+echo "${ECHO_T}$ac_cv_type_long_long" >&6 -+ -+echo "$as_me:$LINENO: checking size of long long" >&5 -+echo $ECHO_N "checking size of long long... $ECHO_C" >&6 -+if test "${ac_cv_sizeof_long_long+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ if test "$ac_cv_type_long_long" = yes; then -+ # The cast to unsigned long works around a bug in the HP C Compiler -+ # version HP92453-01 B.11.11.23709.GP, which incorrectly rejects -+ # declarations like `int a3[[(sizeof (unsigned char)) >= 0]];'. -+ # This bug is HP SR number 8606223364. -+ if test "$cross_compiling" = yes; then -+ # Depending upon the size, compute the lo and hi bounds. -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (long long))) >= 0)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_lo=0 ac_mid=0 -+ while :; do -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (long long))) <= $ac_mid)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_hi=$ac_mid; break -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_lo=`expr $ac_mid + 1` -+ if test $ac_lo -le $ac_mid; then -+ ac_lo= ac_hi= -+ break -+ fi -+ ac_mid=`expr 2 '*' $ac_mid + 1` -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+ done -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (long long))) < 0)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_hi=-1 ac_mid=-1 -+ while :; do -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (long long))) >= $ac_mid)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_lo=$ac_mid; break -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_hi=`expr '(' $ac_mid ')' - 1` -+ if test $ac_mid -le $ac_hi; then -+ ac_lo= ac_hi= -+ break -+ fi -+ ac_mid=`expr 2 '*' $ac_mid` -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+ done -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_lo= ac_hi= -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+# Binary search between lo and hi bounds. -+while test "x$ac_lo" != "x$ac_hi"; do -+ ac_mid=`expr '(' $ac_hi - $ac_lo ')' / 2 + $ac_lo` -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (long long))) <= $ac_mid)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_hi=$ac_mid -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_lo=`expr '(' $ac_mid ')' + 1` -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+done -+case $ac_lo in -+?*) ac_cv_sizeof_long_long=$ac_lo;; -+'') { { echo "$as_me:$LINENO: error: cannot compute sizeof (long long), 77 -+See \`config.log' for more details." >&5 -+echo "$as_me: error: cannot compute sizeof (long long), 77 -+See \`config.log' for more details." >&2;} -+ { (exit 1); exit 1; }; } ;; -+esac -+else -+ if test "$cross_compiling" = yes; then -+ { { echo "$as_me:$LINENO: error: cannot run test program while cross compiling -+See \`config.log' for more details." >&5 -+echo "$as_me: error: cannot run test program while cross compiling -+See \`config.log' for more details." >&2;} -+ { (exit 1); exit 1; }; } -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+long longval () { return (long) (sizeof (long long)); } -+unsigned long ulongval () { return (long) (sizeof (long long)); } -+#include -+#include -+int -+main () -+{ -+ -+ FILE *f = fopen ("conftest.val", "w"); -+ if (! f) -+ exit (1); -+ if (((long) (sizeof (long long))) < 0) -+ { -+ long i = longval (); -+ if (i != ((long) (sizeof (long long)))) -+ exit (1); -+ fprintf (f, "%ld\n", i); -+ } -+ else -+ { -+ unsigned long i = ulongval (); -+ if (i != ((long) (sizeof (long long)))) -+ exit (1); -+ fprintf (f, "%lu\n", i); -+ } -+ exit (ferror (f) || fclose (f) != 0); -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest$ac_exeext -+if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 -+ (eval $ac_link) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && { ac_try='./conftest$ac_exeext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_sizeof_long_long=`cat conftest.val` -+else -+ echo "$as_me: program exited with status $ac_status" >&5 -+echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+( exit $ac_status ) -+{ { echo "$as_me:$LINENO: error: cannot compute sizeof (long long), 77 -+See \`config.log' for more details." >&5 -+echo "$as_me: error: cannot compute sizeof (long long), 77 -+See \`config.log' for more details." >&2;} -+ { (exit 1); exit 1; }; } -+fi -+rm -f core *.core gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext -+fi -+fi -+rm -f conftest.val -+else -+ ac_cv_sizeof_long_long=0 -+fi -+fi -+echo "$as_me:$LINENO: result: $ac_cv_sizeof_long_long" >&5 -+echo "${ECHO_T}$ac_cv_sizeof_long_long" >&6 -+cat >>confdefs.h <<_ACEOF -+#define SIZEOF_LONG_LONG $ac_cv_sizeof_long_long -+_ACEOF -+ -+ -+echo "$as_me:$LINENO: checking for long" >&5 -+echo $ECHO_N "checking for long... $ECHO_C" >&6 -+if test "${ac_cv_type_long+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+if ((long *) 0) -+ return 0; -+if (sizeof (long)) -+ return 0; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_type_long=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_cv_type_long=no -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: $ac_cv_type_long" >&5 -+echo "${ECHO_T}$ac_cv_type_long" >&6 -+ -+echo "$as_me:$LINENO: checking size of long" >&5 -+echo $ECHO_N "checking size of long... $ECHO_C" >&6 -+if test "${ac_cv_sizeof_long+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ if test "$ac_cv_type_long" = yes; then -+ # The cast to unsigned long works around a bug in the HP C Compiler -+ # version HP92453-01 B.11.11.23709.GP, which incorrectly rejects -+ # declarations like `int a3[[(sizeof (unsigned char)) >= 0]];'. -+ # This bug is HP SR number 8606223364. -+ if test "$cross_compiling" = yes; then -+ # Depending upon the size, compute the lo and hi bounds. -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (long))) >= 0)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_lo=0 ac_mid=0 -+ while :; do -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (long))) <= $ac_mid)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_hi=$ac_mid; break -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_lo=`expr $ac_mid + 1` -+ if test $ac_lo -le $ac_mid; then -+ ac_lo= ac_hi= -+ break -+ fi -+ ac_mid=`expr 2 '*' $ac_mid + 1` -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+ done -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (long))) < 0)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_hi=-1 ac_mid=-1 -+ while :; do -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (long))) >= $ac_mid)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_lo=$ac_mid; break -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_hi=`expr '(' $ac_mid ')' - 1` -+ if test $ac_mid -le $ac_hi; then -+ ac_lo= ac_hi= -+ break -+ fi -+ ac_mid=`expr 2 '*' $ac_mid` -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+ done -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_lo= ac_hi= -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+# Binary search between lo and hi bounds. -+while test "x$ac_lo" != "x$ac_hi"; do -+ ac_mid=`expr '(' $ac_hi - $ac_lo ')' / 2 + $ac_lo` -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (long))) <= $ac_mid)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_hi=$ac_mid -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_lo=`expr '(' $ac_mid ')' + 1` -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+done -+case $ac_lo in -+?*) ac_cv_sizeof_long=$ac_lo;; -+'') { { echo "$as_me:$LINENO: error: cannot compute sizeof (long), 77 -+See \`config.log' for more details." >&5 -+echo "$as_me: error: cannot compute sizeof (long), 77 -+See \`config.log' for more details." >&2;} -+ { (exit 1); exit 1; }; } ;; -+esac -+else -+ if test "$cross_compiling" = yes; then -+ { { echo "$as_me:$LINENO: error: cannot run test program while cross compiling -+See \`config.log' for more details." >&5 -+echo "$as_me: error: cannot run test program while cross compiling -+See \`config.log' for more details." >&2;} -+ { (exit 1); exit 1; }; } -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+long longval () { return (long) (sizeof (long)); } -+unsigned long ulongval () { return (long) (sizeof (long)); } -+#include -+#include -+int -+main () -+{ -+ -+ FILE *f = fopen ("conftest.val", "w"); -+ if (! f) -+ exit (1); -+ if (((long) (sizeof (long))) < 0) -+ { -+ long i = longval (); -+ if (i != ((long) (sizeof (long)))) -+ exit (1); -+ fprintf (f, "%ld\n", i); -+ } -+ else -+ { -+ unsigned long i = ulongval (); -+ if (i != ((long) (sizeof (long)))) -+ exit (1); -+ fprintf (f, "%lu\n", i); -+ } -+ exit (ferror (f) || fclose (f) != 0); -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest$ac_exeext -+if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 -+ (eval $ac_link) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && { ac_try='./conftest$ac_exeext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_sizeof_long=`cat conftest.val` -+else -+ echo "$as_me: program exited with status $ac_status" >&5 -+echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+( exit $ac_status ) -+{ { echo "$as_me:$LINENO: error: cannot compute sizeof (long), 77 -+See \`config.log' for more details." >&5 -+echo "$as_me: error: cannot compute sizeof (long), 77 -+See \`config.log' for more details." >&2;} -+ { (exit 1); exit 1; }; } -+fi -+rm -f core *.core gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext -+fi -+fi -+rm -f conftest.val -+else -+ ac_cv_sizeof_long=0 -+fi -+fi -+echo "$as_me:$LINENO: result: $ac_cv_sizeof_long" >&5 -+echo "${ECHO_T}$ac_cv_sizeof_long" >&6 -+cat >>confdefs.h <<_ACEOF -+#define SIZEOF_LONG $ac_cv_sizeof_long -+_ACEOF -+ -+ -+echo "$as_me:$LINENO: checking for int" >&5 -+echo $ECHO_N "checking for int... $ECHO_C" >&6 -+if test "${ac_cv_type_int+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+if ((int *) 0) -+ return 0; -+if (sizeof (int)) -+ return 0; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_type_int=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_cv_type_int=no -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: $ac_cv_type_int" >&5 -+echo "${ECHO_T}$ac_cv_type_int" >&6 -+ -+echo "$as_me:$LINENO: checking size of int" >&5 -+echo $ECHO_N "checking size of int... $ECHO_C" >&6 -+if test "${ac_cv_sizeof_int+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ if test "$ac_cv_type_int" = yes; then -+ # The cast to unsigned long works around a bug in the HP C Compiler -+ # version HP92453-01 B.11.11.23709.GP, which incorrectly rejects -+ # declarations like `int a3[[(sizeof (unsigned char)) >= 0]];'. -+ # This bug is HP SR number 8606223364. -+ if test "$cross_compiling" = yes; then -+ # Depending upon the size, compute the lo and hi bounds. -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (int))) >= 0)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_lo=0 ac_mid=0 -+ while :; do -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (int))) <= $ac_mid)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_hi=$ac_mid; break -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_lo=`expr $ac_mid + 1` -+ if test $ac_lo -le $ac_mid; then -+ ac_lo= ac_hi= -+ break -+ fi -+ ac_mid=`expr 2 '*' $ac_mid + 1` -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+ done -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (int))) < 0)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_hi=-1 ac_mid=-1 -+ while :; do -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (int))) >= $ac_mid)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_lo=$ac_mid; break -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_hi=`expr '(' $ac_mid ')' - 1` -+ if test $ac_mid -le $ac_hi; then -+ ac_lo= ac_hi= -+ break -+ fi -+ ac_mid=`expr 2 '*' $ac_mid` -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+ done -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_lo= ac_hi= -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+# Binary search between lo and hi bounds. -+while test "x$ac_lo" != "x$ac_hi"; do -+ ac_mid=`expr '(' $ac_hi - $ac_lo ')' / 2 + $ac_lo` -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (int))) <= $ac_mid)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_hi=$ac_mid -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_lo=`expr '(' $ac_mid ')' + 1` -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+done -+case $ac_lo in -+?*) ac_cv_sizeof_int=$ac_lo;; -+'') { { echo "$as_me:$LINENO: error: cannot compute sizeof (int), 77 -+See \`config.log' for more details." >&5 -+echo "$as_me: error: cannot compute sizeof (int), 77 -+See \`config.log' for more details." >&2;} -+ { (exit 1); exit 1; }; } ;; -+esac -+else -+ if test "$cross_compiling" = yes; then -+ { { echo "$as_me:$LINENO: error: cannot run test program while cross compiling -+See \`config.log' for more details." >&5 -+echo "$as_me: error: cannot run test program while cross compiling -+See \`config.log' for more details." >&2;} -+ { (exit 1); exit 1; }; } -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+long longval () { return (long) (sizeof (int)); } -+unsigned long ulongval () { return (long) (sizeof (int)); } -+#include -+#include -+int -+main () -+{ -+ -+ FILE *f = fopen ("conftest.val", "w"); -+ if (! f) -+ exit (1); -+ if (((long) (sizeof (int))) < 0) -+ { -+ long i = longval (); -+ if (i != ((long) (sizeof (int)))) -+ exit (1); -+ fprintf (f, "%ld\n", i); -+ } -+ else -+ { -+ unsigned long i = ulongval (); -+ if (i != ((long) (sizeof (int)))) -+ exit (1); -+ fprintf (f, "%lu\n", i); -+ } -+ exit (ferror (f) || fclose (f) != 0); -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest$ac_exeext -+if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 -+ (eval $ac_link) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && { ac_try='./conftest$ac_exeext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_sizeof_int=`cat conftest.val` -+else -+ echo "$as_me: program exited with status $ac_status" >&5 -+echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+( exit $ac_status ) -+{ { echo "$as_me:$LINENO: error: cannot compute sizeof (int), 77 -+See \`config.log' for more details." >&5 -+echo "$as_me: error: cannot compute sizeof (int), 77 -+See \`config.log' for more details." >&2;} -+ { (exit 1); exit 1; }; } -+fi -+rm -f core *.core gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext -+fi -+fi -+rm -f conftest.val -+else -+ ac_cv_sizeof_int=0 -+fi -+fi -+echo "$as_me:$LINENO: result: $ac_cv_sizeof_int" >&5 -+echo "${ECHO_T}$ac_cv_sizeof_int" >&6 -+cat >>confdefs.h <<_ACEOF -+#define SIZEOF_INT $ac_cv_sizeof_int -+_ACEOF -+ -+ -+echo "$as_me:$LINENO: checking for short" >&5 -+echo $ECHO_N "checking for short... $ECHO_C" >&6 -+if test "${ac_cv_type_short+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+if ((short *) 0) -+ return 0; -+if (sizeof (short)) -+ return 0; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_type_short=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_cv_type_short=no -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: $ac_cv_type_short" >&5 -+echo "${ECHO_T}$ac_cv_type_short" >&6 -+ -+echo "$as_me:$LINENO: checking size of short" >&5 -+echo $ECHO_N "checking size of short... $ECHO_C" >&6 -+if test "${ac_cv_sizeof_short+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ if test "$ac_cv_type_short" = yes; then -+ # The cast to unsigned long works around a bug in the HP C Compiler -+ # version HP92453-01 B.11.11.23709.GP, which incorrectly rejects -+ # declarations like `int a3[[(sizeof (unsigned char)) >= 0]];'. -+ # This bug is HP SR number 8606223364. -+ if test "$cross_compiling" = yes; then -+ # Depending upon the size, compute the lo and hi bounds. -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (short))) >= 0)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_lo=0 ac_mid=0 -+ while :; do -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (short))) <= $ac_mid)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_hi=$ac_mid; break -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_lo=`expr $ac_mid + 1` -+ if test $ac_lo -le $ac_mid; then -+ ac_lo= ac_hi= -+ break -+ fi -+ ac_mid=`expr 2 '*' $ac_mid + 1` -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+ done -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (short))) < 0)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_hi=-1 ac_mid=-1 -+ while :; do -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (short))) >= $ac_mid)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_lo=$ac_mid; break -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_hi=`expr '(' $ac_mid ')' - 1` -+ if test $ac_mid -le $ac_hi; then -+ ac_lo= ac_hi= -+ break -+ fi -+ ac_mid=`expr 2 '*' $ac_mid` -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+ done -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_lo= ac_hi= -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+# Binary search between lo and hi bounds. -+while test "x$ac_lo" != "x$ac_hi"; do -+ ac_mid=`expr '(' $ac_hi - $ac_lo ')' / 2 + $ac_lo` -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+int -+main () -+{ -+static int test_array [1 - 2 * !(((long) (sizeof (short))) <= $ac_mid)]; -+test_array [0] = 0 -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_hi=$ac_mid -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_lo=`expr '(' $ac_mid ')' + 1` -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+done -+case $ac_lo in -+?*) ac_cv_sizeof_short=$ac_lo;; -+'') { { echo "$as_me:$LINENO: error: cannot compute sizeof (short), 77 -+See \`config.log' for more details." >&5 -+echo "$as_me: error: cannot compute sizeof (short), 77 -+See \`config.log' for more details." >&2;} -+ { (exit 1); exit 1; }; } ;; -+esac -+else -+ if test "$cross_compiling" = yes; then -+ { { echo "$as_me:$LINENO: error: cannot run test program while cross compiling -+See \`config.log' for more details." >&5 -+echo "$as_me: error: cannot run test program while cross compiling -+See \`config.log' for more details." >&2;} -+ { (exit 1); exit 1; }; } -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+$ac_includes_default -+long longval () { return (long) (sizeof (short)); } -+unsigned long ulongval () { return (long) (sizeof (short)); } -+#include -+#include -+int -+main () -+{ -+ -+ FILE *f = fopen ("conftest.val", "w"); -+ if (! f) -+ exit (1); -+ if (((long) (sizeof (short))) < 0) -+ { -+ long i = longval (); -+ if (i != ((long) (sizeof (short)))) -+ exit (1); -+ fprintf (f, "%ld\n", i); -+ } -+ else -+ { -+ unsigned long i = ulongval (); -+ if (i != ((long) (sizeof (short)))) -+ exit (1); -+ fprintf (f, "%lu\n", i); -+ } -+ exit (ferror (f) || fclose (f) != 0); -+ -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest$ac_exeext -+if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5 -+ (eval $ac_link) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && { ac_try='./conftest$ac_exeext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_sizeof_short=`cat conftest.val` -+else -+ echo "$as_me: program exited with status $ac_status" >&5 -+echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+( exit $ac_status ) -+{ { echo "$as_me:$LINENO: error: cannot compute sizeof (short), 77 -+See \`config.log' for more details." >&5 -+echo "$as_me: error: cannot compute sizeof (short), 77 -+See \`config.log' for more details." >&2;} -+ { (exit 1); exit 1; }; } -+fi -+rm -f core *.core gmon.out bb.out conftest$ac_exeext conftest.$ac_objext conftest.$ac_ext -+fi -+fi -+rm -f conftest.val -+else -+ ac_cv_sizeof_short=0 -+fi -+fi -+echo "$as_me:$LINENO: result: $ac_cv_sizeof_short" >&5 -+echo "${ECHO_T}$ac_cv_sizeof_short" >&6 -+cat >>confdefs.h <<_ACEOF -+#define SIZEOF_SHORT $ac_cv_sizeof_short -+_ACEOF -+ -+ -+echo "$as_me:$LINENO: checking for struct in6_addr" >&5 -+echo $ECHO_N "checking for struct in6_addr... $ECHO_C" >&6 -+if test "${ac_cv_type_struct_in6_addr+set}" = set; then -+ echo $ECHO_N "(cached) $ECHO_C" >&6 -+else -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+#ifdef WIN32 -+#include -+#else -+#include -+#include -+#include -+#endif -+#ifdef HAVE_NETINET_IN6_H -+#include -+#endif -+ -+int -+main () -+{ -+if ((struct in6_addr *) 0) -+ return 0; -+if (sizeof (struct in6_addr)) -+ return 0; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ ac_cv_type_struct_in6_addr=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+ac_cv_type_struct_in6_addr=no -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+echo "$as_me:$LINENO: result: $ac_cv_type_struct_in6_addr" >&5 -+echo "${ECHO_T}$ac_cv_type_struct_in6_addr" >&6 -+if test $ac_cv_type_struct_in6_addr = yes; then -+ -+cat >>confdefs.h <<_ACEOF -+#define HAVE_STRUCT_IN6_ADDR 1 -+_ACEOF -+ -+ -+fi -+ -+ -+echo "$as_me:$LINENO: checking for socklen_t" >&5 -+echo $ECHO_N "checking for socklen_t... $ECHO_C" >&6 -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+ #include -+ #include -+int -+main () -+{ -+socklen_t x; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ echo "$as_me:$LINENO: result: yes" >&5 -+echo "${ECHO_T}yes" >&6 -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+ -+cat >>confdefs.h <<\_ACEOF -+#define socklen_t unsigned int -+_ACEOF -+ -+ -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+ -+echo "$as_me:$LINENO: checking whether our compiler supports __func__" >&5 -+echo $ECHO_N "checking whether our compiler supports __func__... $ECHO_C" >&6 -+cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+int -+main () -+{ -+ const char *cp = __func__; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ echo "$as_me:$LINENO: result: yes" >&5 -+echo "${ECHO_T}yes" >&6 -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+ echo "$as_me:$LINENO: checking whether our compiler supports __FUNCTION__" >&5 -+echo $ECHO_N "checking whether our compiler supports __FUNCTION__... $ECHO_C" >&6 -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+int -+main () -+{ -+ const char *cp = __FUNCTION__; -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ echo "$as_me:$LINENO: result: yes" >&5 -+echo "${ECHO_T}yes" >&6 -+ -+cat >>confdefs.h <<\_ACEOF -+#define __func__ __FUNCTION__ -+_ACEOF -+ -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+echo "$as_me:$LINENO: result: no" >&5 -+echo "${ECHO_T}no" >&6 -+ -+cat >>confdefs.h <<\_ACEOF -+#define __func__ __FILE__ -+_ACEOF -+ -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+ -+ -+# Add some more warnings which we use in development but not in the -+# released versions. (Some relevant gcc versions can't handle these.) -+if test x$enable_gcc_warnings = xyes; then -+ -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+int -+main () -+{ -+ -+#if !defined(__GNUC__) || (__GNUC__ < 4) -+#error -+#endif -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ have_gcc4=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+have_gcc4=no -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+ -+ cat >conftest.$ac_ext <<_ACEOF -+/* confdefs.h. */ -+_ACEOF -+cat confdefs.h >>conftest.$ac_ext -+cat >>conftest.$ac_ext <<_ACEOF -+/* end confdefs.h. */ -+ -+int -+main () -+{ -+ -+#if !defined(__GNUC__) || (__GNUC__ < 4) || (__GNUC__ == 4 && __GNUC_MINOR__ < 2) -+#error -+#endif -+ ; -+ return 0; -+} -+_ACEOF -+rm -f conftest.$ac_objext -+if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5 -+ (eval $ac_compile) 2>conftest.er1 -+ ac_status=$? -+ grep -v '^ *+' conftest.er1 >conftest.err -+ rm -f conftest.er1 -+ cat conftest.err >&5 -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); } && -+ { ac_try='test -z "$ac_c_werror_flag" -+ || test ! -s conftest.err' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; } && -+ { ac_try='test -s conftest.$ac_objext' -+ { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5 -+ (eval $ac_try) 2>&5 -+ ac_status=$? -+ echo "$as_me:$LINENO: \$? = $ac_status" >&5 -+ (exit $ac_status); }; }; then -+ have_gcc42=yes -+else -+ echo "$as_me: failed program was:" >&5 -+sed 's/^/| /' conftest.$ac_ext >&5 -+ -+have_gcc42=no -+fi -+rm -f conftest.err conftest.$ac_objext conftest.$ac_ext -+ -+ CFLAGS="$CFLAGS -W -Wfloat-equal -Wundef -Wpointer-arith -Wstrict-prototypes -Wmissing-prototypes -Wwrite-strings -Wredundant-decls -Wchar-subscripts -Wcomment -Wformat=2 -Wwrite-strings -Wmissing-declarations -Wredundant-decls -Wnested-externs -Wbad-function-cast -Wswitch-enum -Werror" -+ CFLAGS="$CFLAGS -Wno-unused-parameter -Wno-sign-compare -Wstrict-aliasing" -+ -+ if test x$have_gcc4 = xyes ; then -+ # These warnings break gcc 3.3.5 and work on gcc 4.0.2 -+ CFLAGS="$CFLAGS -Winit-self -Wmissing-field-initializers -Wdeclaration-after-statement" -+ #CFLAGS="$CFLAGS -Wold-style-definition" -+ fi -+ -+ if test x$have_gcc42 = xyes ; then -+ # These warnings break gcc 4.0.2 and work on gcc 4.2 -+ CFLAGS="$CFLAGS -Waddress -Wnormalized=id -Woverride-init" -+ fi -+ -+##This will break the world on some 64-bit architectures -+# CFLAGS="$CFLAGS -Winline" -+ -+fi -+ -+ ac_config_files="$ac_config_files Makefile" -+cat >confcache <<\_ACEOF -+# This file is a shell script that caches the results of configure -+# tests run on this system so they can be shared between configure -+# scripts and configure runs, see configure's option --config-cache. -+# It is not useful on other systems. If it contains results you don't -+# want to keep, you may remove or edit it. -+# -+# config.status only pays attention to the cache file if you give it -+# the --recheck option to rerun configure. -+# -+# `ac_cv_env_foo' variables (set or unset) will be overridden when -+# loading this file, other *unset* `ac_cv_foo' will be assigned the -+# following values. -+ -+_ACEOF -+ -+# The following way of writing the cache mishandles newlines in values, -+# but we know of no workaround that is simple, portable, and efficient. -+# So, don't put newlines in cache variables' values. -+# Ultrix sh set writes to stderr and can't be redirected directly, -+# and sets the high bit in the cache file unless we assign to the vars. -+{ -+ (set) 2>&1 | -+ case `(ac_space=' '; set | grep ac_space) 2>&1` in -+ *ac_space=\ *) -+ # `set' does not quote correctly, so add quotes (double-quote -+ # substitution turns \\\\ into \\, and sed turns \\ into \). -+ sed -n \ -+ "s/'/'\\\\''/g; -+ s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\\2'/p" -+ ;; -+ *) -+ # `set' quotes correctly as required by POSIX, so do not add quotes. -+ sed -n \ -+ "s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1=\\2/p" -+ ;; -+ esac; -+} | -+ sed ' -+ t clear -+ : clear -+ s/^\([^=]*\)=\(.*[{}].*\)$/test "${\1+set}" = set || &/ -+ t end -+ /^ac_cv_env/!s/^\([^=]*\)=\(.*\)$/\1=${\1=\2}/ -+ : end' >>confcache -+if diff $cache_file confcache >/dev/null 2>&1; then :; else -+ if test -w $cache_file; then -+ test "x$cache_file" != "x/dev/null" && echo "updating cache $cache_file" -+ cat confcache >$cache_file -+ else -+ echo "not updating unwritable cache $cache_file" -+ fi -+fi -+rm -f confcache -+ -+test "x$prefix" = xNONE && prefix=$ac_default_prefix -+# Let make expand exec_prefix. -+test "x$exec_prefix" = xNONE && exec_prefix='${prefix}' -+ -+# VPATH may cause trouble with some makes, so we remove $(srcdir), -+# ${srcdir} and @srcdir@ from VPATH if srcdir is ".", strip leading and -+# trailing colons and then remove the whole line if VPATH becomes empty -+# (actually we leave an empty line to preserve line numbers). -+if test "x$srcdir" = x.; then -+ ac_vpsub='/^[ ]*VPATH[ ]*=/{ -+s/:*\$(srcdir):*/:/; -+s/:*\${srcdir}:*/:/; -+s/:*@srcdir@:*/:/; -+s/^\([^=]*=[ ]*\):*/\1/; -+s/:*$//; -+s/^[^=]*=[ ]*$//; -+}' -+fi -+ -+DEFS=-DHAVE_CONFIG_H -+ -+ac_libobjs= -+ac_ltlibobjs= -+for ac_i in : $LIBOBJS; do test "x$ac_i" = x: && continue -+ # 1. Remove the extension, and $U if already installed. -+ ac_i=`echo "$ac_i" | -+ sed 's/\$U\././;s/\.o$//;s/\.obj$//'` -+ # 2. Add them. -+ ac_libobjs="$ac_libobjs $ac_i\$U.$ac_objext" -+ ac_ltlibobjs="$ac_ltlibobjs $ac_i"'$U.lo' -+done -+LIBOBJS=$ac_libobjs -+ -+LTLIBOBJS=$ac_ltlibobjs -+ -+ -+if test -z "${AMDEP_TRUE}" && test -z "${AMDEP_FALSE}"; then -+ { { echo "$as_me:$LINENO: error: conditional \"AMDEP\" was never defined. -+Usually this means the macro was only invoked conditionally." >&5 -+echo "$as_me: error: conditional \"AMDEP\" was never defined. -+Usually this means the macro was only invoked conditionally." >&2;} -+ { (exit 1); exit 1; }; } -+fi -+if test -z "${am__fastdepCC_TRUE}" && test -z "${am__fastdepCC_FALSE}"; then -+ { { echo "$as_me:$LINENO: error: conditional \"am__fastdepCC\" was never defined. -+Usually this means the macro was only invoked conditionally." >&5 -+echo "$as_me: error: conditional \"am__fastdepCC\" was never defined. -+Usually this means the macro was only invoked conditionally." >&2;} -+ { (exit 1); exit 1; }; } -+fi -+if test -z "${BUILD_WIN32_TRUE}" && test -z "${BUILD_WIN32_FALSE}"; then -+ { { echo "$as_me:$LINENO: error: conditional \"BUILD_WIN32\" was never defined. -+Usually this means the macro was only invoked conditionally." >&5 -+echo "$as_me: error: conditional \"BUILD_WIN32\" was never defined. -+Usually this means the macro was only invoked conditionally." >&2;} -+ { (exit 1); exit 1; }; } -+fi -+ -+: ${CONFIG_STATUS=./config.status} -+ac_clean_files_save=$ac_clean_files -+ac_clean_files="$ac_clean_files $CONFIG_STATUS" -+{ echo "$as_me:$LINENO: creating $CONFIG_STATUS" >&5 -+echo "$as_me: creating $CONFIG_STATUS" >&6;} -+cat >$CONFIG_STATUS <<_ACEOF -+#! $SHELL -+# Generated by $as_me. -+# Run this file to recreate the current configuration. -+# Compiler output produced by configure, useful for debugging -+# configure, is in config.log if it exists. -+ -+debug=false -+ac_cs_recheck=false -+ac_cs_silent=false -+SHELL=\${CONFIG_SHELL-$SHELL} -+_ACEOF -+ -+cat >>$CONFIG_STATUS <<\_ACEOF -+## --------------------- ## -+## M4sh Initialization. ## -+## --------------------- ## -+ -+# Be Bourne compatible -+if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then -+ emulate sh -+ NULLCMD=: -+ # Zsh 3.x and 4.x performs word splitting on ${1+"$@"}, which -+ # is contrary to our usage. Disable this feature. -+ alias -g '${1+"$@"}'='"$@"' -+elif test -n "${BASH_VERSION+set}" && (set -o posix) >/dev/null 2>&1; then -+ set -o posix -+fi -+DUALCASE=1; export DUALCASE # for MKS sh -+ -+# Support unset when possible. -+if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then -+ as_unset=unset -+else -+ as_unset=false -+fi -+ -+ -+# Work around bugs in pre-3.0 UWIN ksh. -+$as_unset ENV MAIL MAILPATH -+PS1='$ ' -+PS2='> ' -+PS4='+ ' -+ -+# NLS nuisances. -+for as_var in \ -+ LANG LANGUAGE LC_ADDRESS LC_ALL LC_COLLATE LC_CTYPE LC_IDENTIFICATION \ -+ LC_MEASUREMENT LC_MESSAGES LC_MONETARY LC_NAME LC_NUMERIC LC_PAPER \ -+ LC_TELEPHONE LC_TIME -+do -+ if (set +x; test -z "`(eval $as_var=C; export $as_var) 2>&1`"); then -+ eval $as_var=C; export $as_var -+ else -+ $as_unset $as_var -+ fi -+done -+ -+# Required to use basename. -+if expr a : '\(a\)' >/dev/null 2>&1; then -+ as_expr=expr -+else -+ as_expr=false -+fi -+ -+if (basename /) >/dev/null 2>&1 && test "X`basename / 2>&1`" = "X/"; then -+ as_basename=basename -+else -+ as_basename=false -+fi -+ -+ -+# Name of the executable. -+as_me=`$as_basename "$0" || -+$as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ -+ X"$0" : 'X\(//\)$' \| \ -+ X"$0" : 'X\(/\)$' \| \ -+ . : '\(.\)' 2>/dev/null || -+echo X/"$0" | -+ sed '/^.*\/\([^/][^/]*\)\/*$/{ s//\1/; q; } -+ /^X\/\(\/\/\)$/{ s//\1/; q; } -+ /^X\/\(\/\).*/{ s//\1/; q; } -+ s/.*/./; q'` -+ -+ -+# PATH needs CR, and LINENO needs CR and PATH. -+# Avoid depending upon Character Ranges. -+as_cr_letters='abcdefghijklmnopqrstuvwxyz' -+as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' -+as_cr_Letters=$as_cr_letters$as_cr_LETTERS -+as_cr_digits='0123456789' -+as_cr_alnum=$as_cr_Letters$as_cr_digits -+ -+# The user is always right. -+if test "${PATH_SEPARATOR+set}" != set; then -+ echo "#! /bin/sh" >conf$$.sh -+ echo "exit 0" >>conf$$.sh -+ chmod +x conf$$.sh -+ if (PATH="/nonexistent;."; conf$$.sh) >/dev/null 2>&1; then -+ PATH_SEPARATOR=';' -+ else -+ PATH_SEPARATOR=: -+ fi -+ rm -f conf$$.sh -+fi -+ -+ -+ as_lineno_1=$LINENO -+ as_lineno_2=$LINENO -+ as_lineno_3=`(expr $as_lineno_1 + 1) 2>/dev/null` -+ test "x$as_lineno_1" != "x$as_lineno_2" && -+ test "x$as_lineno_3" = "x$as_lineno_2" || { -+ # Find who we are. Look in the path if we contain no path at all -+ # relative or not. -+ case $0 in -+ *[\\/]* ) as_myself=$0 ;; -+ *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -+for as_dir in $PATH -+do -+ IFS=$as_save_IFS -+ test -z "$as_dir" && as_dir=. -+ test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break -+done -+ -+ ;; -+ esac -+ # We did not find ourselves, most probably we were run as `sh COMMAND' -+ # in which case we are not to be found in the path. -+ if test "x$as_myself" = x; then -+ as_myself=$0 -+ fi -+ if test ! -f "$as_myself"; then -+ { { echo "$as_me:$LINENO: error: cannot find myself; rerun with an absolute path" >&5 -+echo "$as_me: error: cannot find myself; rerun with an absolute path" >&2;} -+ { (exit 1); exit 1; }; } -+ fi -+ case $CONFIG_SHELL in -+ '') -+ as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -+for as_dir in /bin$PATH_SEPARATOR/usr/bin$PATH_SEPARATOR$PATH -+do -+ IFS=$as_save_IFS -+ test -z "$as_dir" && as_dir=. -+ for as_base in sh bash ksh sh5; do -+ case $as_dir in -+ /*) -+ if ("$as_dir/$as_base" -c ' -+ as_lineno_1=$LINENO -+ as_lineno_2=$LINENO -+ as_lineno_3=`(expr $as_lineno_1 + 1) 2>/dev/null` -+ test "x$as_lineno_1" != "x$as_lineno_2" && -+ test "x$as_lineno_3" = "x$as_lineno_2" ') 2>/dev/null; then -+ $as_unset BASH_ENV || test "${BASH_ENV+set}" != set || { BASH_ENV=; export BASH_ENV; } -+ $as_unset ENV || test "${ENV+set}" != set || { ENV=; export ENV; } -+ CONFIG_SHELL=$as_dir/$as_base -+ export CONFIG_SHELL -+ exec "$CONFIG_SHELL" "$0" ${1+"$@"} -+ fi;; -+ esac -+ done -+done -+;; -+ esac -+ -+ # Create $as_me.lineno as a copy of $as_myself, but with $LINENO -+ # uniformly replaced by the line number. The first 'sed' inserts a -+ # line-number line before each line; the second 'sed' does the real -+ # work. The second script uses 'N' to pair each line-number line -+ # with the numbered line, and appends trailing '-' during -+ # substitution so that $LINENO is not a special case at line end. -+ # (Raja R Harinath suggested sed '=', and Paul Eggert wrote the -+ # second 'sed' script. Blame Lee E. McMahon for sed's syntax. :-) -+ sed '=' <$as_myself | -+ sed ' -+ N -+ s,$,-, -+ : loop -+ s,^\(['$as_cr_digits']*\)\(.*\)[$]LINENO\([^'$as_cr_alnum'_]\),\1\2\1\3, -+ t loop -+ s,-$,, -+ s,^['$as_cr_digits']*\n,, -+ ' >$as_me.lineno && -+ chmod +x $as_me.lineno || -+ { { echo "$as_me:$LINENO: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&5 -+echo "$as_me: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&2;} -+ { (exit 1); exit 1; }; } -+ -+ # Don't try to exec as it changes $[0], causing all sort of problems -+ # (the dirname of $[0] is not the place where we might find the -+ # original and so on. Autoconf is especially sensible to this). -+ . ./$as_me.lineno -+ # Exit status is that of the last command. -+ exit -+} -+ -+ -+case `echo "testing\c"; echo 1,2,3`,`echo -n testing; echo 1,2,3` in -+ *c*,-n*) ECHO_N= ECHO_C=' -+' ECHO_T=' ' ;; -+ *c*,* ) ECHO_N=-n ECHO_C= ECHO_T= ;; -+ *) ECHO_N= ECHO_C='\c' ECHO_T= ;; -+esac -+ -+if expr a : '\(a\)' >/dev/null 2>&1; then -+ as_expr=expr -+else -+ as_expr=false -+fi -+ -+rm -f conf$$ conf$$.exe conf$$.file -+echo >conf$$.file -+if ln -s conf$$.file conf$$ 2>/dev/null; then -+ # We could just check for DJGPP; but this test a) works b) is more generic -+ # and c) will remain valid once DJGPP supports symlinks (DJGPP 2.04). -+ if test -f conf$$.exe; then -+ # Don't use ln at all; we don't have any links -+ as_ln_s='cp -p' -+ else -+ as_ln_s='ln -s' -+ fi -+elif ln conf$$.file conf$$ 2>/dev/null; then -+ as_ln_s=ln -+else -+ as_ln_s='cp -p' -+fi -+rm -f conf$$ conf$$.exe conf$$.file -+ -+if mkdir -p . 2>/dev/null; then -+ as_mkdir_p=: -+else -+ test -d ./-p && rmdir ./-p -+ as_mkdir_p=false -+fi -+ -+as_executable_p="test -f" -+ -+# Sed expression to map a string onto a valid CPP name. -+as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" -+ -+# Sed expression to map a string onto a valid variable name. -+as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" -+ -+ -+# IFS -+# We need space, tab and new line, in precisely that order. -+as_nl=' -+' -+IFS=" $as_nl" -+ -+# CDPATH. -+$as_unset CDPATH -+ -+exec 6>&1 -+ -+# Open the log real soon, to keep \$[0] and so on meaningful, and to -+# report actual input values of CONFIG_FILES etc. instead of their -+# values after options handling. Logging --version etc. is OK. -+exec 5>>config.log -+{ -+ echo -+ sed 'h;s/./-/g;s/^.../## /;s/...$/ ##/;p;x;p;x' <<_ASBOX -+## Running $as_me. ## -+_ASBOX -+} >&5 -+cat >&5 <<_CSEOF -+ -+This file was extended by $as_me, which was -+generated by GNU Autoconf 2.59. Invocation command line was -+ -+ CONFIG_FILES = $CONFIG_FILES -+ CONFIG_HEADERS = $CONFIG_HEADERS -+ CONFIG_LINKS = $CONFIG_LINKS -+ CONFIG_COMMANDS = $CONFIG_COMMANDS -+ $ $0 $@ -+ -+_CSEOF -+echo "on `(hostname || uname -n) 2>/dev/null | sed 1q`" >&5 -+echo >&5 -+_ACEOF -+ -+# Files that config.status was made for. -+if test -n "$ac_config_files"; then -+ echo "config_files=\"$ac_config_files\"" >>$CONFIG_STATUS -+fi -+ -+if test -n "$ac_config_headers"; then -+ echo "config_headers=\"$ac_config_headers\"" >>$CONFIG_STATUS -+fi -+ -+if test -n "$ac_config_links"; then -+ echo "config_links=\"$ac_config_links\"" >>$CONFIG_STATUS -+fi -+ -+if test -n "$ac_config_commands"; then -+ echo "config_commands=\"$ac_config_commands\"" >>$CONFIG_STATUS -+fi -+ -+cat >>$CONFIG_STATUS <<\_ACEOF -+ -+ac_cs_usage="\ -+\`$as_me' instantiates files from templates according to the -+current configuration. -+ -+Usage: $0 [OPTIONS] [FILE]... -+ -+ -h, --help print this help, then exit -+ -V, --version print version number, then exit -+ -q, --quiet do not print progress messages -+ -d, --debug don't remove temporary files -+ --recheck update $as_me by reconfiguring in the same conditions -+ --file=FILE[:TEMPLATE] -+ instantiate the configuration file FILE -+ --header=FILE[:TEMPLATE] -+ instantiate the configuration header FILE -+ -+Configuration files: -+$config_files -+ -+Configuration headers: -+$config_headers -+ -+Configuration commands: -+$config_commands -+ -+Report bugs to ." -+_ACEOF -+ -+cat >>$CONFIG_STATUS <<_ACEOF -+ac_cs_version="\\ -+config.status -+configured by $0, generated by GNU Autoconf 2.59, -+ with options \\"`echo "$ac_configure_args" | sed 's/[\\""\`\$]/\\\\&/g'`\\" -+ -+Copyright (C) 2003 Free Software Foundation, Inc. -+This config.status script is free software; the Free Software Foundation -+gives unlimited permission to copy, distribute and modify it." -+srcdir=$srcdir -+INSTALL="$INSTALL" -+_ACEOF -+ -+cat >>$CONFIG_STATUS <<\_ACEOF -+# If no file are specified by the user, then we need to provide default -+# value. By we need to know if files were specified by the user. -+ac_need_defaults=: -+while test $# != 0 -+do -+ case $1 in -+ --*=*) -+ ac_option=`expr "x$1" : 'x\([^=]*\)='` -+ ac_optarg=`expr "x$1" : 'x[^=]*=\(.*\)'` -+ ac_shift=: -+ ;; -+ -*) -+ ac_option=$1 -+ ac_optarg=$2 -+ ac_shift=shift -+ ;; -+ *) # This is not an option, so the user has probably given explicit -+ # arguments. -+ ac_option=$1 -+ ac_need_defaults=false;; -+ esac -+ -+ case $ac_option in -+ # Handling of the options. -+_ACEOF -+cat >>$CONFIG_STATUS <<\_ACEOF -+ -recheck | --recheck | --rechec | --reche | --rech | --rec | --re | --r) -+ ac_cs_recheck=: ;; -+ --version | --vers* | -V ) -+ echo "$ac_cs_version"; exit 0 ;; -+ --he | --h) -+ # Conflict between --help and --header -+ { { echo "$as_me:$LINENO: error: ambiguous option: $1 -+Try \`$0 --help' for more information." >&5 -+echo "$as_me: error: ambiguous option: $1 -+Try \`$0 --help' for more information." >&2;} -+ { (exit 1); exit 1; }; };; -+ --help | --hel | -h ) -+ echo "$ac_cs_usage"; exit 0 ;; -+ --debug | --d* | -d ) -+ debug=: ;; -+ --file | --fil | --fi | --f ) -+ $ac_shift -+ CONFIG_FILES="$CONFIG_FILES $ac_optarg" -+ ac_need_defaults=false;; -+ --header | --heade | --head | --hea ) -+ $ac_shift -+ CONFIG_HEADERS="$CONFIG_HEADERS $ac_optarg" -+ ac_need_defaults=false;; -+ -q | -quiet | --quiet | --quie | --qui | --qu | --q \ -+ | -silent | --silent | --silen | --sile | --sil | --si | --s) -+ ac_cs_silent=: ;; -+ -+ # This is an error. -+ -*) { { echo "$as_me:$LINENO: error: unrecognized option: $1 -+Try \`$0 --help' for more information." >&5 -+echo "$as_me: error: unrecognized option: $1 -+Try \`$0 --help' for more information." >&2;} -+ { (exit 1); exit 1; }; } ;; -+ -+ *) ac_config_targets="$ac_config_targets $1" ;; -+ -+ esac -+ shift -+done -+ -+ac_configure_extra_args= -+ -+if $ac_cs_silent; then -+ exec 6>/dev/null -+ ac_configure_extra_args="$ac_configure_extra_args --silent" -+fi -+ -+_ACEOF -+cat >>$CONFIG_STATUS <<_ACEOF -+if \$ac_cs_recheck; then -+ echo "running $SHELL $0 " $ac_configure_args \$ac_configure_extra_args " --no-create --no-recursion" >&6 -+ exec $SHELL $0 $ac_configure_args \$ac_configure_extra_args --no-create --no-recursion -+fi -+ -+_ACEOF -+ -+cat >>$CONFIG_STATUS <<_ACEOF -+# -+# INIT-COMMANDS section. -+# -+ -+AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir" -+ -+_ACEOF -+ -+ -+ -+cat >>$CONFIG_STATUS <<\_ACEOF -+for ac_config_target in $ac_config_targets -+do -+ case "$ac_config_target" in -+ # Handling of arguments. -+ "Makefile" ) CONFIG_FILES="$CONFIG_FILES Makefile" ;; -+ "depfiles" ) CONFIG_COMMANDS="$CONFIG_COMMANDS depfiles" ;; -+ "config.h" ) CONFIG_HEADERS="$CONFIG_HEADERS config.h" ;; -+ *) { { echo "$as_me:$LINENO: error: invalid argument: $ac_config_target" >&5 -+echo "$as_me: error: invalid argument: $ac_config_target" >&2;} -+ { (exit 1); exit 1; }; };; -+ esac -+done -+ -+# If the user did not use the arguments to specify the items to instantiate, -+# then the envvar interface is used. Set only those that are not. -+# We use the long form for the default assignment because of an extremely -+# bizarre bug on SunOS 4.1.3. -+if $ac_need_defaults; then -+ test "${CONFIG_FILES+set}" = set || CONFIG_FILES=$config_files -+ test "${CONFIG_HEADERS+set}" = set || CONFIG_HEADERS=$config_headers -+ test "${CONFIG_COMMANDS+set}" = set || CONFIG_COMMANDS=$config_commands -+fi -+ -+# Have a temporary directory for convenience. Make it in the build tree -+# simply because there is no reason to put it here, and in addition, -+# creating and moving files from /tmp can sometimes cause problems. -+# Create a temporary directory, and hook for its removal unless debugging. -+$debug || -+{ -+ trap 'exit_status=$?; rm -rf $tmp && exit $exit_status' 0 -+ trap '{ (exit 1); exit 1; }' 1 2 13 15 -+} -+ -+# Create a (secure) tmp directory for tmp files. -+ -+{ -+ tmp=`(umask 077 && mktemp -d -q "./confstatXXXXXX") 2>/dev/null` && -+ test -n "$tmp" && test -d "$tmp" -+} || -+{ -+ tmp=./confstat$$-$RANDOM -+ (umask 077 && mkdir $tmp) -+} || -+{ -+ echo "$me: cannot create a temporary directory in ." >&2 -+ { (exit 1); exit 1; } -+} -+ -+_ACEOF -+ -+cat >>$CONFIG_STATUS <<_ACEOF -+ -+# -+# CONFIG_FILES section. -+# -+ -+# No need to generate the scripts if there are no CONFIG_FILES. -+# This happens for instance when ./config.status config.h -+if test -n "\$CONFIG_FILES"; then -+ # Protect against being on the right side of a sed subst in config.status. -+ sed 's/,@/@@/; s/@,/@@/; s/,;t t\$/@;t t/; /@;t t\$/s/[\\\\&,]/\\\\&/g; -+ s/@@/,@/; s/@@/@,/; s/@;t t\$/,;t t/' >\$tmp/subs.sed <<\\CEOF -+s,@SHELL@,$SHELL,;t t -+s,@PATH_SEPARATOR@,$PATH_SEPARATOR,;t t -+s,@PACKAGE_NAME@,$PACKAGE_NAME,;t t -+s,@PACKAGE_TARNAME@,$PACKAGE_TARNAME,;t t -+s,@PACKAGE_VERSION@,$PACKAGE_VERSION,;t t -+s,@PACKAGE_STRING@,$PACKAGE_STRING,;t t -+s,@PACKAGE_BUGREPORT@,$PACKAGE_BUGREPORT,;t t -+s,@exec_prefix@,$exec_prefix,;t t -+s,@prefix@,$prefix,;t t -+s,@program_transform_name@,$program_transform_name,;t t -+s,@bindir@,$bindir,;t t -+s,@sbindir@,$sbindir,;t t -+s,@libexecdir@,$libexecdir,;t t -+s,@datadir@,$datadir,;t t -+s,@sysconfdir@,$sysconfdir,;t t -+s,@sharedstatedir@,$sharedstatedir,;t t -+s,@localstatedir@,$localstatedir,;t t -+s,@libdir@,$libdir,;t t -+s,@includedir@,$includedir,;t t -+s,@oldincludedir@,$oldincludedir,;t t -+s,@infodir@,$infodir,;t t -+s,@mandir@,$mandir,;t t -+s,@build_alias@,$build_alias,;t t -+s,@host_alias@,$host_alias,;t t -+s,@target_alias@,$target_alias,;t t -+s,@DEFS@,$DEFS,;t t -+s,@ECHO_C@,$ECHO_C,;t t -+s,@ECHO_N@,$ECHO_N,;t t -+s,@ECHO_T@,$ECHO_T,;t t -+s,@LIBS@,$LIBS,;t t -+s,@INSTALL_PROGRAM@,$INSTALL_PROGRAM,;t t -+s,@INSTALL_SCRIPT@,$INSTALL_SCRIPT,;t t -+s,@INSTALL_DATA@,$INSTALL_DATA,;t t -+s,@CYGPATH_W@,$CYGPATH_W,;t t -+s,@PACKAGE@,$PACKAGE,;t t -+s,@VERSION@,$VERSION,;t t -+s,@ACLOCAL@,$ACLOCAL,;t t -+s,@AUTOCONF@,$AUTOCONF,;t t -+s,@AUTOMAKE@,$AUTOMAKE,;t t -+s,@AUTOHEADER@,$AUTOHEADER,;t t -+s,@MAKEINFO@,$MAKEINFO,;t t -+s,@install_sh@,$install_sh,;t t -+s,@STRIP@,$STRIP,;t t -+s,@ac_ct_STRIP@,$ac_ct_STRIP,;t t -+s,@INSTALL_STRIP_PROGRAM@,$INSTALL_STRIP_PROGRAM,;t t -+s,@mkdir_p@,$mkdir_p,;t t -+s,@AWK@,$AWK,;t t -+s,@SET_MAKE@,$SET_MAKE,;t t -+s,@am__leading_dot@,$am__leading_dot,;t t -+s,@AMTAR@,$AMTAR,;t t -+s,@am__tar@,$am__tar,;t t -+s,@am__untar@,$am__untar,;t t -+s,@CC@,$CC,;t t -+s,@CFLAGS@,$CFLAGS,;t t -+s,@LDFLAGS@,$LDFLAGS,;t t -+s,@CPPFLAGS@,$CPPFLAGS,;t t -+s,@ac_ct_CC@,$ac_ct_CC,;t t -+s,@EXEEXT@,$EXEEXT,;t t -+s,@OBJEXT@,$OBJEXT,;t t -+s,@DEPDIR@,$DEPDIR,;t t -+s,@am__include@,$am__include,;t t -+s,@am__quote@,$am__quote,;t t -+s,@AMDEP_TRUE@,$AMDEP_TRUE,;t t -+s,@AMDEP_FALSE@,$AMDEP_FALSE,;t t -+s,@AMDEPBACKSLASH@,$AMDEPBACKSLASH,;t t -+s,@CCDEPMODE@,$CCDEPMODE,;t t -+s,@am__fastdepCC_TRUE@,$am__fastdepCC_TRUE,;t t -+s,@am__fastdepCC_FALSE@,$am__fastdepCC_FALSE,;t t -+s,@LN_S@,$LN_S,;t t -+s,@CPP@,$CPP,;t t -+s,@EGREP@,$EGREP,;t t -+s,@RANLIB@,$RANLIB,;t t -+s,@ac_ct_RANLIB@,$ac_ct_RANLIB,;t t -+s,@BUILD_WIN32_TRUE@,$BUILD_WIN32_TRUE,;t t -+s,@BUILD_WIN32_FALSE@,$BUILD_WIN32_FALSE,;t t -+s,@LIBOBJS@,$LIBOBJS,;t t -+s,@LTLIBOBJS@,$LTLIBOBJS,;t t -+CEOF -+ -+_ACEOF -+ -+ cat >>$CONFIG_STATUS <<\_ACEOF -+ # Split the substitutions into bite-sized pieces for seds with -+ # small command number limits, like on Digital OSF/1 and HP-UX. -+ ac_max_sed_lines=48 -+ ac_sed_frag=1 # Number of current file. -+ ac_beg=1 # First line for current file. -+ ac_end=$ac_max_sed_lines # Line after last line for current file. -+ ac_more_lines=: -+ ac_sed_cmds= -+ while $ac_more_lines; do -+ if test $ac_beg -gt 1; then -+ sed "1,${ac_beg}d; ${ac_end}q" $tmp/subs.sed >$tmp/subs.frag -+ else -+ sed "${ac_end}q" $tmp/subs.sed >$tmp/subs.frag -+ fi -+ if test ! -s $tmp/subs.frag; then -+ ac_more_lines=false -+ else -+ # The purpose of the label and of the branching condition is to -+ # speed up the sed processing (if there are no `@' at all, there -+ # is no need to browse any of the substitutions). -+ # These are the two extra sed commands mentioned above. -+ (echo ':t -+ /@[a-zA-Z_][a-zA-Z_0-9]*@/!b' && cat $tmp/subs.frag) >$tmp/subs-$ac_sed_frag.sed -+ if test -z "$ac_sed_cmds"; then -+ ac_sed_cmds="sed -f $tmp/subs-$ac_sed_frag.sed" -+ else -+ ac_sed_cmds="$ac_sed_cmds | sed -f $tmp/subs-$ac_sed_frag.sed" -+ fi -+ ac_sed_frag=`expr $ac_sed_frag + 1` -+ ac_beg=$ac_end -+ ac_end=`expr $ac_end + $ac_max_sed_lines` -+ fi -+ done -+ if test -z "$ac_sed_cmds"; then -+ ac_sed_cmds=cat -+ fi -+fi # test -n "$CONFIG_FILES" -+ -+_ACEOF -+cat >>$CONFIG_STATUS <<\_ACEOF -+for ac_file in : $CONFIG_FILES; do test "x$ac_file" = x: && continue -+ # Support "outfile[:infile[:infile...]]", defaulting infile="outfile.in". -+ case $ac_file in -+ - | *:- | *:-:* ) # input from stdin -+ cat >$tmp/stdin -+ ac_file_in=`echo "$ac_file" | sed 's,[^:]*:,,'` -+ ac_file=`echo "$ac_file" | sed 's,:.*,,'` ;; -+ *:* ) ac_file_in=`echo "$ac_file" | sed 's,[^:]*:,,'` -+ ac_file=`echo "$ac_file" | sed 's,:.*,,'` ;; -+ * ) ac_file_in=$ac_file.in ;; -+ esac -+ -+ # Compute @srcdir@, @top_srcdir@, and @INSTALL@ for subdirectories. -+ ac_dir=`(dirname "$ac_file") 2>/dev/null || -+$as_expr X"$ac_file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ -+ X"$ac_file" : 'X\(//\)[^/]' \| \ -+ X"$ac_file" : 'X\(//\)$' \| \ -+ X"$ac_file" : 'X\(/\)' \| \ -+ . : '\(.\)' 2>/dev/null || -+echo X"$ac_file" | -+ sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } -+ /^X\(\/\/\)[^/].*/{ s//\1/; q; } -+ /^X\(\/\/\)$/{ s//\1/; q; } -+ /^X\(\/\).*/{ s//\1/; q; } -+ s/.*/./; q'` -+ { if $as_mkdir_p; then -+ mkdir -p "$ac_dir" -+ else -+ as_dir="$ac_dir" -+ as_dirs= -+ while test ! -d "$as_dir"; do -+ as_dirs="$as_dir $as_dirs" -+ as_dir=`(dirname "$as_dir") 2>/dev/null || -+$as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ -+ X"$as_dir" : 'X\(//\)[^/]' \| \ -+ X"$as_dir" : 'X\(//\)$' \| \ -+ X"$as_dir" : 'X\(/\)' \| \ -+ . : '\(.\)' 2>/dev/null || -+echo X"$as_dir" | -+ sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } -+ /^X\(\/\/\)[^/].*/{ s//\1/; q; } -+ /^X\(\/\/\)$/{ s//\1/; q; } -+ /^X\(\/\).*/{ s//\1/; q; } -+ s/.*/./; q'` -+ done -+ test ! -n "$as_dirs" || mkdir $as_dirs -+ fi || { { echo "$as_me:$LINENO: error: cannot create directory \"$ac_dir\"" >&5 -+echo "$as_me: error: cannot create directory \"$ac_dir\"" >&2;} -+ { (exit 1); exit 1; }; }; } -+ -+ ac_builddir=. -+ -+if test "$ac_dir" != .; then -+ ac_dir_suffix=/`echo "$ac_dir" | sed 's,^\.[\\/],,'` -+ # A "../" for each directory in $ac_dir_suffix. -+ ac_top_builddir=`echo "$ac_dir_suffix" | sed 's,/[^\\/]*,../,g'` -+else -+ ac_dir_suffix= ac_top_builddir= -+fi -+ -+case $srcdir in -+ .) # No --srcdir option. We are building in place. -+ ac_srcdir=. -+ if test -z "$ac_top_builddir"; then -+ ac_top_srcdir=. -+ else -+ ac_top_srcdir=`echo $ac_top_builddir | sed 's,/$,,'` -+ fi ;; -+ [\\/]* | ?:[\\/]* ) # Absolute path. -+ ac_srcdir=$srcdir$ac_dir_suffix; -+ ac_top_srcdir=$srcdir ;; -+ *) # Relative path. -+ ac_srcdir=$ac_top_builddir$srcdir$ac_dir_suffix -+ ac_top_srcdir=$ac_top_builddir$srcdir ;; -+esac -+ -+# Do not use `cd foo && pwd` to compute absolute paths, because -+# the directories may not exist. -+case `pwd` in -+.) ac_abs_builddir="$ac_dir";; -+*) -+ case "$ac_dir" in -+ .) ac_abs_builddir=`pwd`;; -+ [\\/]* | ?:[\\/]* ) ac_abs_builddir="$ac_dir";; -+ *) ac_abs_builddir=`pwd`/"$ac_dir";; -+ esac;; -+esac -+case $ac_abs_builddir in -+.) ac_abs_top_builddir=${ac_top_builddir}.;; -+*) -+ case ${ac_top_builddir}. in -+ .) ac_abs_top_builddir=$ac_abs_builddir;; -+ [\\/]* | ?:[\\/]* ) ac_abs_top_builddir=${ac_top_builddir}.;; -+ *) ac_abs_top_builddir=$ac_abs_builddir/${ac_top_builddir}.;; -+ esac;; -+esac -+case $ac_abs_builddir in -+.) ac_abs_srcdir=$ac_srcdir;; -+*) -+ case $ac_srcdir in -+ .) ac_abs_srcdir=$ac_abs_builddir;; -+ [\\/]* | ?:[\\/]* ) ac_abs_srcdir=$ac_srcdir;; -+ *) ac_abs_srcdir=$ac_abs_builddir/$ac_srcdir;; -+ esac;; -+esac -+case $ac_abs_builddir in -+.) ac_abs_top_srcdir=$ac_top_srcdir;; -+*) -+ case $ac_top_srcdir in -+ .) ac_abs_top_srcdir=$ac_abs_builddir;; -+ [\\/]* | ?:[\\/]* ) ac_abs_top_srcdir=$ac_top_srcdir;; -+ *) ac_abs_top_srcdir=$ac_abs_builddir/$ac_top_srcdir;; -+ esac;; -+esac -+ -+ -+ case $INSTALL in -+ [\\/$]* | ?:[\\/]* ) ac_INSTALL=$INSTALL ;; -+ *) ac_INSTALL=$ac_top_builddir$INSTALL ;; -+ esac -+ -+ if test x"$ac_file" != x-; then -+ { echo "$as_me:$LINENO: creating $ac_file" >&5 -+echo "$as_me: creating $ac_file" >&6;} -+ rm -f "$ac_file" -+ fi -+ # Let's still pretend it is `configure' which instantiates (i.e., don't -+ # use $as_me), people would be surprised to read: -+ # /* config.h. Generated by config.status. */ -+ if test x"$ac_file" = x-; then -+ configure_input= -+ else -+ configure_input="$ac_file. " -+ fi -+ configure_input=$configure_input"Generated from `echo $ac_file_in | -+ sed 's,.*/,,'` by configure." -+ -+ # First look for the input files in the build tree, otherwise in the -+ # src tree. -+ ac_file_inputs=`IFS=: -+ for f in $ac_file_in; do -+ case $f in -+ -) echo $tmp/stdin ;; -+ [\\/$]*) -+ # Absolute (can't be DOS-style, as IFS=:) -+ test -f "$f" || { { echo "$as_me:$LINENO: error: cannot find input file: $f" >&5 -+echo "$as_me: error: cannot find input file: $f" >&2;} -+ { (exit 1); exit 1; }; } -+ echo "$f";; -+ *) # Relative -+ if test -f "$f"; then -+ # Build tree -+ echo "$f" -+ elif test -f "$srcdir/$f"; then -+ # Source tree -+ echo "$srcdir/$f" -+ else -+ # /dev/null tree -+ { { echo "$as_me:$LINENO: error: cannot find input file: $f" >&5 -+echo "$as_me: error: cannot find input file: $f" >&2;} -+ { (exit 1); exit 1; }; } -+ fi;; -+ esac -+ done` || { (exit 1); exit 1; } -+_ACEOF -+cat >>$CONFIG_STATUS <<_ACEOF -+ sed "$ac_vpsub -+$extrasub -+_ACEOF -+cat >>$CONFIG_STATUS <<\_ACEOF -+:t -+/@[a-zA-Z_][a-zA-Z_0-9]*@/!b -+s,@configure_input@,$configure_input,;t t -+s,@srcdir@,$ac_srcdir,;t t -+s,@abs_srcdir@,$ac_abs_srcdir,;t t -+s,@top_srcdir@,$ac_top_srcdir,;t t -+s,@abs_top_srcdir@,$ac_abs_top_srcdir,;t t -+s,@builddir@,$ac_builddir,;t t -+s,@abs_builddir@,$ac_abs_builddir,;t t -+s,@top_builddir@,$ac_top_builddir,;t t -+s,@abs_top_builddir@,$ac_abs_top_builddir,;t t -+s,@INSTALL@,$ac_INSTALL,;t t -+" $ac_file_inputs | (eval "$ac_sed_cmds") >$tmp/out -+ rm -f $tmp/stdin -+ if test x"$ac_file" != x-; then -+ mv $tmp/out $ac_file -+ else -+ cat $tmp/out -+ rm -f $tmp/out -+ fi -+ -+done -+_ACEOF -+cat >>$CONFIG_STATUS <<\_ACEOF -+ -+# -+# CONFIG_HEADER section. -+# -+ -+# These sed commands are passed to sed as "A NAME B NAME C VALUE D", where -+# NAME is the cpp macro being defined and VALUE is the value it is being given. -+# -+# ac_d sets the value in "#define NAME VALUE" lines. -+ac_dA='s,^\([ ]*\)#\([ ]*define[ ][ ]*\)' -+ac_dB='[ ].*$,\1#\2' -+ac_dC=' ' -+ac_dD=',;t' -+# ac_u turns "#undef NAME" without trailing blanks into "#define NAME VALUE". -+ac_uA='s,^\([ ]*\)#\([ ]*\)undef\([ ][ ]*\)' -+ac_uB='$,\1#\2define\3' -+ac_uC=' ' -+ac_uD=',;t' -+ -+for ac_file in : $CONFIG_HEADERS; do test "x$ac_file" = x: && continue -+ # Support "outfile[:infile[:infile...]]", defaulting infile="outfile.in". -+ case $ac_file in -+ - | *:- | *:-:* ) # input from stdin -+ cat >$tmp/stdin -+ ac_file_in=`echo "$ac_file" | sed 's,[^:]*:,,'` -+ ac_file=`echo "$ac_file" | sed 's,:.*,,'` ;; -+ *:* ) ac_file_in=`echo "$ac_file" | sed 's,[^:]*:,,'` -+ ac_file=`echo "$ac_file" | sed 's,:.*,,'` ;; -+ * ) ac_file_in=$ac_file.in ;; -+ esac -+ -+ test x"$ac_file" != x- && { echo "$as_me:$LINENO: creating $ac_file" >&5 -+echo "$as_me: creating $ac_file" >&6;} -+ -+ # First look for the input files in the build tree, otherwise in the -+ # src tree. -+ ac_file_inputs=`IFS=: -+ for f in $ac_file_in; do -+ case $f in -+ -) echo $tmp/stdin ;; -+ [\\/$]*) -+ # Absolute (can't be DOS-style, as IFS=:) -+ test -f "$f" || { { echo "$as_me:$LINENO: error: cannot find input file: $f" >&5 -+echo "$as_me: error: cannot find input file: $f" >&2;} -+ { (exit 1); exit 1; }; } -+ # Do quote $f, to prevent DOS paths from being IFS'd. -+ echo "$f";; -+ *) # Relative -+ if test -f "$f"; then -+ # Build tree -+ echo "$f" -+ elif test -f "$srcdir/$f"; then -+ # Source tree -+ echo "$srcdir/$f" -+ else -+ # /dev/null tree -+ { { echo "$as_me:$LINENO: error: cannot find input file: $f" >&5 -+echo "$as_me: error: cannot find input file: $f" >&2;} -+ { (exit 1); exit 1; }; } -+ fi;; -+ esac -+ done` || { (exit 1); exit 1; } -+ # Remove the trailing spaces. -+ sed 's/[ ]*$//' $ac_file_inputs >$tmp/in -+ -+_ACEOF -+ -+# Transform confdefs.h into two sed scripts, `conftest.defines' and -+# `conftest.undefs', that substitutes the proper values into -+# config.h.in to produce config.h. The first handles `#define' -+# templates, and the second `#undef' templates. -+# And first: Protect against being on the right side of a sed subst in -+# config.status. Protect against being in an unquoted here document -+# in config.status. -+rm -f conftest.defines conftest.undefs -+# Using a here document instead of a string reduces the quoting nightmare. -+# Putting comments in sed scripts is not portable. -+# -+# `end' is used to avoid that the second main sed command (meant for -+# 0-ary CPP macros) applies to n-ary macro definitions. -+# See the Autoconf documentation for `clear'. -+cat >confdef2sed.sed <<\_ACEOF -+s/[\\&,]/\\&/g -+s,[\\$`],\\&,g -+t clear -+: clear -+s,^[ ]*#[ ]*define[ ][ ]*\([^ (][^ (]*\)\(([^)]*)\)[ ]*\(.*\)$,${ac_dA}\1${ac_dB}\1\2${ac_dC}\3${ac_dD},gp -+t end -+s,^[ ]*#[ ]*define[ ][ ]*\([^ ][^ ]*\)[ ]*\(.*\)$,${ac_dA}\1${ac_dB}\1${ac_dC}\2${ac_dD},gp -+: end -+_ACEOF -+# If some macros were called several times there might be several times -+# the same #defines, which is useless. Nevertheless, we may not want to -+# sort them, since we want the *last* AC-DEFINE to be honored. -+uniq confdefs.h | sed -n -f confdef2sed.sed >conftest.defines -+sed 's/ac_d/ac_u/g' conftest.defines >conftest.undefs -+rm -f confdef2sed.sed -+ -+# This sed command replaces #undef with comments. This is necessary, for -+# example, in the case of _POSIX_SOURCE, which is predefined and required -+# on some systems where configure will not decide to define it. -+cat >>conftest.undefs <<\_ACEOF -+s,^[ ]*#[ ]*undef[ ][ ]*[a-zA-Z_][a-zA-Z_0-9]*,/* & */, -+_ACEOF -+ -+# Break up conftest.defines because some shells have a limit on the size -+# of here documents, and old seds have small limits too (100 cmds). -+echo ' # Handle all the #define templates only if necessary.' >>$CONFIG_STATUS -+echo ' if grep "^[ ]*#[ ]*define" $tmp/in >/dev/null; then' >>$CONFIG_STATUS -+echo ' # If there are no defines, we may have an empty if/fi' >>$CONFIG_STATUS -+echo ' :' >>$CONFIG_STATUS -+rm -f conftest.tail -+while grep . conftest.defines >/dev/null -+do -+ # Write a limited-size here document to $tmp/defines.sed. -+ echo ' cat >$tmp/defines.sed <>$CONFIG_STATUS -+ # Speed up: don't consider the non `#define' lines. -+ echo '/^[ ]*#[ ]*define/!b' >>$CONFIG_STATUS -+ # Work around the forget-to-reset-the-flag bug. -+ echo 't clr' >>$CONFIG_STATUS -+ echo ': clr' >>$CONFIG_STATUS -+ sed ${ac_max_here_lines}q conftest.defines >>$CONFIG_STATUS -+ echo 'CEOF -+ sed -f $tmp/defines.sed $tmp/in >$tmp/out -+ rm -f $tmp/in -+ mv $tmp/out $tmp/in -+' >>$CONFIG_STATUS -+ sed 1,${ac_max_here_lines}d conftest.defines >conftest.tail -+ rm -f conftest.defines -+ mv conftest.tail conftest.defines -+done -+rm -f conftest.defines -+echo ' fi # grep' >>$CONFIG_STATUS -+echo >>$CONFIG_STATUS -+ -+# Break up conftest.undefs because some shells have a limit on the size -+# of here documents, and old seds have small limits too (100 cmds). -+echo ' # Handle all the #undef templates' >>$CONFIG_STATUS -+rm -f conftest.tail -+while grep . conftest.undefs >/dev/null -+do -+ # Write a limited-size here document to $tmp/undefs.sed. -+ echo ' cat >$tmp/undefs.sed <>$CONFIG_STATUS -+ # Speed up: don't consider the non `#undef' -+ echo '/^[ ]*#[ ]*undef/!b' >>$CONFIG_STATUS -+ # Work around the forget-to-reset-the-flag bug. -+ echo 't clr' >>$CONFIG_STATUS -+ echo ': clr' >>$CONFIG_STATUS -+ sed ${ac_max_here_lines}q conftest.undefs >>$CONFIG_STATUS -+ echo 'CEOF -+ sed -f $tmp/undefs.sed $tmp/in >$tmp/out -+ rm -f $tmp/in -+ mv $tmp/out $tmp/in -+' >>$CONFIG_STATUS -+ sed 1,${ac_max_here_lines}d conftest.undefs >conftest.tail -+ rm -f conftest.undefs -+ mv conftest.tail conftest.undefs -+done -+rm -f conftest.undefs -+ -+cat >>$CONFIG_STATUS <<\_ACEOF -+ # Let's still pretend it is `configure' which instantiates (i.e., don't -+ # use $as_me), people would be surprised to read: -+ # /* config.h. Generated by config.status. */ -+ if test x"$ac_file" = x-; then -+ echo "/* Generated by configure. */" >$tmp/config.h -+ else -+ echo "/* $ac_file. Generated by configure. */" >$tmp/config.h -+ fi -+ cat $tmp/in >>$tmp/config.h -+ rm -f $tmp/in -+ if test x"$ac_file" != x-; then -+ if diff $ac_file $tmp/config.h >/dev/null 2>&1; then -+ { echo "$as_me:$LINENO: $ac_file is unchanged" >&5 -+echo "$as_me: $ac_file is unchanged" >&6;} -+ else -+ ac_dir=`(dirname "$ac_file") 2>/dev/null || -+$as_expr X"$ac_file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ -+ X"$ac_file" : 'X\(//\)[^/]' \| \ -+ X"$ac_file" : 'X\(//\)$' \| \ -+ X"$ac_file" : 'X\(/\)' \| \ -+ . : '\(.\)' 2>/dev/null || -+echo X"$ac_file" | -+ sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } -+ /^X\(\/\/\)[^/].*/{ s//\1/; q; } -+ /^X\(\/\/\)$/{ s//\1/; q; } -+ /^X\(\/\).*/{ s//\1/; q; } -+ s/.*/./; q'` -+ { if $as_mkdir_p; then -+ mkdir -p "$ac_dir" -+ else -+ as_dir="$ac_dir" -+ as_dirs= -+ while test ! -d "$as_dir"; do -+ as_dirs="$as_dir $as_dirs" -+ as_dir=`(dirname "$as_dir") 2>/dev/null || -+$as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ -+ X"$as_dir" : 'X\(//\)[^/]' \| \ -+ X"$as_dir" : 'X\(//\)$' \| \ -+ X"$as_dir" : 'X\(/\)' \| \ -+ . : '\(.\)' 2>/dev/null || -+echo X"$as_dir" | -+ sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } -+ /^X\(\/\/\)[^/].*/{ s//\1/; q; } -+ /^X\(\/\/\)$/{ s//\1/; q; } -+ /^X\(\/\).*/{ s//\1/; q; } -+ s/.*/./; q'` -+ done -+ test ! -n "$as_dirs" || mkdir $as_dirs -+ fi || { { echo "$as_me:$LINENO: error: cannot create directory \"$ac_dir\"" >&5 -+echo "$as_me: error: cannot create directory \"$ac_dir\"" >&2;} -+ { (exit 1); exit 1; }; }; } -+ -+ rm -f $ac_file -+ mv $tmp/config.h $ac_file -+ fi -+ else -+ cat $tmp/config.h -+ rm -f $tmp/config.h -+ fi -+# Compute $ac_file's index in $config_headers. -+_am_stamp_count=1 -+for _am_header in $config_headers :; do -+ case $_am_header in -+ $ac_file | $ac_file:* ) -+ break ;; -+ * ) -+ _am_stamp_count=`expr $_am_stamp_count + 1` ;; -+ esac -+done -+echo "timestamp for $ac_file" >`(dirname $ac_file) 2>/dev/null || -+$as_expr X$ac_file : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ -+ X$ac_file : 'X\(//\)[^/]' \| \ -+ X$ac_file : 'X\(//\)$' \| \ -+ X$ac_file : 'X\(/\)' \| \ -+ . : '\(.\)' 2>/dev/null || -+echo X$ac_file | -+ sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } -+ /^X\(\/\/\)[^/].*/{ s//\1/; q; } -+ /^X\(\/\/\)$/{ s//\1/; q; } -+ /^X\(\/\).*/{ s//\1/; q; } -+ s/.*/./; q'`/stamp-h$_am_stamp_count -+done -+_ACEOF -+cat >>$CONFIG_STATUS <<\_ACEOF -+ -+# -+# CONFIG_COMMANDS section. -+# -+for ac_file in : $CONFIG_COMMANDS; do test "x$ac_file" = x: && continue -+ ac_dest=`echo "$ac_file" | sed 's,:.*,,'` -+ ac_source=`echo "$ac_file" | sed 's,[^:]*:,,'` -+ ac_dir=`(dirname "$ac_dest") 2>/dev/null || -+$as_expr X"$ac_dest" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ -+ X"$ac_dest" : 'X\(//\)[^/]' \| \ -+ X"$ac_dest" : 'X\(//\)$' \| \ -+ X"$ac_dest" : 'X\(/\)' \| \ -+ . : '\(.\)' 2>/dev/null || -+echo X"$ac_dest" | -+ sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } -+ /^X\(\/\/\)[^/].*/{ s//\1/; q; } -+ /^X\(\/\/\)$/{ s//\1/; q; } -+ /^X\(\/\).*/{ s//\1/; q; } -+ s/.*/./; q'` -+ { if $as_mkdir_p; then -+ mkdir -p "$ac_dir" -+ else -+ as_dir="$ac_dir" -+ as_dirs= -+ while test ! -d "$as_dir"; do -+ as_dirs="$as_dir $as_dirs" -+ as_dir=`(dirname "$as_dir") 2>/dev/null || -+$as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ -+ X"$as_dir" : 'X\(//\)[^/]' \| \ -+ X"$as_dir" : 'X\(//\)$' \| \ -+ X"$as_dir" : 'X\(/\)' \| \ -+ . : '\(.\)' 2>/dev/null || -+echo X"$as_dir" | -+ sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } -+ /^X\(\/\/\)[^/].*/{ s//\1/; q; } -+ /^X\(\/\/\)$/{ s//\1/; q; } -+ /^X\(\/\).*/{ s//\1/; q; } -+ s/.*/./; q'` -+ done -+ test ! -n "$as_dirs" || mkdir $as_dirs -+ fi || { { echo "$as_me:$LINENO: error: cannot create directory \"$ac_dir\"" >&5 -+echo "$as_me: error: cannot create directory \"$ac_dir\"" >&2;} -+ { (exit 1); exit 1; }; }; } -+ -+ ac_builddir=. -+ -+if test "$ac_dir" != .; then -+ ac_dir_suffix=/`echo "$ac_dir" | sed 's,^\.[\\/],,'` -+ # A "../" for each directory in $ac_dir_suffix. -+ ac_top_builddir=`echo "$ac_dir_suffix" | sed 's,/[^\\/]*,../,g'` -+else -+ ac_dir_suffix= ac_top_builddir= -+fi -+ -+case $srcdir in -+ .) # No --srcdir option. We are building in place. -+ ac_srcdir=. -+ if test -z "$ac_top_builddir"; then -+ ac_top_srcdir=. -+ else -+ ac_top_srcdir=`echo $ac_top_builddir | sed 's,/$,,'` -+ fi ;; -+ [\\/]* | ?:[\\/]* ) # Absolute path. -+ ac_srcdir=$srcdir$ac_dir_suffix; -+ ac_top_srcdir=$srcdir ;; -+ *) # Relative path. -+ ac_srcdir=$ac_top_builddir$srcdir$ac_dir_suffix -+ ac_top_srcdir=$ac_top_builddir$srcdir ;; -+esac -+ -+# Do not use `cd foo && pwd` to compute absolute paths, because -+# the directories may not exist. -+case `pwd` in -+.) ac_abs_builddir="$ac_dir";; -+*) -+ case "$ac_dir" in -+ .) ac_abs_builddir=`pwd`;; -+ [\\/]* | ?:[\\/]* ) ac_abs_builddir="$ac_dir";; -+ *) ac_abs_builddir=`pwd`/"$ac_dir";; -+ esac;; -+esac -+case $ac_abs_builddir in -+.) ac_abs_top_builddir=${ac_top_builddir}.;; -+*) -+ case ${ac_top_builddir}. in -+ .) ac_abs_top_builddir=$ac_abs_builddir;; -+ [\\/]* | ?:[\\/]* ) ac_abs_top_builddir=${ac_top_builddir}.;; -+ *) ac_abs_top_builddir=$ac_abs_builddir/${ac_top_builddir}.;; -+ esac;; -+esac -+case $ac_abs_builddir in -+.) ac_abs_srcdir=$ac_srcdir;; -+*) -+ case $ac_srcdir in -+ .) ac_abs_srcdir=$ac_abs_builddir;; -+ [\\/]* | ?:[\\/]* ) ac_abs_srcdir=$ac_srcdir;; -+ *) ac_abs_srcdir=$ac_abs_builddir/$ac_srcdir;; -+ esac;; -+esac -+case $ac_abs_builddir in -+.) ac_abs_top_srcdir=$ac_top_srcdir;; -+*) -+ case $ac_top_srcdir in -+ .) ac_abs_top_srcdir=$ac_abs_builddir;; -+ [\\/]* | ?:[\\/]* ) ac_abs_top_srcdir=$ac_top_srcdir;; -+ *) ac_abs_top_srcdir=$ac_abs_builddir/$ac_top_srcdir;; -+ esac;; -+esac -+ -+ -+ { echo "$as_me:$LINENO: executing $ac_dest commands" >&5 -+echo "$as_me: executing $ac_dest commands" >&6;} -+ case $ac_dest in -+ depfiles ) test x"$AMDEP_TRUE" != x"" || for mf in $CONFIG_FILES; do -+ # Strip MF so we end up with the name of the file. -+ mf=`echo "$mf" | sed -e 's/:.*$//'` -+ # Check whether this is an Automake generated Makefile or not. -+ # We used to match only the files named `Makefile.in', but -+ # some people rename them; so instead we look at the file content. -+ # Grep'ing the first line is not enough: some people post-process -+ # each Makefile.in and add a new line on top of each file to say so. -+ # So let's grep whole file. -+ if grep '^#.*generated by automake' $mf > /dev/null 2>&1; then -+ dirpart=`(dirname "$mf") 2>/dev/null || -+$as_expr X"$mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ -+ X"$mf" : 'X\(//\)[^/]' \| \ -+ X"$mf" : 'X\(//\)$' \| \ -+ X"$mf" : 'X\(/\)' \| \ -+ . : '\(.\)' 2>/dev/null || -+echo X"$mf" | -+ sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } -+ /^X\(\/\/\)[^/].*/{ s//\1/; q; } -+ /^X\(\/\/\)$/{ s//\1/; q; } -+ /^X\(\/\).*/{ s//\1/; q; } -+ s/.*/./; q'` -+ else -+ continue -+ fi -+ # Extract the definition of DEPDIR, am__include, and am__quote -+ # from the Makefile without running `make'. -+ DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"` -+ test -z "$DEPDIR" && continue -+ am__include=`sed -n 's/^am__include = //p' < "$mf"` -+ test -z "am__include" && continue -+ am__quote=`sed -n 's/^am__quote = //p' < "$mf"` -+ # When using ansi2knr, U may be empty or an underscore; expand it -+ U=`sed -n 's/^U = //p' < "$mf"` -+ # Find all dependency output files, they are included files with -+ # $(DEPDIR) in their names. We invoke sed twice because it is the -+ # simplest approach to changing $(DEPDIR) to its actual value in the -+ # expansion. -+ for file in `sed -n " -+ s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \ -+ sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g' -e 's/\$U/'"$U"'/g'`; do -+ # Make sure the directory exists. -+ test -f "$dirpart/$file" && continue -+ fdir=`(dirname "$file") 2>/dev/null || -+$as_expr X"$file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ -+ X"$file" : 'X\(//\)[^/]' \| \ -+ X"$file" : 'X\(//\)$' \| \ -+ X"$file" : 'X\(/\)' \| \ -+ . : '\(.\)' 2>/dev/null || -+echo X"$file" | -+ sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } -+ /^X\(\/\/\)[^/].*/{ s//\1/; q; } -+ /^X\(\/\/\)$/{ s//\1/; q; } -+ /^X\(\/\).*/{ s//\1/; q; } -+ s/.*/./; q'` -+ { if $as_mkdir_p; then -+ mkdir -p $dirpart/$fdir -+ else -+ as_dir=$dirpart/$fdir -+ as_dirs= -+ while test ! -d "$as_dir"; do -+ as_dirs="$as_dir $as_dirs" -+ as_dir=`(dirname "$as_dir") 2>/dev/null || -+$as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ -+ X"$as_dir" : 'X\(//\)[^/]' \| \ -+ X"$as_dir" : 'X\(//\)$' \| \ -+ X"$as_dir" : 'X\(/\)' \| \ -+ . : '\(.\)' 2>/dev/null || -+echo X"$as_dir" | -+ sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; } -+ /^X\(\/\/\)[^/].*/{ s//\1/; q; } -+ /^X\(\/\/\)$/{ s//\1/; q; } -+ /^X\(\/\).*/{ s//\1/; q; } -+ s/.*/./; q'` -+ done -+ test ! -n "$as_dirs" || mkdir $as_dirs -+ fi || { { echo "$as_me:$LINENO: error: cannot create directory $dirpart/$fdir" >&5 -+echo "$as_me: error: cannot create directory $dirpart/$fdir" >&2;} -+ { (exit 1); exit 1; }; }; } -+ -+ # echo "creating $dirpart/$file" -+ echo '# dummy' > "$dirpart/$file" -+ done -+done -+ ;; -+ esac -+done -+_ACEOF -+ -+cat >>$CONFIG_STATUS <<\_ACEOF -+ -+{ (exit 0); exit 0; } -+_ACEOF -+chmod +x $CONFIG_STATUS -+ac_clean_files=$ac_clean_files_save -+ -+ -+# configure is writing to config.log, and then calls config.status. -+# config.status does its own redirection, appending to config.log. -+# Unfortunately, on DOS this fails, as config.log is still kept open -+# by configure, so config.status won't be able to write to it; its -+# output is simply discarded. So we exec the FD to /dev/null, -+# effectively closing config.log, so it can be properly (re)opened and -+# appended to by config.status. When coming back to configure, we -+# need to make the FD available again. -+if test "$no_create" != yes; then -+ ac_cs_success=: -+ ac_config_status_args= -+ test "$silent" = yes && -+ ac_config_status_args="$ac_config_status_args --quiet" -+ exec 5>/dev/null -+ $SHELL $CONFIG_STATUS $ac_config_status_args || ac_cs_success=false -+ exec 5>>config.log -+ # Use ||, not &&, to avoid exiting from the if with $? = 1, which -+ # would make configure fail if this is the last instruction. -+ $ac_cs_success || { (exit 1); exit 1; } -+fi -+ -diff --git a/libevent/configure.in b/libevent/configure.in -new file mode 100644 -index 0000000..852d3c5 ---- /dev/null -+++ b/libevent/configure.in -@@ -0,0 +1,385 @@ -+dnl configure.in for libevent -+dnl Dug Song -+AC_INIT(event.c) -+ -+AM_INIT_AUTOMAKE(libevent,1.4.8-stable) -+AM_CONFIG_HEADER(config.h) -+dnl AM_MAINTAINER_MODE -+ -+dnl Initialize prefix. -+if test "$prefix" = "NONE"; then -+ prefix="/usr/local" -+fi -+ -+dnl Checks for programs. -+AC_PROG_CC -+AC_PROG_INSTALL -+AC_PROG_LN_S -+ -+AC_PROG_GCC_TRADITIONAL -+#if test "$GCC" = yes ; then -+# CFLAGS="$CFLAGS -Wall" -+#fi -+ -+AC_ARG_ENABLE(gcc-warnings, -+ AS_HELP_STRING(--enable-gcc-warnings, enable verbose warnings with GCC)) -+ -+AC_PROG_RANLIB -+ -+dnl Uncomment "AC_DISABLE_SHARED" to make shared librraries not get -+dnl built by default. You can also turn shared libs on and off from -+dnl the command line with --enable-shared and --disable-shared. -+dnl AC_DISABLE_SHARED -+dnl AC_SUBST(LIBTOOL_DEPS) -+ -+dnl Checks for libraries. -+AC_CHECK_LIB(socket, socket) -+AC_CHECK_LIB(resolv, inet_aton) -+AC_CHECK_LIB(rt, clock_gettime) -+AC_CHECK_LIB(nsl, inet_ntoa) -+ -+dnl Checks for header files. -+AC_HEADER_STDC -+AC_CHECK_HEADERS(fcntl.h stdarg.h inttypes.h stdint.h poll.h signal.h unistd.h sys/epoll.h sys/time.h sys/queue.h sys/event.h sys/param.h sys/ioctl.h sys/select.h sys/devpoll.h port.h netinet/in6.h sys/socket.h) -+if test "x$ac_cv_header_sys_queue_h" = "xyes"; then -+ AC_MSG_CHECKING(for TAILQ_FOREACH in sys/queue.h) -+ AC_EGREP_CPP(yes, -+[ -+#include -+#ifdef TAILQ_FOREACH -+ yes -+#endif -+], [AC_MSG_RESULT(yes) -+ AC_DEFINE(HAVE_TAILQFOREACH, 1, -+ [Define if TAILQ_FOREACH is defined in ])], -+ AC_MSG_RESULT(no) -+ ) -+fi -+ -+if test "x$ac_cv_header_sys_time_h" = "xyes"; then -+ AC_MSG_CHECKING(for timeradd in sys/time.h) -+ AC_EGREP_CPP(yes, -+[ -+#include -+#ifdef timeradd -+ yes -+#endif -+], [ AC_DEFINE(HAVE_TIMERADD, 1, -+ [Define if timeradd is defined in ]) -+ AC_MSG_RESULT(yes)] ,AC_MSG_RESULT(no) -+) -+fi -+ -+if test "x$ac_cv_header_sys_time_h" = "xyes"; then -+ AC_MSG_CHECKING(for timercmp in sys/time.h) -+ AC_EGREP_CPP(yes, -+[ -+#include -+#ifdef timercmp -+ yes -+#endif -+], [ AC_DEFINE(HAVE_TIMERCMP, 1, -+ [Define if timercmp is defined in ]) -+ AC_MSG_RESULT(yes)] ,AC_MSG_RESULT(no) -+) -+fi -+ -+if test "x$ac_cv_header_sys_time_h" = "xyes"; then -+ AC_MSG_CHECKING(for timerclear in sys/time.h) -+ AC_EGREP_CPP(yes, -+[ -+#include -+#ifdef timerclear -+ yes -+#endif -+], [ AC_DEFINE(HAVE_TIMERCLEAR, 1, -+ [Define if timerclear is defined in ]) -+ AC_MSG_RESULT(yes)] ,AC_MSG_RESULT(no) -+) -+fi -+ -+if test "x$ac_cv_header_sys_time_h" = "xyes"; then -+ AC_MSG_CHECKING(for timerisset in sys/time.h) -+ AC_EGREP_CPP(yes, -+[ -+#include -+#ifdef timerisset -+ yes -+#endif -+], [ AC_DEFINE(HAVE_TIMERISSET, 1, -+ [Define if timerisset is defined in ]) -+ AC_MSG_RESULT(yes)] ,AC_MSG_RESULT(no) -+) -+fi -+ -+dnl - check if the macro WIN32 is defined on this compiler. -+dnl - (this is how we check for a windows version of GCC) -+AC_MSG_CHECKING(for WIN32) -+AC_TRY_COMPILE(, -+ [ -+#ifndef WIN32 -+die horribly -+#endif -+ ], -+ bwin32=true; AC_MSG_RESULT(yes), -+ bwin32=false; AC_MSG_RESULT(no), -+) -+ -+AM_CONDITIONAL(BUILD_WIN32, test x$bwin32 = xtrue) -+ -+dnl Checks for typedefs, structures, and compiler characteristics. -+AC_C_CONST -+AC_C_INLINE -+AC_HEADER_TIME -+ -+dnl Checks for library functions. -+AC_CHECK_FUNCS(gettimeofday vasprintf fcntl clock_gettime strtok_r strsep getaddrinfo getnameinfo strlcpy inet_ntop signal sigaction strtoll) -+ -+AC_CHECK_SIZEOF(long) -+ -+if test "x$ac_cv_func_clock_gettime" = "xyes"; then -+ AC_DEFINE(DNS_USE_CPU_CLOCK_FOR_ID, 1, [Define if clock_gettime is available in libc]) -+else -+ AC_DEFINE(DNS_USE_GETTIMEOFDAY_FOR_ID, 1, [Define is no secure id variant is available]) -+fi -+ -+AC_MSG_CHECKING(for F_SETFD in fcntl.h) -+AC_EGREP_CPP(yes, -+[ -+#define _GNU_SOURCE -+#include -+#ifdef F_SETFD -+yes -+#endif -+], [ AC_DEFINE(HAVE_SETFD, 1, -+ [Define if F_SETFD is defined in ]) -+ AC_MSG_RESULT(yes) ], AC_MSG_RESULT(no)) -+ -+needsignal=no -+haveselect=no -+AC_CHECK_FUNCS(select, [haveselect=yes], ) -+if test "x$haveselect" = "xyes" ; then -+ AC_LIBOBJ(select) -+ needsignal=yes -+fi -+ -+havepoll=no -+AC_CHECK_FUNCS(poll, [havepoll=yes], ) -+if test "x$havepoll" = "xyes" ; then -+ AC_LIBOBJ(poll) -+ needsignal=yes -+fi -+ -+haveepoll=no -+AC_CHECK_FUNCS(epoll_ctl, [haveepoll=yes], ) -+if test "x$haveepoll" = "xyes" ; then -+ AC_DEFINE(HAVE_EPOLL, 1, -+ [Define if your system supports the epoll system calls]) -+ AC_LIBOBJ(epoll) -+ needsignal=yes -+fi -+ -+havedevpoll=no -+if test "x$ac_cv_header_sys_devpoll_h" = "xyes"; then -+ AC_DEFINE(HAVE_DEVPOLL, 1, -+ [Define if /dev/poll is available]) -+ AC_LIBOBJ(devpoll) -+fi -+ -+havekqueue=no -+if test "x$ac_cv_header_sys_event_h" = "xyes"; then -+ AC_CHECK_FUNCS(kqueue, [havekqueue=yes], ) -+ if test "x$havekqueue" = "xyes" ; then -+ AC_MSG_CHECKING(for working kqueue) -+ AC_TRY_RUN( -+#include -+#include -+#include -+#include -+#include -+#include -+ -+int -+main(int argc, char **argv) -+{ -+ int kq; -+ int n; -+ int fd[[2]]; -+ struct kevent ev; -+ struct timespec ts; -+ char buf[[8000]]; -+ -+ if (pipe(fd) == -1) -+ exit(1); -+ if (fcntl(fd[[1]], F_SETFL, O_NONBLOCK) == -1) -+ exit(1); -+ -+ while ((n = write(fd[[1]], buf, sizeof(buf))) == sizeof(buf)) -+ ; -+ -+ if ((kq = kqueue()) == -1) -+ exit(1); -+ -+ ev.ident = fd[[1]]; -+ ev.filter = EVFILT_WRITE; -+ ev.flags = EV_ADD | EV_ENABLE; -+ n = kevent(kq, &ev, 1, NULL, 0, NULL); -+ if (n == -1) -+ exit(1); -+ -+ read(fd[[0]], buf, sizeof(buf)); -+ -+ ts.tv_sec = 0; -+ ts.tv_nsec = 0; -+ n = kevent(kq, NULL, 0, &ev, 1, &ts); -+ if (n == -1 || n == 0) -+ exit(1); -+ -+ exit(0); -+}, [AC_MSG_RESULT(yes) -+ AC_DEFINE(HAVE_WORKING_KQUEUE, 1, -+ [Define if kqueue works correctly with pipes]) -+ AC_LIBOBJ(kqueue)], AC_MSG_RESULT(no), AC_MSG_RESULT(no)) -+ fi -+fi -+ -+haveepollsyscall=no -+if test "x$ac_cv_header_sys_epoll_h" = "xyes"; then -+ if test "x$haveepoll" = "xno" ; then -+ AC_MSG_CHECKING(for epoll system call) -+ AC_TRY_RUN( -+#include -+#include -+#include -+#include -+#include -+#include -+ -+int -+epoll_create(int size) -+{ -+ return (syscall(__NR_epoll_create, size)); -+} -+ -+int -+main(int argc, char **argv) -+{ -+ int epfd; -+ -+ epfd = epoll_create(256); -+ exit (epfd == -1 ? 1 : 0); -+}, [AC_MSG_RESULT(yes) -+ AC_DEFINE(HAVE_EPOLL, 1, -+ [Define if your system supports the epoll system calls]) -+ needsignal=yes -+ AC_LIBOBJ(epoll_sub) -+ AC_LIBOBJ(epoll)], AC_MSG_RESULT(no), AC_MSG_RESULT(no)) -+ fi -+fi -+ -+haveeventports=no -+AC_CHECK_FUNCS(port_create, [haveeventports=yes], ) -+if test "x$haveeventports" = "xyes" ; then -+ AC_DEFINE(HAVE_EVENT_PORTS, 1, -+ [Define if your system supports event ports]) -+ AC_LIBOBJ(evport) -+ needsignal=yes -+fi -+if test "x$bwin32" = "xtrue"; then -+ needsignal=yes -+fi -+if test "x$bwin32" = "xtrue"; then -+ needsignal=yes -+fi -+if test "x$needsignal" = "xyes" ; then -+ AC_LIBOBJ(signal) -+fi -+ -+AC_TYPE_PID_T -+AC_TYPE_SIZE_T -+AC_CHECK_TYPES([uint64_t, uint32_t, uint16_t, uint8_t], , , -+[#ifdef HAVE_STDINT_H -+#include -+#elif defined(HAVE_INTTYPES_H) -+#include -+#endif -+#ifdef HAVE_SYS_TYPES_H -+#include -+#endif]) -+AC_CHECK_SIZEOF(long long) -+AC_CHECK_SIZEOF(long) -+AC_CHECK_SIZEOF(int) -+AC_CHECK_SIZEOF(short) -+AC_CHECK_TYPES([struct in6_addr], , , -+[#ifdef WIN32 -+#include -+#else -+#include -+#include -+#include -+#endif -+#ifdef HAVE_NETINET_IN6_H -+#include -+#endif]) -+ -+AC_MSG_CHECKING([for socklen_t]) -+AC_TRY_COMPILE([ -+ #include -+ #include ], -+ [socklen_t x;], -+ AC_MSG_RESULT([yes]), -+ [AC_MSG_RESULT([no]) -+ AC_DEFINE(socklen_t, unsigned int, -+ [Define to unsigned int if you dont have it])] -+) -+ -+AC_MSG_CHECKING([whether our compiler supports __func__]) -+AC_TRY_COMPILE([], -+ [ const char *cp = __func__; ], -+ AC_MSG_RESULT([yes]), -+ AC_MSG_RESULT([no]) -+ AC_MSG_CHECKING([whether our compiler supports __FUNCTION__]) -+ AC_TRY_COMPILE([], -+ [ const char *cp = __FUNCTION__; ], -+ AC_MSG_RESULT([yes]) -+ AC_DEFINE(__func__, __FUNCTION__, -+ [Define to appropriate substitue if compiler doesnt have __func__]), -+ AC_MSG_RESULT([no]) -+ AC_DEFINE(__func__, __FILE__, -+ [Define to appropriate substitue if compiler doesnt have __func__]))) -+ -+ -+# Add some more warnings which we use in development but not in the -+# released versions. (Some relevant gcc versions can't handle these.) -+if test x$enable_gcc_warnings = xyes; then -+ -+ AC_COMPILE_IFELSE(AC_LANG_PROGRAM([], [ -+#if !defined(__GNUC__) || (__GNUC__ < 4) -+#error -+#endif]), have_gcc4=yes, have_gcc4=no) -+ -+ AC_COMPILE_IFELSE(AC_LANG_PROGRAM([], [ -+#if !defined(__GNUC__) || (__GNUC__ < 4) || (__GNUC__ == 4 && __GNUC_MINOR__ < 2) -+#error -+#endif]), have_gcc42=yes, have_gcc42=no) -+ -+ CFLAGS="$CFLAGS -W -Wfloat-equal -Wundef -Wpointer-arith -Wstrict-prototypes -Wmissing-prototypes -Wwrite-strings -Wredundant-decls -Wchar-subscripts -Wcomment -Wformat=2 -Wwrite-strings -Wmissing-declarations -Wredundant-decls -Wnested-externs -Wbad-function-cast -Wswitch-enum -Werror" -+ CFLAGS="$CFLAGS -Wno-unused-parameter -Wno-sign-compare -Wstrict-aliasing" -+ -+ if test x$have_gcc4 = xyes ; then -+ # These warnings break gcc 3.3.5 and work on gcc 4.0.2 -+ CFLAGS="$CFLAGS -Winit-self -Wmissing-field-initializers -Wdeclaration-after-statement" -+ #CFLAGS="$CFLAGS -Wold-style-definition" -+ fi -+ -+ if test x$have_gcc42 = xyes ; then -+ # These warnings break gcc 4.0.2 and work on gcc 4.2 -+ CFLAGS="$CFLAGS -Waddress -Wnormalized=id -Woverride-init" -+ fi -+ -+##This will break the world on some 64-bit architectures -+# CFLAGS="$CFLAGS -Winline" -+ -+fi -+ -+AC_OUTPUT(Makefile) -diff --git a/libevent/depcomp b/libevent/depcomp -new file mode 100644 -index 0000000..ffcd540 ---- /dev/null -+++ b/libevent/depcomp -@@ -0,0 +1,529 @@ -+#! /bin/sh -+# depcomp - compile a program generating dependencies as side-effects -+ -+scriptversion=2005-02-09.22 -+ -+# Copyright (C) 1999, 2000, 2003, 2004, 2005 Free Software Foundation, Inc. -+ -+# 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, 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. -+ -+# You should have received a copy of the GNU General Public License -+# along with this program; if not, write to the Free Software -+# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA -+# 02111-1307, USA. -+ -+# As a special exception to the GNU General Public License, if you -+# distribute this file as part of a program that contains a -+# configuration script generated by Autoconf, you may include it under -+# the same distribution terms that you use for the rest of that program. -+ -+# Originally written by Alexandre Oliva . -+ -+case $1 in -+ '') -+ echo "$0: No command. Try \`$0 --help' for more information." 1>&2 -+ exit 1; -+ ;; -+ -h | --h*) -+ cat <<\EOF -+Usage: depcomp [--help] [--version] PROGRAM [ARGS] -+ -+Run PROGRAMS ARGS to compile a file, generating dependencies -+as side-effects. -+ -+Environment variables: -+ depmode Dependency tracking mode. -+ source Source file read by `PROGRAMS ARGS'. -+ object Object file output by `PROGRAMS ARGS'. -+ DEPDIR directory where to store dependencies. -+ depfile Dependency file to output. -+ tmpdepfile Temporary file to use when outputing dependencies. -+ libtool Whether libtool is used (yes/no). -+ -+Report bugs to . -+EOF -+ exit $? -+ ;; -+ -v | --v*) -+ echo "depcomp $scriptversion" -+ exit $? -+ ;; -+esac -+ -+if test -z "$depmode" || test -z "$source" || test -z "$object"; then -+ echo "depcomp: Variables source, object and depmode must be set" 1>&2 -+ exit 1 -+fi -+ -+# Dependencies for sub/bar.o or sub/bar.obj go into sub/.deps/bar.Po. -+depfile=${depfile-`echo "$object" | -+ sed 's|[^\\/]*$|'${DEPDIR-.deps}'/&|;s|\.\([^.]*\)$|.P\1|;s|Pobj$|Po|'`} -+tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`} -+ -+rm -f "$tmpdepfile" -+ -+# Some modes work just like other modes, but use different flags. We -+# parameterize here, but still list the modes in the big case below, -+# to make depend.m4 easier to write. Note that we *cannot* use a case -+# here, because this file can only contain one case statement. -+if test "$depmode" = hp; then -+ # HP compiler uses -M and no extra arg. -+ gccflag=-M -+ depmode=gcc -+fi -+ -+if test "$depmode" = dashXmstdout; then -+ # This is just like dashmstdout with a different argument. -+ dashmflag=-xM -+ depmode=dashmstdout -+fi -+ -+case "$depmode" in -+gcc3) -+## gcc 3 implements dependency tracking that does exactly what -+## we want. Yay! Note: for some reason libtool 1.4 doesn't like -+## it if -MD -MP comes after the -MF stuff. Hmm. -+ "$@" -MT "$object" -MD -MP -MF "$tmpdepfile" -+ stat=$? -+ if test $stat -eq 0; then : -+ else -+ rm -f "$tmpdepfile" -+ exit $stat -+ fi -+ mv "$tmpdepfile" "$depfile" -+ ;; -+ -+gcc) -+## There are various ways to get dependency output from gcc. Here's -+## why we pick this rather obscure method: -+## - Don't want to use -MD because we'd like the dependencies to end -+## up in a subdir. Having to rename by hand is ugly. -+## (We might end up doing this anyway to support other compilers.) -+## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like -+## -MM, not -M (despite what the docs say). -+## - Using -M directly means running the compiler twice (even worse -+## than renaming). -+ if test -z "$gccflag"; then -+ gccflag=-MD, -+ fi -+ "$@" -Wp,"$gccflag$tmpdepfile" -+ stat=$? -+ if test $stat -eq 0; then : -+ else -+ rm -f "$tmpdepfile" -+ exit $stat -+ fi -+ rm -f "$depfile" -+ echo "$object : \\" > "$depfile" -+ alpha=ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz -+## The second -e expression handles DOS-style file names with drive letters. -+ sed -e 's/^[^:]*: / /' \ -+ -e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile" -+## This next piece of magic avoids the `deleted header file' problem. -+## The problem is that when a header file which appears in a .P file -+## is deleted, the dependency causes make to die (because there is -+## typically no way to rebuild the header). We avoid this by adding -+## dummy dependencies for each header file. Too bad gcc doesn't do -+## this for us directly. -+ tr ' ' ' -+' < "$tmpdepfile" | -+## Some versions of gcc put a space before the `:'. On the theory -+## that the space means something, we add a space to the output as -+## well. -+## Some versions of the HPUX 10.20 sed can't process this invocation -+## correctly. Breaking it into two sed invocations is a workaround. -+ sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile" -+ rm -f "$tmpdepfile" -+ ;; -+ -+hp) -+ # This case exists only to let depend.m4 do its work. It works by -+ # looking at the text of this script. This case will never be run, -+ # since it is checked for above. -+ exit 1 -+ ;; -+ -+sgi) -+ if test "$libtool" = yes; then -+ "$@" "-Wp,-MDupdate,$tmpdepfile" -+ else -+ "$@" -MDupdate "$tmpdepfile" -+ fi -+ stat=$? -+ if test $stat -eq 0; then : -+ else -+ rm -f "$tmpdepfile" -+ exit $stat -+ fi -+ rm -f "$depfile" -+ -+ if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files -+ echo "$object : \\" > "$depfile" -+ -+ # Clip off the initial element (the dependent). Don't try to be -+ # clever and replace this with sed code, as IRIX sed won't handle -+ # lines with more than a fixed number of characters (4096 in -+ # IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines; -+ # the IRIX cc adds comments like `#:fec' to the end of the -+ # dependency line. -+ tr ' ' ' -+' < "$tmpdepfile" \ -+ | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' | \ -+ tr ' -+' ' ' >> $depfile -+ echo >> $depfile -+ -+ # The second pass generates a dummy entry for each header file. -+ tr ' ' ' -+' < "$tmpdepfile" \ -+ | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \ -+ >> $depfile -+ else -+ # The sourcefile does not contain any dependencies, so just -+ # store a dummy comment line, to avoid errors with the Makefile -+ # "include basename.Plo" scheme. -+ echo "#dummy" > "$depfile" -+ fi -+ rm -f "$tmpdepfile" -+ ;; -+ -+aix) -+ # The C for AIX Compiler uses -M and outputs the dependencies -+ # in a .u file. In older versions, this file always lives in the -+ # current directory. Also, the AIX compiler puts `$object:' at the -+ # start of each line; $object doesn't have directory information. -+ # Version 6 uses the directory in both cases. -+ stripped=`echo "$object" | sed 's/\(.*\)\..*$/\1/'` -+ tmpdepfile="$stripped.u" -+ if test "$libtool" = yes; then -+ "$@" -Wc,-M -+ else -+ "$@" -M -+ fi -+ stat=$? -+ -+ if test -f "$tmpdepfile"; then : -+ else -+ stripped=`echo "$stripped" | sed 's,^.*/,,'` -+ tmpdepfile="$stripped.u" -+ fi -+ -+ if test $stat -eq 0; then : -+ else -+ rm -f "$tmpdepfile" -+ exit $stat -+ fi -+ -+ if test -f "$tmpdepfile"; then -+ outname="$stripped.o" -+ # Each line is of the form `foo.o: dependent.h'. -+ # Do two passes, one to just change these to -+ # `$object: dependent.h' and one to simply `dependent.h:'. -+ sed -e "s,^$outname:,$object :," < "$tmpdepfile" > "$depfile" -+ sed -e "s,^$outname: \(.*\)$,\1:," < "$tmpdepfile" >> "$depfile" -+ else -+ # The sourcefile does not contain any dependencies, so just -+ # store a dummy comment line, to avoid errors with the Makefile -+ # "include basename.Plo" scheme. -+ echo "#dummy" > "$depfile" -+ fi -+ rm -f "$tmpdepfile" -+ ;; -+ -+icc) -+ # Intel's C compiler understands `-MD -MF file'. However on -+ # icc -MD -MF foo.d -c -o sub/foo.o sub/foo.c -+ # ICC 7.0 will fill foo.d with something like -+ # foo.o: sub/foo.c -+ # foo.o: sub/foo.h -+ # which is wrong. We want: -+ # sub/foo.o: sub/foo.c -+ # sub/foo.o: sub/foo.h -+ # sub/foo.c: -+ # sub/foo.h: -+ # ICC 7.1 will output -+ # foo.o: sub/foo.c sub/foo.h -+ # and will wrap long lines using \ : -+ # foo.o: sub/foo.c ... \ -+ # sub/foo.h ... \ -+ # ... -+ -+ "$@" -MD -MF "$tmpdepfile" -+ stat=$? -+ if test $stat -eq 0; then : -+ else -+ rm -f "$tmpdepfile" -+ exit $stat -+ fi -+ rm -f "$depfile" -+ # Each line is of the form `foo.o: dependent.h', -+ # or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'. -+ # Do two passes, one to just change these to -+ # `$object: dependent.h' and one to simply `dependent.h:'. -+ sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile" -+ # Some versions of the HPUX 10.20 sed can't process this invocation -+ # correctly. Breaking it into two sed invocations is a workaround. -+ sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" | -+ sed -e 's/$/ :/' >> "$depfile" -+ rm -f "$tmpdepfile" -+ ;; -+ -+tru64) -+ # The Tru64 compiler uses -MD to generate dependencies as a side -+ # effect. `cc -MD -o foo.o ...' puts the dependencies into `foo.o.d'. -+ # At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put -+ # dependencies in `foo.d' instead, so we check for that too. -+ # Subdirectories are respected. -+ dir=`echo "$object" | sed -e 's|/[^/]*$|/|'` -+ test "x$dir" = "x$object" && dir= -+ base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'` -+ -+ if test "$libtool" = yes; then -+ # With Tru64 cc, shared objects can also be used to make a -+ # static library. This mecanism is used in libtool 1.4 series to -+ # handle both shared and static libraries in a single compilation. -+ # With libtool 1.4, dependencies were output in $dir.libs/$base.lo.d. -+ # -+ # With libtool 1.5 this exception was removed, and libtool now -+ # generates 2 separate objects for the 2 libraries. These two -+ # compilations output dependencies in in $dir.libs/$base.o.d and -+ # in $dir$base.o.d. We have to check for both files, because -+ # one of the two compilations can be disabled. We should prefer -+ # $dir$base.o.d over $dir.libs/$base.o.d because the latter is -+ # automatically cleaned when .libs/ is deleted, while ignoring -+ # the former would cause a distcleancheck panic. -+ tmpdepfile1=$dir.libs/$base.lo.d # libtool 1.4 -+ tmpdepfile2=$dir$base.o.d # libtool 1.5 -+ tmpdepfile3=$dir.libs/$base.o.d # libtool 1.5 -+ tmpdepfile4=$dir.libs/$base.d # Compaq CCC V6.2-504 -+ "$@" -Wc,-MD -+ else -+ tmpdepfile1=$dir$base.o.d -+ tmpdepfile2=$dir$base.d -+ tmpdepfile3=$dir$base.d -+ tmpdepfile4=$dir$base.d -+ "$@" -MD -+ fi -+ -+ stat=$? -+ if test $stat -eq 0; then : -+ else -+ rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" "$tmpdepfile4" -+ exit $stat -+ fi -+ -+ for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" "$tmpdepfile4" -+ do -+ test -f "$tmpdepfile" && break -+ done -+ if test -f "$tmpdepfile"; then -+ sed -e "s,^.*\.[a-z]*:,$object:," < "$tmpdepfile" > "$depfile" -+ # That's a tab and a space in the []. -+ sed -e 's,^.*\.[a-z]*:[ ]*,,' -e 's,$,:,' < "$tmpdepfile" >> "$depfile" -+ else -+ echo "#dummy" > "$depfile" -+ fi -+ rm -f "$tmpdepfile" -+ ;; -+ -+#nosideeffect) -+ # This comment above is used by automake to tell side-effect -+ # dependency tracking mechanisms from slower ones. -+ -+dashmstdout) -+ # Important note: in order to support this mode, a compiler *must* -+ # always write the preprocessed file to stdout, regardless of -o. -+ "$@" || exit $? -+ -+ # Remove the call to Libtool. -+ if test "$libtool" = yes; then -+ while test $1 != '--mode=compile'; do -+ shift -+ done -+ shift -+ fi -+ -+ # Remove `-o $object'. -+ IFS=" " -+ for arg -+ do -+ case $arg in -+ -o) -+ shift -+ ;; -+ $object) -+ shift -+ ;; -+ *) -+ set fnord "$@" "$arg" -+ shift # fnord -+ shift # $arg -+ ;; -+ esac -+ done -+ -+ test -z "$dashmflag" && dashmflag=-M -+ # Require at least two characters before searching for `:' -+ # in the target name. This is to cope with DOS-style filenames: -+ # a dependency such as `c:/foo/bar' could be seen as target `c' otherwise. -+ "$@" $dashmflag | -+ sed 's:^[ ]*[^: ][^:][^:]*\:[ ]*:'"$object"'\: :' > "$tmpdepfile" -+ rm -f "$depfile" -+ cat < "$tmpdepfile" > "$depfile" -+ tr ' ' ' -+' < "$tmpdepfile" | \ -+## Some versions of the HPUX 10.20 sed can't process this invocation -+## correctly. Breaking it into two sed invocations is a workaround. -+ sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile" -+ rm -f "$tmpdepfile" -+ ;; -+ -+dashXmstdout) -+ # This case only exists to satisfy depend.m4. It is never actually -+ # run, as this mode is specially recognized in the preamble. -+ exit 1 -+ ;; -+ -+makedepend) -+ "$@" || exit $? -+ # Remove any Libtool call -+ if test "$libtool" = yes; then -+ while test $1 != '--mode=compile'; do -+ shift -+ done -+ shift -+ fi -+ # X makedepend -+ shift -+ cleared=no -+ for arg in "$@"; do -+ case $cleared in -+ no) -+ set ""; shift -+ cleared=yes ;; -+ esac -+ case "$arg" in -+ -D*|-I*) -+ set fnord "$@" "$arg"; shift ;; -+ # Strip any option that makedepend may not understand. Remove -+ # the object too, otherwise makedepend will parse it as a source file. -+ -*|$object) -+ ;; -+ *) -+ set fnord "$@" "$arg"; shift ;; -+ esac -+ done -+ obj_suffix="`echo $object | sed 's/^.*\././'`" -+ touch "$tmpdepfile" -+ ${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@" -+ rm -f "$depfile" -+ cat < "$tmpdepfile" > "$depfile" -+ sed '1,2d' "$tmpdepfile" | tr ' ' ' -+' | \ -+## Some versions of the HPUX 10.20 sed can't process this invocation -+## correctly. Breaking it into two sed invocations is a workaround. -+ sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile" -+ rm -f "$tmpdepfile" "$tmpdepfile".bak -+ ;; -+ -+cpp) -+ # Important note: in order to support this mode, a compiler *must* -+ # always write the preprocessed file to stdout. -+ "$@" || exit $? -+ -+ # Remove the call to Libtool. -+ if test "$libtool" = yes; then -+ while test $1 != '--mode=compile'; do -+ shift -+ done -+ shift -+ fi -+ -+ # Remove `-o $object'. -+ IFS=" " -+ for arg -+ do -+ case $arg in -+ -o) -+ shift -+ ;; -+ $object) -+ shift -+ ;; -+ *) -+ set fnord "$@" "$arg" -+ shift # fnord -+ shift # $arg -+ ;; -+ esac -+ done -+ -+ "$@" -E | -+ sed -n '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' | -+ sed '$ s: \\$::' > "$tmpdepfile" -+ rm -f "$depfile" -+ echo "$object : \\" > "$depfile" -+ cat < "$tmpdepfile" >> "$depfile" -+ sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile" -+ rm -f "$tmpdepfile" -+ ;; -+ -+msvisualcpp) -+ # Important note: in order to support this mode, a compiler *must* -+ # always write the preprocessed file to stdout, regardless of -o, -+ # because we must use -o when running libtool. -+ "$@" || exit $? -+ IFS=" " -+ for arg -+ do -+ case "$arg" in -+ "-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI") -+ set fnord "$@" -+ shift -+ shift -+ ;; -+ *) -+ set fnord "$@" "$arg" -+ shift -+ shift -+ ;; -+ esac -+ done -+ "$@" -E | -+ sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::echo "`cygpath -u \\"\1\\"`":p' | sort | uniq > "$tmpdepfile" -+ rm -f "$depfile" -+ echo "$object : \\" > "$depfile" -+ . "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s:: \1 \\:p' >> "$depfile" -+ echo " " >> "$depfile" -+ . "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s::\1\::p' >> "$depfile" -+ rm -f "$tmpdepfile" -+ ;; -+ -+none) -+ exec "$@" -+ ;; -+ -+*) -+ echo "Unknown depmode $depmode" 1>&2 -+ exit 1 -+ ;; -+esac -+ -+exit 0 -+ -+# Local Variables: -+# mode: shell-script -+# sh-indentation: 2 -+# eval: (add-hook 'write-file-hooks 'time-stamp) -+# time-stamp-start: "scriptversion=" -+# time-stamp-format: "%:y-%02m-%02d.%02H" -+# time-stamp-end: "$" -+# End: -diff --git a/libevent/devpoll.c b/libevent/devpoll.c -new file mode 100644 -index 0000000..cbd2730 ---- /dev/null -+++ b/libevent/devpoll.c -@@ -0,0 +1,417 @@ -+/* -+ * Copyright 2000-2004 Niels Provos -+ * All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. The name of the author may not be used to endorse or promote products -+ * derived from this software without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR -+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES -+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. -+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, -+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT -+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF -+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+ */ -+#ifdef HAVE_CONFIG_H -+#include "config.h" -+#endif -+ -+#include -+#include -+#ifdef HAVE_SYS_TIME_H -+#include -+#else -+#include -+#endif -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+ -+#include "event.h" -+#include "event-internal.h" -+#include "evsignal.h" -+#include "log.h" -+ -+/* due to limitations in the devpoll interface, we need to keep track of -+ * all file descriptors outself. -+ */ -+struct evdevpoll { -+ struct event *evread; -+ struct event *evwrite; -+}; -+ -+struct devpollop { -+ struct evdevpoll *fds; -+ int nfds; -+ struct pollfd *events; -+ int nevents; -+ int dpfd; -+ struct pollfd *changes; -+ int nchanges; -+}; -+ -+static void *devpoll_init (struct event_base *); -+static int devpoll_add (void *, struct event *); -+static int devpoll_del (void *, struct event *); -+static int devpoll_dispatch (struct event_base *, void *, struct timeval *); -+static void devpoll_dealloc (struct event_base *, void *); -+ -+const struct eventop devpollops = { -+ "devpoll", -+ devpoll_init, -+ devpoll_add, -+ devpoll_del, -+ devpoll_dispatch, -+ devpoll_dealloc, -+ 1 /* need reinit */ -+}; -+ -+#define NEVENT 32000 -+ -+static int -+devpoll_commit(struct devpollop *devpollop) -+{ -+ /* -+ * Due to a bug in Solaris, we have to use pwrite with an offset of 0. -+ * Write is limited to 2GB of data, until it will fail. -+ */ -+ if (pwrite(devpollop->dpfd, devpollop->changes, -+ sizeof(struct pollfd) * devpollop->nchanges, 0) == -1) -+ return(-1); -+ -+ devpollop->nchanges = 0; -+ return(0); -+} -+ -+static int -+devpoll_queue(struct devpollop *devpollop, int fd, int events) { -+ struct pollfd *pfd; -+ -+ if (devpollop->nchanges >= devpollop->nevents) { -+ /* -+ * Change buffer is full, must commit it to /dev/poll before -+ * adding more -+ */ -+ if (devpoll_commit(devpollop) != 0) -+ return(-1); -+ } -+ -+ pfd = &devpollop->changes[devpollop->nchanges++]; -+ pfd->fd = fd; -+ pfd->events = events; -+ pfd->revents = 0; -+ -+ return(0); -+} -+ -+static void * -+devpoll_init(struct event_base *base) -+{ -+ int dpfd, nfiles = NEVENT; -+ struct rlimit rl; -+ struct devpollop *devpollop; -+ -+ /* Disable devpoll when this environment variable is set */ -+ if (getenv("EVENT_NODEVPOLL")) -+ return (NULL); -+ -+ if (!(devpollop = calloc(1, sizeof(struct devpollop)))) -+ return (NULL); -+ -+ if (getrlimit(RLIMIT_NOFILE, &rl) == 0 && -+ rl.rlim_cur != RLIM_INFINITY) -+ nfiles = rl.rlim_cur; -+ -+ /* Initialize the kernel queue */ -+ if ((dpfd = open("/dev/poll", O_RDWR)) == -1) { -+ event_warn("open: /dev/poll"); -+ free(devpollop); -+ return (NULL); -+ } -+ -+ devpollop->dpfd = dpfd; -+ -+ /* Initialize fields */ -+ devpollop->events = calloc(nfiles, sizeof(struct pollfd)); -+ if (devpollop->events == NULL) { -+ free(devpollop); -+ close(dpfd); -+ return (NULL); -+ } -+ devpollop->nevents = nfiles; -+ -+ devpollop->fds = calloc(nfiles, sizeof(struct evdevpoll)); -+ if (devpollop->fds == NULL) { -+ free(devpollop->events); -+ free(devpollop); -+ close(dpfd); -+ return (NULL); -+ } -+ devpollop->nfds = nfiles; -+ -+ devpollop->changes = calloc(nfiles, sizeof(struct pollfd)); -+ if (devpollop->changes == NULL) { -+ free(devpollop->fds); -+ free(devpollop->events); -+ free(devpollop); -+ close(dpfd); -+ return (NULL); -+ } -+ -+ evsignal_init(base); -+ -+ return (devpollop); -+} -+ -+static int -+devpoll_recalc(struct event_base *base, void *arg, int max) -+{ -+ struct devpollop *devpollop = arg; -+ -+ if (max >= devpollop->nfds) { -+ struct evdevpoll *fds; -+ int nfds; -+ -+ nfds = devpollop->nfds; -+ while (nfds <= max) -+ nfds <<= 1; -+ -+ fds = realloc(devpollop->fds, nfds * sizeof(struct evdevpoll)); -+ if (fds == NULL) { -+ event_warn("realloc"); -+ return (-1); -+ } -+ devpollop->fds = fds; -+ memset(fds + devpollop->nfds, 0, -+ (nfds - devpollop->nfds) * sizeof(struct evdevpoll)); -+ devpollop->nfds = nfds; -+ } -+ -+ return (0); -+} -+ -+static int -+devpoll_dispatch(struct event_base *base, void *arg, struct timeval *tv) -+{ -+ struct devpollop *devpollop = arg; -+ struct pollfd *events = devpollop->events; -+ struct dvpoll dvp; -+ struct evdevpoll *evdp; -+ int i, res, timeout = -1; -+ -+ if (devpollop->nchanges) -+ devpoll_commit(devpollop); -+ -+ if (tv != NULL) -+ timeout = tv->tv_sec * 1000 + (tv->tv_usec + 999) / 1000; -+ -+ dvp.dp_fds = devpollop->events; -+ dvp.dp_nfds = devpollop->nevents; -+ dvp.dp_timeout = timeout; -+ -+ res = ioctl(devpollop->dpfd, DP_POLL, &dvp); -+ -+ if (res == -1) { -+ if (errno != EINTR) { -+ event_warn("ioctl: DP_POLL"); -+ return (-1); -+ } -+ -+ evsignal_process(base); -+ return (0); -+ } else if (base->sig.evsignal_caught) { -+ evsignal_process(base); -+ } -+ -+ event_debug(("%s: devpoll_wait reports %d", __func__, res)); -+ -+ for (i = 0; i < res; i++) { -+ int which = 0; -+ int what = events[i].revents; -+ struct event *evread = NULL, *evwrite = NULL; -+ -+ assert(events[i].fd < devpollop->nfds); -+ evdp = &devpollop->fds[events[i].fd]; -+ -+ if (what & POLLHUP) -+ what |= POLLIN | POLLOUT; -+ else if (what & POLLERR) -+ what |= POLLIN | POLLOUT; -+ -+ if (what & POLLIN) { -+ evread = evdp->evread; -+ which |= EV_READ; -+ } -+ -+ if (what & POLLOUT) { -+ evwrite = evdp->evwrite; -+ which |= EV_WRITE; -+ } -+ -+ if (!which) -+ continue; -+ -+ if (evread != NULL && !(evread->ev_events & EV_PERSIST)) -+ event_del(evread); -+ if (evwrite != NULL && evwrite != evread && -+ !(evwrite->ev_events & EV_PERSIST)) -+ event_del(evwrite); -+ -+ if (evread != NULL) -+ event_active(evread, EV_READ, 1); -+ if (evwrite != NULL) -+ event_active(evwrite, EV_WRITE, 1); -+ } -+ -+ return (0); -+} -+ -+ -+static int -+devpoll_add(void *arg, struct event *ev) -+{ -+ struct devpollop *devpollop = arg; -+ struct evdevpoll *evdp; -+ int fd, events; -+ -+ if (ev->ev_events & EV_SIGNAL) -+ return (evsignal_add(ev)); -+ -+ fd = ev->ev_fd; -+ if (fd >= devpollop->nfds) { -+ /* Extend the file descriptor array as necessary */ -+ if (devpoll_recalc(ev->ev_base, devpollop, fd) == -1) -+ return (-1); -+ } -+ evdp = &devpollop->fds[fd]; -+ -+ /* -+ * It's not necessary to OR the existing read/write events that we -+ * are currently interested in with the new event we are adding. -+ * The /dev/poll driver ORs any new events with the existing events -+ * that it has cached for the fd. -+ */ -+ -+ events = 0; -+ if (ev->ev_events & EV_READ) { -+ if (evdp->evread && evdp->evread != ev) { -+ /* There is already a different read event registered */ -+ return(-1); -+ } -+ events |= POLLIN; -+ } -+ -+ if (ev->ev_events & EV_WRITE) { -+ if (evdp->evwrite && evdp->evwrite != ev) { -+ /* There is already a different write event registered */ -+ return(-1); -+ } -+ events |= POLLOUT; -+ } -+ -+ if (devpoll_queue(devpollop, fd, events) != 0) -+ return(-1); -+ -+ /* Update events responsible */ -+ if (ev->ev_events & EV_READ) -+ evdp->evread = ev; -+ if (ev->ev_events & EV_WRITE) -+ evdp->evwrite = ev; -+ -+ return (0); -+} -+ -+static int -+devpoll_del(void *arg, struct event *ev) -+{ -+ struct devpollop *devpollop = arg; -+ struct evdevpoll *evdp; -+ int fd, events; -+ int needwritedelete = 1, needreaddelete = 1; -+ -+ if (ev->ev_events & EV_SIGNAL) -+ return (evsignal_del(ev)); -+ -+ fd = ev->ev_fd; -+ if (fd >= devpollop->nfds) -+ return (0); -+ evdp = &devpollop->fds[fd]; -+ -+ events = 0; -+ if (ev->ev_events & EV_READ) -+ events |= POLLIN; -+ if (ev->ev_events & EV_WRITE) -+ events |= POLLOUT; -+ -+ /* -+ * The only way to remove an fd from the /dev/poll monitored set is -+ * to use POLLREMOVE by itself. This removes ALL events for the fd -+ * provided so if we care about two events and are only removing one -+ * we must re-add the other event after POLLREMOVE. -+ */ -+ -+ if (devpoll_queue(devpollop, fd, POLLREMOVE) != 0) -+ return(-1); -+ -+ if ((events & (POLLIN|POLLOUT)) != (POLLIN|POLLOUT)) { -+ /* -+ * We're not deleting all events, so we must resubmit the -+ * event that we are still interested in if one exists. -+ */ -+ -+ if ((events & POLLIN) && evdp->evwrite != NULL) { -+ /* Deleting read, still care about write */ -+ devpoll_queue(devpollop, fd, POLLOUT); -+ needwritedelete = 0; -+ } else if ((events & POLLOUT) && evdp->evread != NULL) { -+ /* Deleting write, still care about read */ -+ devpoll_queue(devpollop, fd, POLLIN); -+ needreaddelete = 0; -+ } -+ } -+ -+ if (needreaddelete) -+ evdp->evread = NULL; -+ if (needwritedelete) -+ evdp->evwrite = NULL; -+ -+ return (0); -+} -+ -+static void -+devpoll_dealloc(struct event_base *base, void *arg) -+{ -+ struct devpollop *devpollop = arg; -+ -+ evsignal_dealloc(base); -+ if (devpollop->fds) -+ free(devpollop->fds); -+ if (devpollop->events) -+ free(devpollop->events); -+ if (devpollop->changes) -+ free(devpollop->changes); -+ if (devpollop->dpfd >= 0) -+ close(devpollop->dpfd); -+ -+ memset(devpollop, 0, sizeof(struct devpollop)); -+ free(devpollop); -+} -diff --git a/libevent/epoll.c b/libevent/epoll.c -new file mode 100644 -index 0000000..cf3c859 ---- /dev/null -+++ b/libevent/epoll.c -@@ -0,0 +1,370 @@ -+/* -+ * Copyright 2000-2003 Niels Provos -+ * All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. The name of the author may not be used to endorse or promote products -+ * derived from this software without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR -+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES -+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. -+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, -+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT -+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF -+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+ */ -+#ifdef HAVE_CONFIG_H -+#include "config.h" -+#endif -+ -+#include -+#include -+#include -+#ifdef HAVE_SYS_TIME_H -+#include -+#else -+#include -+#endif -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#ifdef HAVE_FCNTL_H -+#include -+#endif -+ -+#include "event.h" -+#include "event-internal.h" -+#include "evsignal.h" -+#include "log.h" -+ -+/* due to limitations in the epoll interface, we need to keep track of -+ * all file descriptors outself. -+ */ -+struct evepoll { -+ struct event *evread; -+ struct event *evwrite; -+}; -+ -+struct epollop { -+ struct evepoll *fds; -+ int nfds; -+ struct epoll_event *events; -+ int nevents; -+ int epfd; -+}; -+ -+static void *epoll_init (struct event_base *); -+static int epoll_add (void *, struct event *); -+static int epoll_del (void *, struct event *); -+static int epoll_dispatch (struct event_base *, void *, struct timeval *); -+static void epoll_dealloc (struct event_base *, void *); -+ -+const struct eventop epollops = { -+ "epoll", -+ epoll_init, -+ epoll_add, -+ epoll_del, -+ epoll_dispatch, -+ epoll_dealloc, -+ 1 /* need reinit */ -+}; -+ -+#ifdef HAVE_SETFD -+#define FD_CLOSEONEXEC(x) do { \ -+ if (fcntl(x, F_SETFD, 1) == -1) \ -+ event_warn("fcntl(%d, F_SETFD)", x); \ -+} while (0) -+#else -+#define FD_CLOSEONEXEC(x) -+#endif -+ -+#define NEVENT 32000 -+ -+/* On Linux kernels at least up to 2.6.24.4, epoll can't handle timeout -+ * values bigger than (LONG_MAX - 999ULL)/HZ. HZ in the wild can be -+ * as big as 1000, and LONG_MAX can be as small as (1<<31)-1, so the -+ * largest number of msec we can support here is 2147482. Let's -+ * round that down by 47 seconds. -+ */ -+#define MAX_EPOLL_TIMEOUT_MSEC (35*60*1000) -+ -+static void * -+epoll_init(struct event_base *base) -+{ -+ int epfd, nfiles = NEVENT; -+ struct rlimit rl; -+ struct epollop *epollop; -+ -+ /* Disable epollueue when this environment variable is set */ -+ if (getenv("EVENT_NOEPOLL")) -+ return (NULL); -+ -+ if (getrlimit(RLIMIT_NOFILE, &rl) == 0 && -+ rl.rlim_cur != RLIM_INFINITY) { -+ /* -+ * Solaris is somewhat retarded - it's important to drop -+ * backwards compatibility when making changes. So, don't -+ * dare to put rl.rlim_cur here. -+ */ -+ nfiles = rl.rlim_cur - 1; -+ } -+ -+ /* Initalize the kernel queue */ -+ -+ if ((epfd = epoll_create(nfiles)) == -1) { -+ if (errno != ENOSYS) -+ event_warn("epoll_create"); -+ return (NULL); -+ } -+ -+ FD_CLOSEONEXEC(epfd); -+ -+ if (!(epollop = calloc(1, sizeof(struct epollop)))) -+ return (NULL); -+ -+ epollop->epfd = epfd; -+ -+ /* Initalize fields */ -+ epollop->events = malloc(nfiles * sizeof(struct epoll_event)); -+ if (epollop->events == NULL) { -+ free(epollop); -+ return (NULL); -+ } -+ epollop->nevents = nfiles; -+ -+ epollop->fds = calloc(nfiles, sizeof(struct evepoll)); -+ if (epollop->fds == NULL) { -+ free(epollop->events); -+ free(epollop); -+ return (NULL); -+ } -+ epollop->nfds = nfiles; -+ -+ evsignal_init(base); -+ -+ return (epollop); -+} -+ -+static int -+epoll_recalc(struct event_base *base, void *arg, int max) -+{ -+ struct epollop *epollop = arg; -+ -+ if (max > epollop->nfds) { -+ struct evepoll *fds; -+ int nfds; -+ -+ nfds = epollop->nfds; -+ while (nfds < max) -+ nfds <<= 1; -+ -+ fds = realloc(epollop->fds, nfds * sizeof(struct evepoll)); -+ if (fds == NULL) { -+ event_warn("realloc"); -+ return (-1); -+ } -+ epollop->fds = fds; -+ memset(fds + epollop->nfds, 0, -+ (nfds - epollop->nfds) * sizeof(struct evepoll)); -+ epollop->nfds = nfds; -+ } -+ -+ return (0); -+} -+ -+static int -+epoll_dispatch(struct event_base *base, void *arg, struct timeval *tv) -+{ -+ struct epollop *epollop = arg; -+ struct epoll_event *events = epollop->events; -+ struct evepoll *evep; -+ int i, res, timeout = -1; -+ -+ if (tv != NULL) -+ timeout = tv->tv_sec * 1000 + (tv->tv_usec + 999) / 1000; -+ -+ if (timeout > MAX_EPOLL_TIMEOUT_MSEC) { -+ /* Linux kernels can wait forever if the timeout is too big; -+ * see comment on MAX_EPOLL_TIMEOUT_MSEC. */ -+ timeout = MAX_EPOLL_TIMEOUT_MSEC; -+ } -+ -+ res = epoll_wait(epollop->epfd, events, epollop->nevents, timeout); -+ -+ if (res == -1) { -+ if (errno != EINTR) { -+ event_warn("epoll_wait"); -+ return (-1); -+ } -+ -+ evsignal_process(base); -+ return (0); -+ } else if (base->sig.evsignal_caught) { -+ evsignal_process(base); -+ } -+ -+ event_debug(("%s: epoll_wait reports %d", __func__, res)); -+ -+ for (i = 0; i < res; i++) { -+ int what = events[i].events; -+ struct event *evread = NULL, *evwrite = NULL; -+ -+ evep = (struct evepoll *)events[i].data.ptr; -+ -+ if (what & (EPOLLHUP|EPOLLERR)) { -+ evread = evep->evread; -+ evwrite = evep->evwrite; -+ } else { -+ if (what & EPOLLIN) { -+ evread = evep->evread; -+ } -+ -+ if (what & EPOLLOUT) { -+ evwrite = evep->evwrite; -+ } -+ } -+ -+ if (!(evread||evwrite)) -+ continue; -+ -+ if (evread != NULL) -+ event_active(evread, EV_READ, 1); -+ if (evwrite != NULL) -+ event_active(evwrite, EV_WRITE, 1); -+ } -+ -+ return (0); -+} -+ -+ -+static int -+epoll_add(void *arg, struct event *ev) -+{ -+ struct epollop *epollop = arg; -+ struct epoll_event epev = {0, {0}}; -+ struct evepoll *evep; -+ int fd, op, events; -+ -+ if (ev->ev_events & EV_SIGNAL) -+ return (evsignal_add(ev)); -+ -+ fd = ev->ev_fd; -+ if (fd >= epollop->nfds) { -+ /* Extent the file descriptor array as necessary */ -+ if (epoll_recalc(ev->ev_base, epollop, fd) == -1) -+ return (-1); -+ } -+ evep = &epollop->fds[fd]; -+ op = EPOLL_CTL_ADD; -+ events = 0; -+ if (evep->evread != NULL) { -+ events |= EPOLLIN; -+ op = EPOLL_CTL_MOD; -+ } -+ if (evep->evwrite != NULL) { -+ events |= EPOLLOUT; -+ op = EPOLL_CTL_MOD; -+ } -+ -+ if (ev->ev_events & EV_READ) -+ events |= EPOLLIN; -+ if (ev->ev_events & EV_WRITE) -+ events |= EPOLLOUT; -+ -+ epev.data.ptr = evep; -+ epev.events = events; -+ if (epoll_ctl(epollop->epfd, op, ev->ev_fd, &epev) == -1) -+ return (-1); -+ -+ /* Update events responsible */ -+ if (ev->ev_events & EV_READ) -+ evep->evread = ev; -+ if (ev->ev_events & EV_WRITE) -+ evep->evwrite = ev; -+ -+ return (0); -+} -+ -+static int -+epoll_del(void *arg, struct event *ev) -+{ -+ struct epollop *epollop = arg; -+ struct epoll_event epev = {0, {0}}; -+ struct evepoll *evep; -+ int fd, events, op; -+ int needwritedelete = 1, needreaddelete = 1; -+ -+ if (ev->ev_events & EV_SIGNAL) -+ return (evsignal_del(ev)); -+ -+ fd = ev->ev_fd; -+ if (fd >= epollop->nfds) -+ return (0); -+ evep = &epollop->fds[fd]; -+ -+ op = EPOLL_CTL_DEL; -+ events = 0; -+ -+ if (ev->ev_events & EV_READ) -+ events |= EPOLLIN; -+ if (ev->ev_events & EV_WRITE) -+ events |= EPOLLOUT; -+ -+ if ((events & (EPOLLIN|EPOLLOUT)) != (EPOLLIN|EPOLLOUT)) { -+ if ((events & EPOLLIN) && evep->evwrite != NULL) { -+ needwritedelete = 0; -+ events = EPOLLOUT; -+ op = EPOLL_CTL_MOD; -+ } else if ((events & EPOLLOUT) && evep->evread != NULL) { -+ needreaddelete = 0; -+ events = EPOLLIN; -+ op = EPOLL_CTL_MOD; -+ } -+ } -+ -+ epev.events = events; -+ epev.data.ptr = evep; -+ -+ if (needreaddelete) -+ evep->evread = NULL; -+ if (needwritedelete) -+ evep->evwrite = NULL; -+ -+ if (epoll_ctl(epollop->epfd, op, fd, &epev) == -1) -+ return (-1); -+ -+ return (0); -+} -+ -+static void -+epoll_dealloc(struct event_base *base, void *arg) -+{ -+ struct epollop *epollop = arg; -+ -+ evsignal_dealloc(base); -+ if (epollop->fds) -+ free(epollop->fds); -+ if (epollop->events) -+ free(epollop->events); -+ if (epollop->epfd >= 0) -+ close(epollop->epfd); -+ -+ memset(epollop, 0, sizeof(struct epollop)); -+ free(epollop); -+} -diff --git a/libevent/epoll_sub.c b/libevent/epoll_sub.c -new file mode 100644 -index 0000000..431970c ---- /dev/null -+++ b/libevent/epoll_sub.c -@@ -0,0 +1,52 @@ -+/* -+ * Copyright 2003 Niels Provos -+ * All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. The name of the author may not be used to endorse or promote products -+ * derived from this software without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR -+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES -+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. -+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, -+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT -+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF -+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+ */ -+#include -+ -+#include -+#include -+#include -+#include -+#include -+ -+int -+epoll_create(int size) -+{ -+ return (syscall(__NR_epoll_create, size)); -+} -+ -+int -+epoll_ctl(int epfd, int op, int fd, struct epoll_event *event) -+{ -+ -+ return (syscall(__NR_epoll_ctl, epfd, op, fd, event)); -+} -+ -+int -+epoll_wait(int epfd, struct epoll_event *events, int maxevents, int timeout) -+{ -+ return (syscall(__NR_epoll_wait, epfd, events, maxevents, timeout)); -+} -diff --git a/libevent/evbuffer.c b/libevent/evbuffer.c -new file mode 100644 -index 0000000..f2179a5 ---- /dev/null -+++ b/libevent/evbuffer.c -@@ -0,0 +1,455 @@ -+/* -+ * Copyright (c) 2002-2004 Niels Provos -+ * All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. The name of the author may not be used to endorse or promote products -+ * derived from this software without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR -+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES -+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. -+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, -+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT -+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF -+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+ */ -+ -+#include -+ -+#ifdef HAVE_CONFIG_H -+#include "config.h" -+#endif -+ -+#ifdef HAVE_SYS_TIME_H -+#include -+#endif -+ -+#include -+#include -+#include -+#include -+#ifdef HAVE_STDARG_H -+#include -+#endif -+ -+#ifdef WIN32 -+#include -+#endif -+ -+#include "evutil.h" -+#include "event.h" -+ -+/* prototypes */ -+ -+void bufferevent_read_pressure_cb(struct evbuffer *, size_t, size_t, void *); -+ -+static int -+bufferevent_add(struct event *ev, int timeout) -+{ -+ struct timeval tv, *ptv = NULL; -+ -+ if (timeout) { -+ evutil_timerclear(&tv); -+ tv.tv_sec = timeout; -+ ptv = &tv; -+ } -+ -+ return (event_add(ev, ptv)); -+} -+ -+/* -+ * This callback is executed when the size of the input buffer changes. -+ * We use it to apply back pressure on the reading side. -+ */ -+ -+void -+bufferevent_read_pressure_cb(struct evbuffer *buf, size_t old, size_t now, -+ void *arg) { -+ struct bufferevent *bufev = arg; -+ /* -+ * If we are below the watermark then reschedule reading if it's -+ * still enabled. -+ */ -+ if (bufev->wm_read.high == 0 || now < bufev->wm_read.high) { -+ evbuffer_setcb(buf, NULL, NULL); -+ -+ if (bufev->enabled & EV_READ) -+ bufferevent_add(&bufev->ev_read, bufev->timeout_read); -+ } -+} -+ -+static void -+bufferevent_readcb(int fd, short event, void *arg) -+{ -+ struct bufferevent *bufev = arg; -+ int res = 0; -+ short what = EVBUFFER_READ; -+ size_t len; -+ int howmuch = -1; -+ -+ if (event == EV_TIMEOUT) { -+ what |= EVBUFFER_TIMEOUT; -+ goto error; -+ } -+ -+ /* -+ * If we have a high watermark configured then we don't want to -+ * read more data than would make us reach the watermark. -+ */ -+ if (bufev->wm_read.high != 0) { -+ howmuch = bufev->wm_read.high - EVBUFFER_LENGTH(bufev->input); -+ /* we might have lowered the watermark, stop reading */ -+ if (howmuch <= 0) { -+ struct evbuffer *buf = bufev->input; -+ event_del(&bufev->ev_read); -+ evbuffer_setcb(buf, -+ bufferevent_read_pressure_cb, bufev); -+ return; -+ } -+ } -+ -+ res = evbuffer_read(bufev->input, fd, howmuch); -+ if (res == -1) { -+ if (errno == EAGAIN || errno == EINTR) -+ goto reschedule; -+ /* error case */ -+ what |= EVBUFFER_ERROR; -+ } else if (res == 0) { -+ /* eof case */ -+ what |= EVBUFFER_EOF; -+ } -+ -+ if (res <= 0) -+ goto error; -+ -+ bufferevent_add(&bufev->ev_read, bufev->timeout_read); -+ -+ /* See if this callbacks meets the water marks */ -+ len = EVBUFFER_LENGTH(bufev->input); -+ if (bufev->wm_read.low != 0 && len < bufev->wm_read.low) -+ return; -+ if (bufev->wm_read.high != 0 && len >= bufev->wm_read.high) { -+ struct evbuffer *buf = bufev->input; -+ event_del(&bufev->ev_read); -+ -+ /* Now schedule a callback for us when the buffer changes */ -+ evbuffer_setcb(buf, bufferevent_read_pressure_cb, bufev); -+ } -+ -+ /* Invoke the user callback - must always be called last */ -+ if (bufev->readcb != NULL) -+ (*bufev->readcb)(bufev, bufev->cbarg); -+ return; -+ -+ reschedule: -+ bufferevent_add(&bufev->ev_read, bufev->timeout_read); -+ return; -+ -+ error: -+ (*bufev->errorcb)(bufev, what, bufev->cbarg); -+} -+ -+static void -+bufferevent_writecb(int fd, short event, void *arg) -+{ -+ struct bufferevent *bufev = arg; -+ int res = 0; -+ short what = EVBUFFER_WRITE; -+ -+ if (event == EV_TIMEOUT) { -+ what |= EVBUFFER_TIMEOUT; -+ goto error; -+ } -+ -+ if (EVBUFFER_LENGTH(bufev->output)) { -+ res = evbuffer_write(bufev->output, fd); -+ if (res == -1) { -+#ifndef WIN32 -+/*todo. evbuffer uses WriteFile when WIN32 is set. WIN32 system calls do not -+ *set errno. thus this error checking is not portable*/ -+ if (errno == EAGAIN || -+ errno == EINTR || -+ errno == EINPROGRESS) -+ goto reschedule; -+ /* error case */ -+ what |= EVBUFFER_ERROR; -+ -+#else -+ goto reschedule; -+#endif -+ -+ } else if (res == 0) { -+ /* eof case */ -+ what |= EVBUFFER_EOF; -+ } -+ if (res <= 0) -+ goto error; -+ } -+ -+ if (EVBUFFER_LENGTH(bufev->output) != 0) -+ bufferevent_add(&bufev->ev_write, bufev->timeout_write); -+ -+ /* -+ * Invoke the user callback if our buffer is drained or below the -+ * low watermark. -+ */ -+ if (bufev->writecb != NULL && -+ EVBUFFER_LENGTH(bufev->output) <= bufev->wm_write.low) -+ (*bufev->writecb)(bufev, bufev->cbarg); -+ -+ return; -+ -+ reschedule: -+ if (EVBUFFER_LENGTH(bufev->output) != 0) -+ bufferevent_add(&bufev->ev_write, bufev->timeout_write); -+ return; -+ -+ error: -+ (*bufev->errorcb)(bufev, what, bufev->cbarg); -+} -+ -+/* -+ * Create a new buffered event object. -+ * -+ * The read callback is invoked whenever we read new data. -+ * The write callback is invoked whenever the output buffer is drained. -+ * The error callback is invoked on a write/read error or on EOF. -+ * -+ * Both read and write callbacks maybe NULL. The error callback is not -+ * allowed to be NULL and have to be provided always. -+ */ -+ -+struct bufferevent * -+bufferevent_new(int fd, evbuffercb readcb, evbuffercb writecb, -+ everrorcb errorcb, void *cbarg) -+{ -+ struct bufferevent *bufev; -+ -+ if ((bufev = calloc(1, sizeof(struct bufferevent))) == NULL) -+ return (NULL); -+ -+ if ((bufev->input = evbuffer_new()) == NULL) { -+ free(bufev); -+ return (NULL); -+ } -+ -+ if ((bufev->output = evbuffer_new()) == NULL) { -+ evbuffer_free(bufev->input); -+ free(bufev); -+ return (NULL); -+ } -+ -+ event_set(&bufev->ev_read, fd, EV_READ, bufferevent_readcb, bufev); -+ event_set(&bufev->ev_write, fd, EV_WRITE, bufferevent_writecb, bufev); -+ -+ bufferevent_setcb(bufev, readcb, writecb, errorcb, cbarg); -+ -+ /* -+ * Set to EV_WRITE so that using bufferevent_write is going to -+ * trigger a callback. Reading needs to be explicitly enabled -+ * because otherwise no data will be available. -+ */ -+ bufev->enabled = EV_WRITE; -+ -+ return (bufev); -+} -+ -+void -+bufferevent_setcb(struct bufferevent *bufev, -+ evbuffercb readcb, evbuffercb writecb, everrorcb errorcb, void *cbarg) -+{ -+ bufev->readcb = readcb; -+ bufev->writecb = writecb; -+ bufev->errorcb = errorcb; -+ -+ bufev->cbarg = cbarg; -+} -+ -+void -+bufferevent_setfd(struct bufferevent *bufev, int fd) -+{ -+ event_del(&bufev->ev_read); -+ event_del(&bufev->ev_write); -+ -+ event_set(&bufev->ev_read, fd, EV_READ, bufferevent_readcb, bufev); -+ event_set(&bufev->ev_write, fd, EV_WRITE, bufferevent_writecb, bufev); -+ if (bufev->ev_base != NULL) { -+ event_base_set(bufev->ev_base, &bufev->ev_read); -+ event_base_set(bufev->ev_base, &bufev->ev_write); -+ } -+ -+ /* might have to manually trigger event registration */ -+} -+ -+int -+bufferevent_priority_set(struct bufferevent *bufev, int priority) -+{ -+ if (event_priority_set(&bufev->ev_read, priority) == -1) -+ return (-1); -+ if (event_priority_set(&bufev->ev_write, priority) == -1) -+ return (-1); -+ -+ return (0); -+} -+ -+/* Closing the file descriptor is the responsibility of the caller */ -+ -+void -+bufferevent_free(struct bufferevent *bufev) -+{ -+ event_del(&bufev->ev_read); -+ event_del(&bufev->ev_write); -+ -+ evbuffer_free(bufev->input); -+ evbuffer_free(bufev->output); -+ -+ free(bufev); -+} -+ -+/* -+ * Returns 0 on success; -+ * -1 on failure. -+ */ -+ -+int -+bufferevent_write(struct bufferevent *bufev, const void *data, size_t size) -+{ -+ int res; -+ -+ res = evbuffer_add(bufev->output, data, size); -+ -+ if (res == -1) -+ return (res); -+ -+ /* If everything is okay, we need to schedule a write */ -+ if (size > 0 && (bufev->enabled & EV_WRITE)) -+ bufferevent_add(&bufev->ev_write, bufev->timeout_write); -+ -+ return (res); -+} -+ -+int -+bufferevent_write_buffer(struct bufferevent *bufev, struct evbuffer *buf) -+{ -+ int res; -+ -+ res = bufferevent_write(bufev, buf->buffer, buf->off); -+ if (res != -1) -+ evbuffer_drain(buf, buf->off); -+ -+ return (res); -+} -+ -+size_t -+bufferevent_read(struct bufferevent *bufev, void *data, size_t size) -+{ -+ struct evbuffer *buf = bufev->input; -+ -+ if (buf->off < size) -+ size = buf->off; -+ -+ /* Copy the available data to the user buffer */ -+ memcpy(data, buf->buffer, size); -+ -+ if (size) -+ evbuffer_drain(buf, size); -+ -+ return (size); -+} -+ -+int -+bufferevent_enable(struct bufferevent *bufev, short event) -+{ -+ if (event & EV_READ) { -+ if (bufferevent_add(&bufev->ev_read, bufev->timeout_read) == -1) -+ return (-1); -+ } -+ if (event & EV_WRITE) { -+ if (bufferevent_add(&bufev->ev_write, bufev->timeout_write) == -1) -+ return (-1); -+ } -+ -+ bufev->enabled |= event; -+ return (0); -+} -+ -+int -+bufferevent_disable(struct bufferevent *bufev, short event) -+{ -+ if (event & EV_READ) { -+ if (event_del(&bufev->ev_read) == -1) -+ return (-1); -+ } -+ if (event & EV_WRITE) { -+ if (event_del(&bufev->ev_write) == -1) -+ return (-1); -+ } -+ -+ bufev->enabled &= ~event; -+ return (0); -+} -+ -+/* -+ * Sets the read and write timeout for a buffered event. -+ */ -+ -+void -+bufferevent_settimeout(struct bufferevent *bufev, -+ int timeout_read, int timeout_write) { -+ bufev->timeout_read = timeout_read; -+ bufev->timeout_write = timeout_write; -+ -+ if (event_pending(&bufev->ev_read, EV_READ, NULL)) -+ bufferevent_add(&bufev->ev_read, timeout_read); -+ if (event_pending(&bufev->ev_write, EV_WRITE, NULL)) -+ bufferevent_add(&bufev->ev_write, timeout_write); -+} -+ -+/* -+ * Sets the water marks -+ */ -+ -+void -+bufferevent_setwatermark(struct bufferevent *bufev, short events, -+ size_t lowmark, size_t highmark) -+{ -+ if (events & EV_READ) { -+ bufev->wm_read.low = lowmark; -+ bufev->wm_read.high = highmark; -+ } -+ -+ if (events & EV_WRITE) { -+ bufev->wm_write.low = lowmark; -+ bufev->wm_write.high = highmark; -+ } -+ -+ /* If the watermarks changed then see if we should call read again */ -+ bufferevent_read_pressure_cb(bufev->input, -+ 0, EVBUFFER_LENGTH(bufev->input), bufev); -+} -+ -+int -+bufferevent_base_set(struct event_base *base, struct bufferevent *bufev) -+{ -+ int res; -+ -+ bufev->ev_base = base; -+ -+ res = event_base_set(base, &bufev->ev_read); -+ if (res == -1) -+ return (res); -+ -+ res = event_base_set(base, &bufev->ev_write); -+ return (res); -+} -diff --git a/libevent/event-config.h b/libevent/event-config.h -new file mode 100644 -index 0000000..0a278b3 ---- /dev/null -+++ b/libevent/event-config.h -@@ -0,0 +1,262 @@ -+/* event-config.h -+ * Generated by autoconf; post-processed by libevent. -+ * Do not edit this file. -+ * Do not rely on macros in this file existing in later versions. -+ */ -+#ifndef _EVENT_CONFIG_H_ -+#define _EVENT_CONFIG_H_ -+/* config.h. Generated from config.h.in by configure. */ -+/* config.h.in. Generated from configure.in by autoheader. */ -+ -+/* Define if clock_gettime is available in libc */ -+/* #undef _EVENT_DNS_USE_CPU_CLOCK_FOR_ID */ -+ -+/* Define is no secure id variant is available */ -+#define _EVENT_DNS_USE_GETTIMEOFDAY_FOR_ID 1 -+ -+/* Define to 1 if you have the `clock_gettime' function. */ -+/* #undef _EVENT_HAVE_CLOCK_GETTIME */ -+ -+/* Define if /dev/poll is available */ -+/* #undef _EVENT_HAVE_DEVPOLL */ -+ -+/* Define to 1 if you have the header file. */ -+#define _EVENT_HAVE_DLFCN_H 1 -+ -+/* Define if your system supports the epoll system calls */ -+/* #undef _EVENT_HAVE_EPOLL */ -+ -+/* Define to 1 if you have the `epoll_ctl' function. */ -+/* #undef _EVENT_HAVE_EPOLL_CTL */ -+ -+/* Define if your system supports event ports */ -+/* #undef _EVENT_HAVE_EVENT_PORTS */ -+ -+/* Define to 1 if you have the `fcntl' function. */ -+#define _EVENT_HAVE_FCNTL 1 -+ -+/* Define to 1 if you have the header file. */ -+#define _EVENT_HAVE_FCNTL_H 1 -+ -+/* Define to 1 if you have the `getaddrinfo' function. */ -+#define _EVENT_HAVE_GETADDRINFO 1 -+ -+/* Define to 1 if you have the `getnameinfo' function. */ -+#define _EVENT_HAVE_GETNAMEINFO 1 -+ -+/* Define to 1 if you have the `gettimeofday' function. */ -+#define _EVENT_HAVE_GETTIMEOFDAY 1 -+ -+/* Define to 1 if you have the `inet_ntop' function. */ -+#define _EVENT_HAVE_INET_NTOP 1 -+ -+/* Define to 1 if you have the header file. */ -+#define _EVENT_HAVE_INTTYPES_H 1 -+ -+/* Define to 1 if you have the `kqueue' function. */ -+#define _EVENT_HAVE_KQUEUE 1 -+ -+/* Define to 1 if you have the `nsl' library (-lnsl). */ -+/* #undef _EVENT_HAVE_LIBNSL */ -+ -+/* Define to 1 if you have the `resolv' library (-lresolv). */ -+#define _EVENT_HAVE_LIBRESOLV 1 -+ -+/* Define to 1 if you have the `rt' library (-lrt). */ -+/* #undef _EVENT_HAVE_LIBRT */ -+ -+/* Define to 1 if you have the `socket' library (-lsocket). */ -+/* #undef _EVENT_HAVE_LIBSOCKET */ -+ -+/* Define to 1 if you have the header file. */ -+#define _EVENT_HAVE_MEMORY_H 1 -+ -+/* Define to 1 if you have the header file. */ -+/* #undef _EVENT_HAVE_NETINET_IN6_H */ -+ -+/* Define to 1 if you have the `poll' function. */ -+#define _EVENT_HAVE_POLL 1 -+ -+/* Define to 1 if you have the header file. */ -+#define _EVENT_HAVE_POLL_H 1 -+ -+/* Define to 1 if you have the `port_create' function. */ -+/* #undef _EVENT_HAVE_PORT_CREATE */ -+ -+/* Define to 1 if you have the header file. */ -+/* #undef _EVENT_HAVE_PORT_H */ -+ -+/* Define to 1 if you have the `select' function. */ -+#define _EVENT_HAVE_SELECT 1 -+ -+/* Define if F_SETFD is defined in */ -+#define _EVENT_HAVE_SETFD 1 -+ -+/* Define to 1 if you have the `sigaction' function. */ -+#define _EVENT_HAVE_SIGACTION 1 -+ -+/* Define to 1 if you have the `signal' function. */ -+#define _EVENT_HAVE_SIGNAL 1 -+ -+/* Define to 1 if you have the header file. */ -+#define _EVENT_HAVE_SIGNAL_H 1 -+ -+/* Define to 1 if you have the header file. */ -+#define _EVENT_HAVE_STDARG_H 1 -+ -+/* Define to 1 if you have the header file. */ -+#define _EVENT_HAVE_STDINT_H 1 -+ -+/* Define to 1 if you have the header file. */ -+#define _EVENT_HAVE_STDLIB_H 1 -+ -+/* Define to 1 if you have the header file. */ -+#define _EVENT_HAVE_STRINGS_H 1 -+ -+/* Define to 1 if you have the header file. */ -+#define _EVENT_HAVE_STRING_H 1 -+ -+/* Define to 1 if you have the `strlcpy' function. */ -+#define _EVENT_HAVE_STRLCPY 1 -+ -+/* Define to 1 if you have the `strsep' function. */ -+#define _EVENT_HAVE_STRSEP 1 -+ -+/* Define to 1 if you have the `strtok_r' function. */ -+#define _EVENT_HAVE_STRTOK_R 1 -+ -+/* Define to 1 if you have the `strtoll' function. */ -+#define _EVENT_HAVE_STRTOLL 1 -+ -+/* Define to 1 if the system has the type `struct in6_addr'. */ -+#define _EVENT_HAVE_STRUCT_IN6_ADDR 1 -+ -+/* Define to 1 if you have the header file. */ -+/* #undef _EVENT_HAVE_SYS_DEVPOLL_H */ -+ -+/* Define to 1 if you have the header file. */ -+/* #undef _EVENT_HAVE_SYS_EPOLL_H */ -+ -+/* Define to 1 if you have the header file. */ -+#define _EVENT_HAVE_SYS_EVENT_H 1 -+ -+/* Define to 1 if you have the header file. */ -+#define _EVENT_HAVE_SYS_IOCTL_H 1 -+ -+/* Define to 1 if you have the header file. */ -+#define _EVENT_HAVE_SYS_PARAM_H 1 -+ -+/* Define to 1 if you have the header file. */ -+#define _EVENT_HAVE_SYS_QUEUE_H 1 -+ -+/* Define to 1 if you have the header file. */ -+#define _EVENT_HAVE_SYS_SELECT_H 1 -+ -+/* Define to 1 if you have the header file. */ -+#define _EVENT_HAVE_SYS_SOCKET_H 1 -+ -+/* Define to 1 if you have the header file. */ -+#define _EVENT_HAVE_SYS_STAT_H 1 -+ -+/* Define to 1 if you have the header file. */ -+#define _EVENT_HAVE_SYS_TIME_H 1 -+ -+/* Define to 1 if you have the header file. */ -+#define _EVENT_HAVE_SYS_TYPES_H 1 -+ -+/* Define if TAILQ_FOREACH is defined in */ -+#define _EVENT_HAVE_TAILQFOREACH 1 -+ -+/* Define if timeradd is defined in */ -+#define _EVENT_HAVE_TIMERADD 1 -+ -+/* Define if timerclear is defined in */ -+#define _EVENT_HAVE_TIMERCLEAR 1 -+ -+/* Define if timercmp is defined in */ -+#define _EVENT_HAVE_TIMERCMP 1 -+ -+/* Define if timerisset is defined in */ -+#define _EVENT_HAVE_TIMERISSET 1 -+ -+/* Define to 1 if the system has the type `uint16_t'. */ -+#define _EVENT_HAVE_UINT16_T 1 -+ -+/* Define to 1 if the system has the type `uint32_t'. */ -+#define _EVENT_HAVE_UINT32_T 1 -+ -+/* Define to 1 if the system has the type `uint64_t'. */ -+#define _EVENT_HAVE_UINT64_T 1 -+ -+/* Define to 1 if the system has the type `uint8_t'. */ -+#define _EVENT_HAVE_UINT8_T 1 -+ -+/* Define to 1 if you have the header file. */ -+#define _EVENT_HAVE_UNISTD_H 1 -+ -+/* Define to 1 if you have the `vasprintf' function. */ -+#define _EVENT_HAVE_VASPRINTF 1 -+ -+/* Define if kqueue works correctly with pipes */ -+#define _EVENT_HAVE_WORKING_KQUEUE 1 -+ -+/* Name of package */ -+#define _EVENT_PACKAGE "libevent" -+ -+/* Define to the address where bug reports for this package should be sent. */ -+#define _EVENT_PACKAGE_BUGREPORT "" -+ -+/* Define to the full name of this package. */ -+#define _EVENT_PACKAGE_NAME "" -+ -+/* Define to the full name and version of this package. */ -+#define _EVENT_PACKAGE_STRING "" -+ -+/* Define to the one symbol short name of this package. */ -+#define _EVENT_PACKAGE_TARNAME "" -+ -+/* Define to the version of this package. */ -+#define _EVENT_PACKAGE_VERSION "" -+ -+/* The size of `int', as computed by sizeof. */ -+#define _EVENT_SIZEOF_INT 4 -+ -+/* The size of `long', as computed by sizeof. */ -+#define _EVENT_SIZEOF_LONG 4 -+ -+/* The size of `long long', as computed by sizeof. */ -+#define _EVENT_SIZEOF_LONG_LONG 8 -+ -+/* The size of `short', as computed by sizeof. */ -+#define _EVENT_SIZEOF_SHORT 2 -+ -+/* Define to 1 if you have the ANSI C header files. */ -+#define _EVENT_STDC_HEADERS 1 -+ -+/* Define to 1 if you can safely include both and . */ -+#define _EVENT_TIME_WITH_SYS_TIME 1 -+ -+/* Version number of package */ -+#define _EVENT_VERSION "1.4.8-stable" -+ -+/* Define to appropriate substitue if compiler doesnt have __func__ */ -+/* #undef _EVENT___func__ */ -+ -+/* Define to empty if `const' does not conform to ANSI C. */ -+/* #undef _EVENT_const */ -+ -+/* Define to `__inline__' or `__inline' if that's what the C compiler -+ calls it, or to nothing if 'inline' is not supported under any name. */ -+#ifndef _EVENT___cplusplus -+/* #undef _EVENT_inline */ -+#endif -+ -+/* Define to `int' if does not define. */ -+/* #undef _EVENT_pid_t */ -+ -+/* Define to `unsigned int' if does not define. */ -+/* #undef _EVENT_size_t */ -+ -+/* Define to unsigned int if you dont have it */ -+/* #undef _EVENT_socklen_t */ -+#endif -diff --git a/libevent/event-fpm.h b/libevent/event-fpm.h -new file mode 100644 -index 0000000..8625ca5 ---- /dev/null -+++ b/libevent/event-fpm.h -@@ -0,0 +1,129 @@ -+#define event_active _fpm_event_active -+#define event_add _fpm_event_add -+#define event_base_dispatch _fpm_event_base_dispatch -+#define event_base_free _fpm_event_base_free -+#define event_base_get_method _fpm_event_base_get_method -+#define event_base_loop _fpm_event_base_loop -+#define event_base_loopbreak _fpm_event_base_loopbreak -+#define event_base_loopexit _fpm_event_base_loopexit -+#define event_base_new _fpm_event_base_new -+#define event_base_once _fpm_event_base_once -+#define event_base_priority_init _fpm_event_base_priority_init -+#define event_base_set _fpm_event_base_set -+#define event_del _fpm_event_del -+#define event_dispatch _fpm_event_dispatch -+#define event_get_method _fpm_event_get_method -+#define event_get_version _fpm_event_get_version -+#define event_init _fpm_event_init -+#define event_loop _fpm_event_loop -+#define event_loopbreak _fpm_event_loopbreak -+#define event_loopexit _fpm_event_loopexit -+#define event_once _fpm_event_once -+#define event_pending _fpm_event_pending -+#define event_priority_init _fpm_event_priority_init -+#define event_priority_set _fpm_event_priority_set -+#define event_reinit _fpm_event_reinit -+#define event_set _fpm_event_set -+#define _event_debugx _fpm__event_debugx -+#define event_err _fpm_event_err -+#define event_errx _fpm_event_errx -+#define event_msgx _fpm_event_msgx -+#define event_set_log_callback _fpm_event_set_log_callback -+#define event_warn _fpm_event_warn -+#define event_warnx _fpm_event_warnx -+#define evutil_make_socket_nonblocking _fpm_evutil_make_socket_nonblocking -+#define evutil_snprintf _fpm_evutil_snprintf -+#define evutil_socketpair _fpm_evutil_socketpair -+#define evutil_strtoll _fpm_evutil_strtoll -+#define evutil_vsnprintf _fpm_evutil_vsnprintf -+#define evhttp_accept_socket _fpm_evhttp_accept_socket -+#define evhttp_add_header _fpm_evhttp_add_header -+#define evhttp_bind_socket _fpm_evhttp_bind_socket -+#define evhttp_clear_headers _fpm_evhttp_clear_headers -+#define evhttp_connection_connect _fpm_evhttp_connection_connect -+#define evhttp_connection_fail _fpm_evhttp_connection_fail -+#define evhttp_connection_free _fpm_evhttp_connection_free -+#define evhttp_connection_get_peer _fpm_evhttp_connection_get_peer -+#define evhttp_connection_new _fpm_evhttp_connection_new -+#define evhttp_connection_reset _fpm_evhttp_connection_reset -+#define evhttp_connection_set_base _fpm_evhttp_connection_set_base -+#define evhttp_connection_set_closecb _fpm_evhttp_connection_set_closecb -+#define evhttp_connection_set_local_address _fpm_evhttp_connection_set_local_address -+#define evhttp_connection_set_retries _fpm_evhttp_connection_set_retries -+#define evhttp_connection_set_timeout _fpm_evhttp_connection_set_timeout -+#define evhttp_decode_uri _fpm_evhttp_decode_uri -+#define evhttp_del_cb _fpm_evhttp_del_cb -+#define evhttp_encode_uri _fpm_evhttp_encode_uri -+#define evhttp_find_header _fpm_evhttp_find_header -+#define evhttp_free _fpm_evhttp_free -+#define evhttp_get_request _fpm_evhttp_get_request -+#define evhttp_hostportfile _fpm_evhttp_hostportfile -+#define evhttp_htmlescape _fpm_evhttp_htmlescape -+#define evhttp_make_header _fpm_evhttp_make_header -+#define evhttp_make_request _fpm_evhttp_make_request -+#define evhttp_new _fpm_evhttp_new -+#define evhttp_parse_firstline _fpm_evhttp_parse_firstline -+#define evhttp_parse_headers _fpm_evhttp_parse_headers -+#define evhttp_parse_query _fpm_evhttp_parse_query -+#define evhttp_read _fpm_evhttp_read -+#define evhttp_remove_header _fpm_evhttp_remove_header -+#define evhttp_request_free _fpm_evhttp_request_free -+#define evhttp_request_new _fpm_evhttp_request_new -+#define evhttp_request_set_chunked_cb _fpm_evhttp_request_set_chunked_cb -+#define evhttp_request_uri _fpm_evhttp_request_uri -+#define evhttp_response_code _fpm_evhttp_response_code -+#define evhttp_send_error _fpm_evhttp_send_error -+#define evhttp_send_page _fpm_evhttp_send_page -+#define evhttp_send_reply _fpm_evhttp_send_reply -+#define evhttp_send_reply_chunk _fpm_evhttp_send_reply_chunk -+#define evhttp_send_reply_end _fpm_evhttp_send_reply_end -+#define evhttp_send_reply_start _fpm_evhttp_send_reply_start -+#define evhttp_set_cb _fpm_evhttp_set_cb -+#define evhttp_set_gencb _fpm_evhttp_set_gencb -+#define evhttp_set_timeout _fpm_evhttp_set_timeout -+#define evhttp_start _fpm_evhttp_start -+#define evhttp_start_read _fpm_evhttp_start_read -+#define evhttp_write _fpm_evhttp_write -+#define evhttp_write_buffer _fpm_evhttp_write_buffer -+#define evbuffer_add _fpm_evbuffer_add -+#define evbuffer_add_buffer _fpm_evbuffer_add_buffer -+#define evbuffer_add_printf _fpm_evbuffer_add_printf -+#define evbuffer_add_vprintf _fpm_evbuffer_add_vprintf -+#define evbuffer_drain _fpm_evbuffer_drain -+#define evbuffer_expand _fpm_evbuffer_expand -+#define evbuffer_find _fpm_evbuffer_find -+#define evbuffer_free _fpm_evbuffer_free -+#define evbuffer_new _fpm_evbuffer_new -+#define evbuffer_read _fpm_evbuffer_read -+#define evbuffer_readline _fpm_evbuffer_readline -+#define evbuffer_remove _fpm_evbuffer_remove -+#define evbuffer_setcb _fpm_evbuffer_setcb -+#define evbuffer_write _fpm_evbuffer_write -+#define bufferevent_base_set _fpm_bufferevent_base_set -+#define bufferevent_disable _fpm_bufferevent_disable -+#define bufferevent_enable _fpm_bufferevent_enable -+#define bufferevent_free _fpm_bufferevent_free -+#define bufferevent_new _fpm_bufferevent_new -+#define bufferevent_priority_set _fpm_bufferevent_priority_set -+#define bufferevent_read _fpm_bufferevent_read -+#define bufferevent_read_pressure_cb _fpm_bufferevent_read_pressure_cb -+#define bufferevent_setcb _fpm_bufferevent_setcb -+#define bufferevent_setfd _fpm_bufferevent_setfd -+#define bufferevent_settimeout _fpm_bufferevent_settimeout -+#define bufferevent_setwatermark _fpm_bufferevent_setwatermark -+#define bufferevent_write _fpm_bufferevent_write -+#define bufferevent_write_buffer _fpm_bufferevent_write_buffer -+#define _event_strlcpy _fpm__event_strlcpy -+#define selectops _fpm_selectops -+#define pollops _fpm_pollops -+#define epollops _fpm_epollops -+#define devpollops _fpm_devpollops -+#define evportops _fpm_evportops -+#define kqops _fpm_kqops -+#define evsignal_add _fpm_evsignal_add -+#define evsignal_dealloc _fpm_evsignal_dealloc -+#define evsignal_del _fpm_evsignal_del -+#define evsignal_init _fpm_evsignal_init -+#define evsignal_process _fpm_evsignal_process -+#define _evsignal_restore_handler _fpm__evsignal_restore_handler -+#define _evsignal_set_handler _fpm__evsignal_set_handler -diff --git a/libevent/event-internal.h b/libevent/event-internal.h -new file mode 100644 -index 0000000..7485f21 ---- /dev/null -+++ b/libevent/event-internal.h -@@ -0,0 +1,98 @@ -+/* -+ * Copyright (c) 2000-2004 Niels Provos -+ * All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. The name of the author may not be used to endorse or promote products -+ * derived from this software without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR -+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES -+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. -+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, -+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT -+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF -+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+ */ -+#ifndef _EVENT_INTERNAL_H_ -+#define _EVENT_INTERNAL_H_ -+ -+#ifdef __cplusplus -+extern "C" { -+#endif -+ -+#include "config.h" -+#include "min_heap.h" -+#include "evsignal.h" -+ -+struct eventop { -+ const char *name; -+ void *(*init)(struct event_base *); -+ int (*add)(void *, struct event *); -+ int (*del)(void *, struct event *); -+ int (*dispatch)(struct event_base *, void *, struct timeval *); -+ void (*dealloc)(struct event_base *, void *); -+ /* set if we need to reinitialize the event base */ -+ int need_reinit; -+}; -+ -+struct event_base { -+ const struct eventop *evsel; -+ void *evbase; -+ int event_count; /* counts number of total events */ -+ int event_count_active; /* counts number of active events */ -+ -+ int event_gotterm; /* Set to terminate loop */ -+ int event_break; /* Set to terminate loop immediately */ -+ -+ /* active event management */ -+ struct event_list **activequeues; -+ int nactivequeues; -+ -+ /* signal handling info */ -+ struct evsignal_info sig; -+ -+ struct event_list eventqueue; -+ struct timeval event_tv; -+ -+ struct min_heap timeheap; -+ -+ struct timeval tv_cache; -+}; -+ -+/* Internal use only: Functions that might be missing from */ -+#ifndef HAVE_TAILQFOREACH -+#define TAILQ_FIRST(head) ((head)->tqh_first) -+#define TAILQ_END(head) NULL -+#define TAILQ_NEXT(elm, field) ((elm)->field.tqe_next) -+#define TAILQ_FOREACH(var, head, field) \ -+ for((var) = TAILQ_FIRST(head); \ -+ (var) != TAILQ_END(head); \ -+ (var) = TAILQ_NEXT(var, field)) -+#define TAILQ_INSERT_BEFORE(listelm, elm, field) do { \ -+ (elm)->field.tqe_prev = (listelm)->field.tqe_prev; \ -+ (elm)->field.tqe_next = (listelm); \ -+ *(listelm)->field.tqe_prev = (elm); \ -+ (listelm)->field.tqe_prev = &(elm)->field.tqe_next; \ -+} while (0) -+#endif /* TAILQ_FOREACH */ -+ -+int _evsignal_set_handler(struct event_base *base, int evsignal, -+ void (*fn)(int)); -+int _evsignal_restore_handler(struct event_base *base, int evsignal); -+ -+#ifdef __cplusplus -+} -+#endif -+ -+#endif /* _EVENT_INTERNAL_H_ */ -diff --git a/libevent/event.3 b/libevent/event.3 -new file mode 100644 -index 0000000..5b33ec6 ---- /dev/null -+++ b/libevent/event.3 -@@ -0,0 +1,624 @@ -+.\" $OpenBSD: event.3,v 1.4 2002/07/12 18:50:48 provos Exp $ -+.\" -+.\" Copyright (c) 2000 Artur Grabowski -+.\" All rights reserved. -+.\" -+.\" Redistribution and use in source and binary forms, with or without -+.\" modification, are permitted provided that the following conditions -+.\" are met: -+.\" -+.\" 1. Redistributions of source code must retain the above copyright -+.\" notice, this list of conditions and the following disclaimer. -+.\" 2. Redistributions in binary form must reproduce the above copyright -+.\" notice, this list of conditions and the following disclaimer in the -+.\" documentation and/or other materials provided with the distribution. -+.\" 3. The name of the author may not be used to endorse or promote products -+.\" derived from this software without specific prior written permission. -+.\" -+.\" THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, -+.\" INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY -+.\" AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL -+.\" THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, -+.\" EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, -+.\" PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; -+.\" OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, -+.\" WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR -+.\" OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF -+.\" ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+.\" -+.Dd August 8, 2000 -+.Dt EVENT 3 -+.Os -+.Sh NAME -+.Nm event_init , -+.Nm event_dispatch , -+.Nm event_loop , -+.Nm event_loopexit , -+.Nm event_loopbreak , -+.Nm event_set , -+.Nm event_base_dispatch , -+.Nm event_base_loop , -+.Nm event_base_loopexit , -+.Nm event_base_loopbreak , -+.Nm event_base_set , -+.Nm event_base_free , -+.Nm event_add , -+.Nm event_del , -+.Nm event_once , -+.Nm event_base_once , -+.Nm event_pending , -+.Nm event_initialized , -+.Nm event_priority_init , -+.Nm event_priority_set , -+.Nm evtimer_set , -+.Nm evtimer_add , -+.Nm evtimer_del , -+.Nm evtimer_pending , -+.Nm evtimer_initialized , -+.Nm signal_set , -+.Nm signal_add , -+.Nm signal_del , -+.Nm signal_pending , -+.Nm signal_initialized , -+.Nm bufferevent_new , -+.Nm bufferevent_free , -+.Nm bufferevent_write , -+.Nm bufferevent_write_buffer , -+.Nm bufferevent_read , -+.Nm bufferevent_enable , -+.Nm bufferevent_disable , -+.Nm bufferevent_settimeout , -+.Nm bufferevent_base_set , -+.Nm evbuffer_new , -+.Nm evbuffer_free , -+.Nm evbuffer_add , -+.Nm evbuffer_add_buffer , -+.Nm evbuffer_add_printf , -+.Nm evbuffer_add_vprintf , -+.Nm evbuffer_drain , -+.Nm evbuffer_write , -+.Nm evbuffer_read , -+.Nm evbuffer_find , -+.Nm evbuffer_readline , -+.Nm evhttp_new , -+.Nm evhttp_bind_socket , -+.Nm evhttp_free -+.Nd execute a function when a specific event occurs -+.Sh SYNOPSIS -+.Fd #include -+.Fd #include -+.Ft "struct event_base *" -+.Fn "event_init" "void" -+.Ft int -+.Fn "event_dispatch" "void" -+.Ft int -+.Fn "event_loop" "int flags" -+.Ft int -+.Fn "event_loopexit" "struct timeval *tv" -+.Ft int -+.Fn "event_loopbreak" "void" -+.Ft void -+.Fn "event_set" "struct event *ev" "int fd" "short event" "void (*fn)(int, short, void *)" "void *arg" -+.Ft int -+.Fn "event_base_dispatch" "struct event_base *base" -+.Ft int -+.Fn "event_base_loop" "struct event_base *base" "int flags" -+.Ft int -+.Fn "event_base_loopexit" "struct event_base *base" "struct timeval *tv" -+.Ft int -+.Fn "event_base_loopbreak" "struct event_base *base" -+.Ft int -+.Fn "event_base_set" "struct event_base *base" "struct event *" -+.Ft void -+.Fn "event_base_free" "struct event_base *base" -+.Ft int -+.Fn "event_add" "struct event *ev" "struct timeval *tv" -+.Ft int -+.Fn "event_del" "struct event *ev" -+.Ft int -+.Fn "event_once" "int fd" "short event" "void (*fn)(int, short, void *)" "void *arg" "struct timeval *tv" -+.Ft int -+.Fn "event_base_once" "struct event_base *base" "int fd" "short event" "void (*fn)(int, short, void *)" "void *arg" "struct timeval *tv" -+.Ft int -+.Fn "event_pending" "struct event *ev" "short event" "struct timeval *tv" -+.Ft int -+.Fn "event_initialized" "struct event *ev" -+.Ft int -+.Fn "event_priority_init" "int npriorities" -+.Ft int -+.Fn "event_priority_set" "struct event *ev" "int priority" -+.Ft void -+.Fn "evtimer_set" "struct event *ev" "void (*fn)(int, short, void *)" "void *arg" -+.Ft void -+.Fn "evtimer_add" "struct event *ev" "struct timeval *" -+.Ft void -+.Fn "evtimer_del" "struct event *ev" -+.Ft int -+.Fn "evtimer_pending" "struct event *ev" "struct timeval *tv" -+.Ft int -+.Fn "evtimer_initialized" "struct event *ev" -+.Ft void -+.Fn "signal_set" "struct event *ev" "int signal" "void (*fn)(int, short, void *)" "void *arg" -+.Ft void -+.Fn "signal_add" "struct event *ev" "struct timeval *" -+.Ft void -+.Fn "signal_del" "struct event *ev" -+.Ft int -+.Fn "signal_pending" "struct event *ev" "struct timeval *tv" -+.Ft int -+.Fn "signal_initialized" "struct event *ev" -+.Ft "struct bufferevent *" -+.Fn "bufferevent_new" "int fd" "evbuffercb readcb" "evbuffercb writecb" "everrorcb" "void *cbarg" -+.Ft void -+.Fn "bufferevent_free" "struct bufferevent *bufev" -+.Ft int -+.Fn "bufferevent_write" "struct bufferevent *bufev" "void *data" "size_t size" -+.Ft int -+.Fn "bufferevent_write_buffer" "struct bufferevent *bufev" "struct evbuffer *buf" -+.Ft size_t -+.Fn "bufferevent_read" "struct bufferevent *bufev" "void *data" "size_t size" -+.Ft int -+.Fn "bufferevent_enable" "struct bufferevent *bufev" "short event" -+.Ft int -+.Fn "bufferevent_disable" "struct bufferevent *bufev" "short event" -+.Ft void -+.Fn "bufferevent_settimeout" "struct bufferevent *bufev" "int timeout_read" "int timeout_write" -+.Ft int -+.Fn "bufferevent_base_set" "struct event_base *base" "struct bufferevent *bufev" -+.Ft "struct evbuffer *" -+.Fn "evbuffer_new" "void" -+.Ft void -+.Fn "evbuffer_free" "struct evbuffer *buf" -+.Ft int -+.Fn "evbuffer_add" "struct evbuffer *buf" "const void *data" "size_t size" -+.Ft int -+.Fn "evbuffer_add_buffer" "struct evbuffer *dst" "struct evbuffer *src" -+.Ft int -+.Fn "evbuffer_add_printf" "struct evbuffer *buf" "const char *fmt" "..." -+.Ft int -+.Fn "evbuffer_add_vprintf" "struct evbuffer *buf" "const char *fmt" "va_list ap" -+.Ft void -+.Fn "evbuffer_drain" "struct evbuffer *buf" "size_t size" -+.Ft int -+.Fn "evbuffer_write" "struct evbuffer *buf" "int fd" -+.Ft int -+.Fn "evbuffer_read" "struct evbuffer *buf" "int fd" "int size" -+.Ft "u_char *" -+.Fn "evbuffer_find" "struct evbuffer *buf" "const u_char *data" "size_t size" -+.Ft "char *" -+.Fn "evbuffer_readline" "struct evbuffer *buf" -+.Ft "struct evhttp *" -+.Fn "evhttp_new" "struct event_base *base" -+.Ft int -+.Fn "evhttp_bind_socket" "struct evhttp *http" "const char *address" "u_short port" -+.Ft "void" -+.Fn "evhttp_free" "struct evhttp *http" -+.Ft int -+.Fa (*event_sigcb)(void) ; -+.Ft volatile sig_atomic_t -+.Fa event_gotsig ; -+.Sh DESCRIPTION -+The -+.Nm event -+API provides a mechanism to execute a function when a specific event -+on a file descriptor occurs or after a given time has passed. -+.Pp -+The -+.Nm event -+API needs to be initialized with -+.Fn event_init -+before it can be used. -+.Pp -+In order to process events, an application needs to call -+.Fn event_dispatch . -+This function only returns on error, and should replace the event core -+of the application program. -+.Pp -+The function -+.Fn event_set -+prepares the event structure -+.Fa ev -+to be used in future calls to -+.Fn event_add -+and -+.Fn event_del . -+The event will be prepared to call the function specified by the -+.Fa fn -+argument with an -+.Fa int -+argument indicating the file descriptor, a -+.Fa short -+argument indicating the type of event, and a -+.Fa void * -+argument given in the -+.Fa arg -+argument. -+The -+.Fa fd -+indicates the file descriptor that should be monitored for events. -+The events can be either -+.Va EV_READ , -+.Va EV_WRITE , -+or both, -+indicating that an application can read or write from the file descriptor -+respectively without blocking. -+.Pp -+The function -+.Fa fn -+will be called with the file descriptor that triggered the event and -+the type of event which will be either -+.Va EV_TIMEOUT , -+.Va EV_SIGNAL , -+.Va EV_READ , -+or -+.Va EV_WRITE . -+Additionally, an event which has registered interest in more than one of the -+preceeding events, via bitwise-OR to -+.Fn event_set , -+can provide its callback function with a bitwise-OR of more than one triggered -+event. -+The additional flag -+.Va EV_PERSIST -+makes an -+.Fn event_add -+persistent until -+.Fn event_del -+has been called. -+.Pp -+Once initialized, the -+.Fa ev -+structure can be used repeatedly with -+.Fn event_add -+and -+.Fn event_del -+and does not need to be reinitialized unless the function called and/or -+the argument to it are to be changed. -+However, when an -+.Fa ev -+structure has been added to libevent using -+.Fn event_add -+the structure must persist until the event occurs (assuming -+.Fa EV_PERSIST -+is not set) or is removed -+using -+.Fn event_del . -+You may not reuse the same -+.Fa ev -+structure for multiple monitored descriptors; each descriptor -+needs its own -+.Fa ev . -+.Pp -+The function -+.Fn event_add -+schedules the execution of the -+.Fa ev -+event when the event specified in -+.Fn event_set -+occurs or in at least the time specified in the -+.Fa tv . -+If -+.Fa tv -+is -+.Dv NULL , -+no timeout occurs and the function will only be called -+if a matching event occurs on the file descriptor. -+The event in the -+.Fa ev -+argument must be already initialized by -+.Fn event_set -+and may not be used in calls to -+.Fn event_set -+until it has timed out or been removed with -+.Fn event_del . -+If the event in the -+.Fa ev -+argument already has a scheduled timeout, the old timeout will be -+replaced by the new one. -+.Pp -+The function -+.Fn event_del -+will cancel the event in the argument -+.Fa ev . -+If the event has already executed or has never been added -+the call will have no effect. -+.Pp -+The functions -+.Fn evtimer_set , -+.Fn evtimer_add , -+.Fn evtimer_del , -+.Fn evtimer_initialized , -+and -+.Fn evtimer_pending -+are abbreviations for common situations where only a timeout is required. -+The file descriptor passed will be \-1, and the event type will be -+.Va EV_TIMEOUT . -+.Pp -+The functions -+.Fn signal_set , -+.Fn signal_add , -+.Fn signal_del , -+.Fn signal_initialized , -+and -+.Fn signal_pending -+are abbreviations. -+The event type will be a persistent -+.Va EV_SIGNAL . -+That means -+.Fn signal_set -+adds -+.Va EV_PERSIST . -+.Pp -+In order to avoid races in signal handlers, the -+.Nm event -+API provides two variables: -+.Va event_sigcb -+and -+.Va event_gotsig . -+A signal handler -+sets -+.Va event_gotsig -+to indicate that a signal has been received. -+The application sets -+.Va event_sigcb -+to a callback function. -+After the signal handler sets -+.Va event_gotsig , -+.Nm event_dispatch -+will execute the callback function to process received signals. -+The callback returns 1 when no events are registered any more. -+It can return \-1 to indicate an error to the -+.Nm event -+library, causing -+.Fn event_dispatch -+to terminate with -+.Va errno -+set to -+.Er EINTR . -+.Pp -+The function -+.Fn event_once -+is similar to -+.Fn event_set . -+However, it schedules a callback to be called exactly once and does not -+require the caller to prepare an -+.Fa event -+structure. -+This function supports -+.Fa EV_TIMEOUT , -+.Fa EV_READ , -+and -+.Fa EV_WRITE . -+.Pp -+The -+.Fn event_pending -+function can be used to check if the event specified by -+.Fa event -+is pending to run. -+If -+.Va EV_TIMEOUT -+was specified and -+.Fa tv -+is not -+.Dv NULL , -+the expiration time of the event will be returned in -+.Fa tv . -+.Pp -+The -+.Fn event_initialized -+macro can be used to check if an event has been initialized. -+.Pp -+The -+.Nm event_loop -+function provides an interface for single pass execution of pending -+events. -+The flags -+.Va EVLOOP_ONCE -+and -+.Va EVLOOP_NONBLOCK -+are recognized. -+The -+.Nm event_loopexit -+function exits from the event loop. The next -+.Fn event_loop -+iteration after the -+given timer expires will complete normally (handling all queued events) then -+exit without blocking for events again. Subsequent invocations of -+.Fn event_loop -+will proceed normally. -+The -+.Nm event_loopbreak -+function exits from the event loop immediately. -+.Fn event_loop -+will abort after the next event is completed; -+.Fn event_loopbreak -+is typically invoked from this event's callback. This behavior is analogous -+to the "break;" statement. Subsequent invocations of -+.Fn event_loop -+will proceed normally. -+.Pp -+It is the responsibility of the caller to provide these functions with -+pre-allocated event structures. -+.Pp -+.Sh EVENT PRIORITIES -+By default -+.Nm libevent -+schedules all active events with the same priority. -+However, sometimes it is desirable to process some events with a higher -+priority than others. -+For that reason, -+.Nm libevent -+supports strict priority queues. -+Active events with a lower priority are always processed before events -+with a higher priority. -+.Pp -+The number of different priorities can be set initially with the -+.Fn event_priority_init -+function. -+This function should be called before the first call to -+.Fn event_dispatch . -+The -+.Fn event_priority_set -+function can be used to assign a priority to an event. -+By default, -+.Nm libevent -+assigns the middle priority to all events unless their priority -+is explicitly set. -+.Sh THREAD SAFE EVENTS -+.Nm Libevent -+has experimental support for thread-safe events. -+When initializing the library via -+.Fn event_init , -+an event base is returned. -+This event base can be used in conjunction with calls to -+.Fn event_base_set , -+.Fn event_base_dispatch , -+.Fn event_base_loop , -+.Fn event_base_loopexit , -+.Fn bufferevent_base_set -+and -+.Fn event_base_free . -+.Fn event_base_set -+should be called after preparing an event with -+.Fn event_set , -+as -+.Fn event_set -+assigns the provided event to the most recently created event base. -+.Fn bufferevent_base_set -+should be called after preparing a bufferevent with -+.Fn bufferevent_new . -+.Fn event_base_free -+should be used to free memory associated with the event base -+when it is no longer needed. -+.Sh BUFFERED EVENTS -+.Nm libevent -+provides an abstraction on top of the regular event callbacks. -+This abstraction is called a -+.Va "buffered event" . -+A buffered event provides input and output buffers that get filled -+and drained automatically. -+The user of a buffered event no longer deals directly with the IO, -+but instead is reading from input and writing to output buffers. -+.Pp -+A new bufferevent is created by -+.Fn bufferevent_new . -+The parameter -+.Fa fd -+specifies the file descriptor from which data is read and written to. -+This file descriptor is not allowed to be a -+.Xr pipe 2 . -+The next three parameters are callbacks. -+The read and write callback have the following form: -+.Ft void -+.Fn "(*cb)" "struct bufferevent *bufev" "void *arg" . -+The error callback has the following form: -+.Ft void -+.Fn "(*cb)" "struct bufferevent *bufev" "short what" "void *arg" . -+The argument is specified by the fourth parameter -+.Fa "cbarg" . -+A -+.Fa bufferevent struct -+pointer is returned on success, NULL on error. -+Both the read and the write callback may be NULL. -+The error callback has to be always provided. -+.Pp -+Once initialized, the bufferevent structure can be used repeatedly with -+bufferevent_enable() and bufferevent_disable(). -+The flags parameter can be a combination of -+.Va EV_READ -+and -+.Va EV_WRITE . -+When read enabled the bufferevent will try to read from the file -+descriptor and call the read callback. -+The write callback is executed -+whenever the output buffer is drained below the write low watermark, -+which is -+.Va 0 -+by default. -+.Pp -+The -+.Fn bufferevent_write -+function can be used to write data to the file descriptor. -+The data is appended to the output buffer and written to the descriptor -+automatically as it becomes available for writing. -+.Fn bufferevent_write -+returns 0 on success or \-1 on failure. -+The -+.Fn bufferevent_read -+function is used to read data from the input buffer, -+returning the amount of data read. -+.Pp -+If multiple bases are in use, bufferevent_base_set() must be called before -+enabling the bufferevent for the first time. -+.Sh NON-BLOCKING HTTP SUPPORT -+.Nm libevent -+provides a very thin HTTP layer that can be used both to host an HTTP -+server and also to make HTTP requests. -+An HTTP server can be created by calling -+.Fn evhttp_new . -+It can be bound to any port and address with the -+.Fn evhttp_bind_socket -+function. -+When the HTTP server is no longer used, it can be freed via -+.Fn evhttp_free . -+.Pp -+To be notified of HTTP requests, a user needs to register callbacks with the -+HTTP server. -+This can be done by calling -+.Fn evhttp_set_cb . -+The second argument is the URI for which a callback is being registered. -+The corresponding callback will receive an -+.Va struct evhttp_request -+object that contains all information about the request. -+.Pp -+This section does not document all the possible function calls; please -+check -+.Va event.h -+for the public interfaces. -+.Sh ADDITIONAL NOTES -+It is possible to disable support for -+.Va epoll , kqueue , devpoll , poll -+or -+.Va select -+by setting the environment variable -+.Va EVENT_NOEPOLL , EVENT_NOKQUEUE , EVENT_NODEVPOLL , EVENT_NOPOLL -+or -+.Va EVENT_NOSELECT , -+respectively. -+By setting the environment variable -+.Va EVENT_SHOW_METHOD , -+.Nm libevent -+displays the kernel notification method that it uses. -+.Sh RETURN VALUES -+Upon successful completion -+.Fn event_add -+and -+.Fn event_del -+return 0. -+Otherwise, \-1 is returned and the global variable errno is -+set to indicate the error. -+.Sh SEE ALSO -+.Xr kqueue 2 , -+.Xr poll 2 , -+.Xr select 2 , -+.Xr evdns 3 , -+.Xr timeout 9 -+.Sh HISTORY -+The -+.Nm event -+API manpage is based on the -+.Xr timeout 9 -+manpage by Artur Grabowski. -+The port of -+.Nm libevent -+to Windows is due to Michael A. Davis. -+Support for real-time signals is due to Taral. -+.Sh AUTHORS -+The -+.Nm event -+library was written by Niels Provos. -+.Sh BUGS -+This documentation is neither complete nor authoritative. -+If you are in doubt about the usage of this API then -+check the source code to find out how it works, write -+up the missing piece of documentation and send it to -+me for inclusion in this man page. -diff --git a/libevent/event.c b/libevent/event.c -new file mode 100644 -index 0000000..826b7db ---- /dev/null -+++ b/libevent/event.c -@@ -0,0 +1,977 @@ -+/* -+ * Copyright (c) 2000-2004 Niels Provos -+ * All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. The name of the author may not be used to endorse or promote products -+ * derived from this software without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR -+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES -+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. -+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, -+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT -+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF -+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+ */ -+#ifdef HAVE_CONFIG_H -+#include "config.h" -+#endif -+ -+#ifdef WIN32 -+#define WIN32_LEAN_AND_MEAN -+#include -+#undef WIN32_LEAN_AND_MEAN -+#endif -+#include -+#ifdef HAVE_SYS_TIME_H -+#include -+#else -+#include -+#endif -+#include -+#include -+#include -+#ifndef WIN32 -+#include -+#endif -+#include -+#include -+#include -+#include -+#include -+ -+#include "event.h" -+#include "event-internal.h" -+#include "evutil.h" -+#include "log.h" -+ -+#ifdef HAVE_EVENT_PORTS -+extern const struct eventop evportops; -+#endif -+#ifdef HAVE_SELECT -+extern const struct eventop selectops; -+#endif -+#ifdef HAVE_POLL -+extern const struct eventop pollops; -+#endif -+#ifdef HAVE_EPOLL -+extern const struct eventop epollops; -+#endif -+#ifdef HAVE_WORKING_KQUEUE -+extern const struct eventop kqops; -+#endif -+#ifdef HAVE_DEVPOLL -+extern const struct eventop devpollops; -+#endif -+#ifdef WIN32 -+extern const struct eventop win32ops; -+#endif -+ -+/* In order of preference */ -+static const struct eventop *eventops[] = { -+#ifdef HAVE_EVENT_PORTS -+ &evportops, -+#endif -+#ifdef HAVE_WORKING_KQUEUE -+ &kqops, -+#endif -+#ifdef HAVE_EPOLL -+ &epollops, -+#endif -+#ifdef HAVE_DEVPOLL -+ &devpollops, -+#endif -+#ifdef HAVE_POLL -+ &pollops, -+#endif -+#ifdef HAVE_SELECT -+ &selectops, -+#endif -+#ifdef WIN32 -+ &win32ops, -+#endif -+ NULL -+}; -+ -+/* Global state */ -+struct event_base *current_base = NULL; -+extern struct event_base *evsignal_base; -+static int use_monotonic; -+ -+/* Handle signals - This is a deprecated interface */ -+int (*event_sigcb)(void); /* Signal callback when gotsig is set */ -+volatile sig_atomic_t event_gotsig; /* Set in signal handler */ -+ -+/* Prototypes */ -+static void event_queue_insert(struct event_base *, struct event *, int); -+static void event_queue_remove(struct event_base *, struct event *, int); -+static int event_haveevents(struct event_base *); -+ -+static void event_process_active(struct event_base *); -+ -+static int timeout_next(struct event_base *, struct timeval **); -+static void timeout_process(struct event_base *); -+static void timeout_correct(struct event_base *, struct timeval *); -+ -+static void -+detect_monotonic(void) -+{ -+#if defined(HAVE_CLOCK_GETTIME) && defined(CLOCK_MONOTONIC) -+ struct timespec ts; -+ -+ if (clock_gettime(CLOCK_MONOTONIC, &ts) == 0) -+ use_monotonic = 1; -+#endif -+} -+ -+static int -+gettime(struct event_base *base, struct timeval *tp) -+{ -+ if (base->tv_cache.tv_sec) { -+ *tp = base->tv_cache; -+ return (0); -+ } -+ -+#if defined(HAVE_CLOCK_GETTIME) && defined(CLOCK_MONOTONIC) -+ if (use_monotonic) { -+ struct timespec ts; -+ -+ if (clock_gettime(CLOCK_MONOTONIC, &ts) == -1) -+ return (-1); -+ -+ tp->tv_sec = ts.tv_sec; -+ tp->tv_usec = ts.tv_nsec / 1000; -+ return (0); -+ } -+#endif -+ -+ return (evutil_gettimeofday(tp, NULL)); -+} -+ -+struct event_base * -+event_init(void) -+{ -+ struct event_base *base = event_base_new(); -+ -+ if (base != NULL) -+ current_base = base; -+ -+ return (base); -+} -+ -+struct event_base * -+event_base_new(void) -+{ -+ int i; -+ struct event_base *base; -+ -+ if ((base = calloc(1, sizeof(struct event_base))) == NULL) -+ event_err(1, "%s: calloc", __func__); -+ -+ event_sigcb = NULL; -+ event_gotsig = 0; -+ -+ detect_monotonic(); -+ gettime(base, &base->event_tv); -+ -+ min_heap_ctor(&base->timeheap); -+ TAILQ_INIT(&base->eventqueue); -+ base->sig.ev_signal_pair[0] = -1; -+ base->sig.ev_signal_pair[1] = -1; -+ -+ base->evbase = NULL; -+ for (i = 0; eventops[i] && !base->evbase; i++) { -+ base->evsel = eventops[i]; -+ -+ base->evbase = base->evsel->init(base); -+ } -+ -+ if (base->evbase == NULL) -+ event_errx(1, "%s: no event mechanism available", __func__); -+ -+ if (getenv("EVENT_SHOW_METHOD")) -+ event_msgx("libevent using: %s\n", -+ base->evsel->name); -+ -+ /* allocate a single active event queue */ -+ event_base_priority_init(base, 1); -+ -+ return (base); -+} -+ -+void -+event_base_free(struct event_base *base) -+{ -+ int i; -+ -+ if (base == NULL && current_base) -+ base = current_base; -+ if (base == current_base) -+ current_base = NULL; -+ -+ assert(base); -+ -+ if (base->evsel->dealloc != NULL) -+ base->evsel->dealloc(base, base->evbase); -+ -+ min_heap_dtor(&base->timeheap); -+ -+ for (i = 0; i < base->nactivequeues; ++i) -+ free(base->activequeues[i]); -+ free(base->activequeues); -+ -+ free(base); -+} -+ -+/* reinitialized the event base after a fork */ -+int -+event_reinit(struct event_base *base) -+{ -+ const struct eventop *evsel = base->evsel; -+ void *evbase = base->evbase; -+ int res = 0; -+ struct event *ev; -+ -+ /* check if this event mechanism requires reinit */ -+ if (!evsel->need_reinit) -+ return (0); -+ -+ /* prevent internal delete */ -+ if (base->sig.ev_signal_added) { -+ event_queue_remove(base, &base->sig.ev_signal, -+ EVLIST_INSERTED); -+ base->sig.ev_signal_added = 0; -+ } -+ -+ if (base->evsel->dealloc != NULL) -+ base->evsel->dealloc(base, base->evbase); -+ evbase = base->evbase = evsel->init(base); -+ if (base->evbase == NULL) -+ event_errx(1, "%s: could not reinitialize event mechanism", -+ __func__); -+ -+ TAILQ_FOREACH(ev, &base->eventqueue, ev_next) { -+ if (evsel->add(evbase, ev) == -1) -+ res = -1; -+ } -+ -+ return (res); -+} -+ -+int -+event_priority_init(int npriorities) -+{ -+ return event_base_priority_init(current_base, npriorities); -+} -+ -+int -+event_base_priority_init(struct event_base *base, int npriorities) -+{ -+ int i; -+ -+ if (base->event_count_active) -+ return (-1); -+ -+ if (base->nactivequeues && npriorities != base->nactivequeues) { -+ for (i = 0; i < base->nactivequeues; ++i) { -+ free(base->activequeues[i]); -+ } -+ free(base->activequeues); -+ } -+ -+ /* Allocate our priority queues */ -+ base->nactivequeues = npriorities; -+ base->activequeues = (struct event_list **)calloc(base->nactivequeues, -+ npriorities * sizeof(struct event_list *)); -+ if (base->activequeues == NULL) -+ event_err(1, "%s: calloc", __func__); -+ -+ for (i = 0; i < base->nactivequeues; ++i) { -+ base->activequeues[i] = malloc(sizeof(struct event_list)); -+ if (base->activequeues[i] == NULL) -+ event_err(1, "%s: malloc", __func__); -+ TAILQ_INIT(base->activequeues[i]); -+ } -+ -+ return (0); -+} -+ -+int -+event_haveevents(struct event_base *base) -+{ -+ return (base->event_count > 0); -+} -+ -+/* -+ * Active events are stored in priority queues. Lower priorities are always -+ * process before higher priorities. Low priority events can starve high -+ * priority ones. -+ */ -+ -+static void -+event_process_active(struct event_base *base) -+{ -+ struct event *ev; -+ struct event_list *activeq = NULL; -+ int i; -+ short ncalls; -+ -+ for (i = 0; i < base->nactivequeues; ++i) { -+ if (TAILQ_FIRST(base->activequeues[i]) != NULL) { -+ activeq = base->activequeues[i]; -+ break; -+ } -+ } -+ -+ assert(activeq != NULL); -+ -+ for (ev = TAILQ_FIRST(activeq); ev; ev = TAILQ_FIRST(activeq)) { -+ if (ev->ev_events & EV_PERSIST) -+ event_queue_remove(base, ev, EVLIST_ACTIVE); -+ else -+ event_del(ev); -+ -+ /* Allows deletes to work */ -+ ncalls = ev->ev_ncalls; -+ ev->ev_pncalls = &ncalls; -+ while (ncalls) { -+ ncalls--; -+ ev->ev_ncalls = ncalls; -+ (*ev->ev_callback)((int)ev->ev_fd, ev->ev_res, ev->ev_arg); -+ if (event_gotsig || base->event_break) -+ return; -+ } -+ } -+} -+ -+/* -+ * Wait continously for events. We exit only if no events are left. -+ */ -+ -+int -+event_dispatch(void) -+{ -+ return (event_loop(0)); -+} -+ -+int -+event_base_dispatch(struct event_base *event_base) -+{ -+ return (event_base_loop(event_base, 0)); -+} -+ -+const char * -+event_base_get_method(struct event_base *base) -+{ -+ assert(base); -+ return (base->evsel->name); -+} -+ -+static void -+event_loopexit_cb(int fd, short what, void *arg) -+{ -+ struct event_base *base = arg; -+ base->event_gotterm = 1; -+} -+ -+/* not thread safe */ -+int -+event_loopexit(const struct timeval *tv) -+{ -+ return (event_once(-1, EV_TIMEOUT, event_loopexit_cb, -+ current_base, tv)); -+ -+} -+ -+int -+event_base_loopexit(struct event_base *event_base, const struct timeval *tv) -+{ -+ return (event_base_once(event_base, -1, EV_TIMEOUT, event_loopexit_cb, -+ event_base, tv)); -+} -+ -+/* not thread safe */ -+int -+event_loopbreak(void) -+{ -+ return (event_base_loopbreak(current_base)); -+} -+ -+int -+event_base_loopbreak(struct event_base *event_base) -+{ -+ if (event_base == NULL) -+ return (-1); -+ -+ event_base->event_break = 1; -+ return (0); -+} -+ -+ -+ -+/* not thread safe */ -+ -+int -+event_loop(int flags) -+{ -+ return event_base_loop(current_base, flags); -+} -+ -+int -+event_base_loop(struct event_base *base, int flags) -+{ -+ const struct eventop *evsel = base->evsel; -+ void *evbase = base->evbase; -+ struct timeval tv; -+ struct timeval *tv_p; -+ int res, done; -+ -+ if (&base->sig.ev_signal_added) -+ evsignal_base = base; -+ done = 0; -+ while (!done) { -+ /* Terminate the loop if we have been asked to */ -+ if (base->event_gotterm) { -+ base->event_gotterm = 0; -+ break; -+ } -+ -+ if (base->event_break) { -+ base->event_break = 0; -+ break; -+ } -+ -+ /* You cannot use this interface for multi-threaded apps */ -+ while (event_gotsig) { -+ event_gotsig = 0; -+ if (event_sigcb) { -+ res = (*event_sigcb)(); -+ if (res == -1) { -+ errno = EINTR; -+ return (-1); -+ } -+ } -+ } -+ -+ timeout_correct(base, &tv); -+ -+ tv_p = &tv; -+ if (!base->event_count_active && !(flags & EVLOOP_NONBLOCK)) { -+ timeout_next(base, &tv_p); -+ } else { -+ /* -+ * if we have active events, we just poll new events -+ * without waiting. -+ */ -+ evutil_timerclear(&tv); -+ } -+ -+ /* If we have no events, we just exit */ -+ if (!event_haveevents(base)) { -+ event_debug(("%s: no events registered.", __func__)); -+ return (1); -+ } -+ -+ /* update last old time */ -+ gettime(base, &base->event_tv); -+ -+ /* clear time cache */ -+ base->tv_cache.tv_sec = 0; -+ -+ res = evsel->dispatch(base, evbase, tv_p); -+ -+ if (res == -1) -+ return (-1); -+ gettime(base, &base->tv_cache); -+ -+ timeout_process(base); -+ -+ if (base->event_count_active) { -+ event_process_active(base); -+ if (!base->event_count_active && (flags & EVLOOP_ONCE)) -+ done = 1; -+ } else if (flags & EVLOOP_NONBLOCK) -+ done = 1; -+ } -+ -+ event_debug(("%s: asked to terminate loop.", __func__)); -+ return (0); -+} -+ -+/* Sets up an event for processing once */ -+ -+struct event_once { -+ struct event ev; -+ -+ void (*cb)(int, short, void *); -+ void *arg; -+}; -+ -+/* One-time callback, it deletes itself */ -+ -+static void -+event_once_cb(int fd, short events, void *arg) -+{ -+ struct event_once *eonce = arg; -+ -+ (*eonce->cb)(fd, events, eonce->arg); -+ free(eonce); -+} -+ -+/* not threadsafe, event scheduled once. */ -+int -+event_once(int fd, short events, -+ void (*callback)(int, short, void *), void *arg, const struct timeval *tv) -+{ -+ return event_base_once(current_base, fd, events, callback, arg, tv); -+} -+ -+/* Schedules an event once */ -+int -+event_base_once(struct event_base *base, int fd, short events, -+ void (*callback)(int, short, void *), void *arg, const struct timeval *tv) -+{ -+ struct event_once *eonce; -+ struct timeval etv; -+ int res; -+ -+ /* We cannot support signals that just fire once */ -+ if (events & EV_SIGNAL) -+ return (-1); -+ -+ if ((eonce = calloc(1, sizeof(struct event_once))) == NULL) -+ return (-1); -+ -+ eonce->cb = callback; -+ eonce->arg = arg; -+ -+ if (events == EV_TIMEOUT) { -+ if (tv == NULL) { -+ evutil_timerclear(&etv); -+ tv = &etv; -+ } -+ -+ evtimer_set(&eonce->ev, event_once_cb, eonce); -+ } else if (events & (EV_READ|EV_WRITE)) { -+ events &= EV_READ|EV_WRITE; -+ -+ event_set(&eonce->ev, fd, events, event_once_cb, eonce); -+ } else { -+ /* Bad event combination */ -+ free(eonce); -+ return (-1); -+ } -+ -+ res = event_base_set(base, &eonce->ev); -+ if (res == 0) -+ res = event_add(&eonce->ev, tv); -+ if (res != 0) { -+ free(eonce); -+ return (res); -+ } -+ -+ return (0); -+} -+ -+void -+event_set(struct event *ev, int fd, short events, -+ void (*callback)(int, short, void *), void *arg) -+{ -+ /* Take the current base - caller needs to set the real base later */ -+ ev->ev_base = current_base; -+ -+ ev->ev_callback = callback; -+ ev->ev_arg = arg; -+ ev->ev_fd = fd; -+ ev->ev_events = events; -+ ev->ev_res = 0; -+ ev->ev_flags = EVLIST_INIT; -+ ev->ev_ncalls = 0; -+ ev->ev_pncalls = NULL; -+ -+ min_heap_elem_init(ev); -+ -+ /* by default, we put new events into the middle priority */ -+ if(current_base) -+ ev->ev_pri = current_base->nactivequeues/2; -+} -+ -+int -+event_base_set(struct event_base *base, struct event *ev) -+{ -+ /* Only innocent events may be assigned to a different base */ -+ if (ev->ev_flags != EVLIST_INIT) -+ return (-1); -+ -+ ev->ev_base = base; -+ ev->ev_pri = base->nactivequeues/2; -+ -+ return (0); -+} -+ -+/* -+ * Set's the priority of an event - if an event is already scheduled -+ * changing the priority is going to fail. -+ */ -+ -+int -+event_priority_set(struct event *ev, int pri) -+{ -+ if (ev->ev_flags & EVLIST_ACTIVE) -+ return (-1); -+ if (pri < 0 || pri >= ev->ev_base->nactivequeues) -+ return (-1); -+ -+ ev->ev_pri = pri; -+ -+ return (0); -+} -+ -+/* -+ * Checks if a specific event is pending or scheduled. -+ */ -+ -+int -+event_pending(struct event *ev, short event, struct timeval *tv) -+{ -+ struct timeval now, res; -+ int flags = 0; -+ -+ if (ev->ev_flags & EVLIST_INSERTED) -+ flags |= (ev->ev_events & (EV_READ|EV_WRITE|EV_SIGNAL)); -+ if (ev->ev_flags & EVLIST_ACTIVE) -+ flags |= ev->ev_res; -+ if (ev->ev_flags & EVLIST_TIMEOUT) -+ flags |= EV_TIMEOUT; -+ -+ event &= (EV_TIMEOUT|EV_READ|EV_WRITE|EV_SIGNAL); -+ -+ /* See if there is a timeout that we should report */ -+ if (tv != NULL && (flags & event & EV_TIMEOUT)) { -+ gettime(ev->ev_base, &now); -+ evutil_timersub(&ev->ev_timeout, &now, &res); -+ /* correctly remap to real time */ -+ evutil_gettimeofday(&now, NULL); -+ evutil_timeradd(&now, &res, tv); -+ } -+ -+ return (flags & event); -+} -+ -+int -+event_add(struct event *ev, const struct timeval *tv) -+{ -+ struct event_base *base = ev->ev_base; -+ const struct eventop *evsel = base->evsel; -+ void *evbase = base->evbase; -+ int res = 0; -+ -+ event_debug(( -+ "event_add: event: %p, %s%s%scall %p", -+ ev, -+ ev->ev_events & EV_READ ? "EV_READ " : " ", -+ ev->ev_events & EV_WRITE ? "EV_WRITE " : " ", -+ tv ? "EV_TIMEOUT " : " ", -+ ev->ev_callback)); -+ -+ assert(!(ev->ev_flags & ~EVLIST_ALL)); -+ -+ /* -+ * prepare for timeout insertion further below, if we get a -+ * failure on any step, we should not change any state. -+ */ -+ if (tv != NULL && !(ev->ev_flags & EVLIST_TIMEOUT)) { -+ if (min_heap_reserve(&base->timeheap, -+ 1 + min_heap_size(&base->timeheap)) == -1) -+ return (-1); /* ENOMEM == errno */ -+ } -+ -+ if ((ev->ev_events & (EV_READ|EV_WRITE|EV_SIGNAL)) && -+ !(ev->ev_flags & (EVLIST_INSERTED|EVLIST_ACTIVE))) { -+ res = evsel->add(evbase, ev); -+ if (res != -1) -+ event_queue_insert(base, ev, EVLIST_INSERTED); -+ } -+ -+ /* -+ * we should change the timout state only if the previous event -+ * addition succeeded. -+ */ -+ if (res != -1 && tv != NULL) { -+ struct timeval now; -+ -+ /* -+ * we already reserved memory above for the case where we -+ * are not replacing an exisiting timeout. -+ */ -+ if (ev->ev_flags & EVLIST_TIMEOUT) -+ event_queue_remove(base, ev, EVLIST_TIMEOUT); -+ -+ /* Check if it is active due to a timeout. Rescheduling -+ * this timeout before the callback can be executed -+ * removes it from the active list. */ -+ if ((ev->ev_flags & EVLIST_ACTIVE) && -+ (ev->ev_res & EV_TIMEOUT)) { -+ /* See if we are just active executing this -+ * event in a loop -+ */ -+ if (ev->ev_ncalls && ev->ev_pncalls) { -+ /* Abort loop */ -+ *ev->ev_pncalls = 0; -+ } -+ -+ event_queue_remove(base, ev, EVLIST_ACTIVE); -+ } -+ -+ gettime(base, &now); -+ evutil_timeradd(&now, tv, &ev->ev_timeout); -+ -+ event_debug(( -+ "event_add: timeout in %ld seconds, call %p", -+ tv->tv_sec, ev->ev_callback)); -+ -+ event_queue_insert(base, ev, EVLIST_TIMEOUT); -+ } -+ -+ return (0); -+} -+ -+int -+event_del(struct event *ev) -+{ -+ struct event_base *base; -+ const struct eventop *evsel; -+ void *evbase; -+ -+ event_debug(("event_del: %p, callback %p", -+ ev, ev->ev_callback)); -+ -+ /* An event without a base has not been added */ -+ if (ev->ev_base == NULL) -+ return (-1); -+ -+ base = ev->ev_base; -+ evsel = base->evsel; -+ evbase = base->evbase; -+ -+ assert(!(ev->ev_flags & ~EVLIST_ALL)); -+ -+ /* See if we are just active executing this event in a loop */ -+ if (ev->ev_ncalls && ev->ev_pncalls) { -+ /* Abort loop */ -+ *ev->ev_pncalls = 0; -+ } -+ -+ if (ev->ev_flags & EVLIST_TIMEOUT) -+ event_queue_remove(base, ev, EVLIST_TIMEOUT); -+ -+ if (ev->ev_flags & EVLIST_ACTIVE) -+ event_queue_remove(base, ev, EVLIST_ACTIVE); -+ -+ if (ev->ev_flags & EVLIST_INSERTED) { -+ event_queue_remove(base, ev, EVLIST_INSERTED); -+ return (evsel->del(evbase, ev)); -+ } -+ -+ return (0); -+} -+ -+void -+event_active(struct event *ev, int res, short ncalls) -+{ -+ /* We get different kinds of events, add them together */ -+ if (ev->ev_flags & EVLIST_ACTIVE) { -+ ev->ev_res |= res; -+ return; -+ } -+ -+ ev->ev_res = res; -+ ev->ev_ncalls = ncalls; -+ ev->ev_pncalls = NULL; -+ event_queue_insert(ev->ev_base, ev, EVLIST_ACTIVE); -+} -+ -+static int -+timeout_next(struct event_base *base, struct timeval **tv_p) -+{ -+ struct timeval now; -+ struct event *ev; -+ struct timeval *tv = *tv_p; -+ -+ if ((ev = min_heap_top(&base->timeheap)) == NULL) { -+ /* if no time-based events are active wait for I/O */ -+ *tv_p = NULL; -+ return (0); -+ } -+ -+ if (gettime(base, &now) == -1) -+ return (-1); -+ -+ if (evutil_timercmp(&ev->ev_timeout, &now, <=)) { -+ evutil_timerclear(tv); -+ return (0); -+ } -+ -+ evutil_timersub(&ev->ev_timeout, &now, tv); -+ -+ assert(tv->tv_sec >= 0); -+ assert(tv->tv_usec >= 0); -+ -+ event_debug(("timeout_next: in %ld seconds", tv->tv_sec)); -+ return (0); -+} -+ -+/* -+ * Determines if the time is running backwards by comparing the current -+ * time against the last time we checked. Not needed when using clock -+ * monotonic. -+ */ -+ -+static void -+timeout_correct(struct event_base *base, struct timeval *tv) -+{ -+ struct event **pev; -+ unsigned int size; -+ struct timeval off; -+ -+ if (use_monotonic) -+ return; -+ -+ /* Check if time is running backwards */ -+ gettime(base, tv); -+ if (evutil_timercmp(tv, &base->event_tv, >=)) { -+ base->event_tv = *tv; -+ return; -+ } -+ -+ event_debug(("%s: time is running backwards, corrected", -+ __func__)); -+ evutil_timersub(&base->event_tv, tv, &off); -+ -+ /* -+ * We can modify the key element of the node without destroying -+ * the key, beause we apply it to all in the right order. -+ */ -+ pev = base->timeheap.p; -+ size = base->timeheap.n; -+ for (; size-- > 0; ++pev) { -+ struct timeval *ev_tv = &(**pev).ev_timeout; -+ evutil_timersub(ev_tv, &off, ev_tv); -+ } -+} -+ -+void -+timeout_process(struct event_base *base) -+{ -+ struct timeval now; -+ struct event *ev; -+ -+ if (min_heap_empty(&base->timeheap)) -+ return; -+ -+ gettime(base, &now); -+ -+ while ((ev = min_heap_top(&base->timeheap))) { -+ if (evutil_timercmp(&ev->ev_timeout, &now, >)) -+ break; -+ -+ /* delete this event from the I/O queues */ -+ event_del(ev); -+ -+ event_debug(("timeout_process: call %p", -+ ev->ev_callback)); -+ event_active(ev, EV_TIMEOUT, 1); -+ } -+} -+ -+void -+event_queue_remove(struct event_base *base, struct event *ev, int queue) -+{ -+ if (!(ev->ev_flags & queue)) -+ event_errx(1, "%s: %p(fd %d) not on queue %x", __func__, -+ ev, ev->ev_fd, queue); -+ -+ if (~ev->ev_flags & EVLIST_INTERNAL) -+ base->event_count--; -+ -+ ev->ev_flags &= ~queue; -+ switch (queue) { -+ case EVLIST_INSERTED: -+ TAILQ_REMOVE(&base->eventqueue, ev, ev_next); -+ break; -+ case EVLIST_ACTIVE: -+ base->event_count_active--; -+ TAILQ_REMOVE(base->activequeues[ev->ev_pri], -+ ev, ev_active_next); -+ break; -+ case EVLIST_TIMEOUT: -+ min_heap_erase(&base->timeheap, ev); -+ break; -+ default: -+ event_errx(1, "%s: unknown queue %x", __func__, queue); -+ } -+} -+ -+void -+event_queue_insert(struct event_base *base, struct event *ev, int queue) -+{ -+ if (ev->ev_flags & queue) { -+ /* Double insertion is possible for active events */ -+ if (queue & EVLIST_ACTIVE) -+ return; -+ -+ event_errx(1, "%s: %p(fd %d) already on queue %x", __func__, -+ ev, ev->ev_fd, queue); -+ } -+ -+ if (~ev->ev_flags & EVLIST_INTERNAL) -+ base->event_count++; -+ -+ ev->ev_flags |= queue; -+ switch (queue) { -+ case EVLIST_INSERTED: -+ TAILQ_INSERT_TAIL(&base->eventqueue, ev, ev_next); -+ break; -+ case EVLIST_ACTIVE: -+ base->event_count_active++; -+ TAILQ_INSERT_TAIL(base->activequeues[ev->ev_pri], -+ ev,ev_active_next); -+ break; -+ case EVLIST_TIMEOUT: { -+ min_heap_push(&base->timeheap, ev); -+ break; -+ } -+ default: -+ event_errx(1, "%s: unknown queue %x", __func__, queue); -+ } -+} -+ -+/* Functions for debugging */ -+ -+const char * -+event_get_version(void) -+{ -+ return (VERSION); -+} -+ -+/* -+ * No thread-safe interface needed - the information should be the same -+ * for all threads. -+ */ -+ -+const char * -+event_get_method(void) -+{ -+ return (current_base->evsel->name); -+} -diff --git a/libevent/event.h b/libevent/event.h -new file mode 100644 -index 0000000..d67ecb5 ---- /dev/null -+++ b/libevent/event.h -@@ -0,0 +1,1203 @@ -+/* -+ * Copyright (c) 2000-2007 Niels Provos -+ * All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. The name of the author may not be used to endorse or promote products -+ * derived from this software without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR -+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES -+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. -+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, -+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT -+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF -+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+ */ -+#ifndef _EVENT_H_ -+#define _EVENT_H_ -+ -+#include "event-fpm.h" -+ -+/** @mainpage -+ -+ @section intro Introduction -+ -+ libevent is an event notification library for developing scalable network -+ servers. The libevent API provides a mechanism to execute a callback -+ function when a specific event occurs on a file descriptor or after a -+ timeout has been reached. Furthermore, libevent also support callbacks due -+ to signals or regular timeouts. -+ -+ libevent is meant to replace the event loop found in event driven network -+ servers. An application just needs to call event_dispatch() and then add or -+ remove events dynamically without having to change the event loop. -+ -+ Currently, libevent supports /dev/poll, kqueue(2), select(2), poll(2) and -+ epoll(4). It also has experimental support for real-time signals. The -+ internal event mechanism is completely independent of the exposed event API, -+ and a simple update of libevent can provide new functionality without having -+ to redesign the applications. As a result, Libevent allows for portable -+ application development and provides the most scalable event notification -+ mechanism available on an operating system. Libevent can also be used for -+ multi-threaded aplications; see Steven Grimm's explanation. Libevent should -+ compile on Linux, *BSD, Mac OS X, Solaris and Windows. -+ -+ @section usage Standard usage -+ -+ Every program that uses libevent must include the header, and pass -+ the -levent flag to the linker. Before using any of the functions in the -+ library, you must call event_init() or event_base_new() to perform one-time -+ initialization of the libevent library. -+ -+ @section event Event notification -+ -+ For each file descriptor that you wish to monitor, you must declare an event -+ structure and call event_set() to initialize the members of the structure. -+ To enable notification, you add the structure to the list of monitored -+ events by calling event_add(). The event structure must remain allocated as -+ long as it is active, so it should be allocated on the heap. Finally, you -+ call event_dispatch() to loop and dispatch events. -+ -+ @section bufferevent I/O Buffers -+ -+ libevent provides an abstraction on top of the regular event callbacks. This -+ abstraction is called a buffered event. A buffered event provides input and -+ output buffers that get filled and drained automatically. The user of a -+ buffered event no longer deals directly with the I/O, but instead is reading -+ from input and writing to output buffers. -+ -+ Once initialized via bufferevent_new(), the bufferevent structure can be -+ used repeatedly with bufferevent_enable() and bufferevent_disable(). -+ Instead of reading and writing directly to a socket, you would call -+ bufferevent_read() and bufferevent_write(). -+ -+ When read enabled the bufferevent will try to read from the file descriptor -+ and call the read callback. The write callback is executed whenever the -+ output buffer is drained below the write low watermark, which is 0 by -+ default. -+ -+ @section timers Timers -+ -+ libevent can also be used to create timers that invoke a callback after a -+ certain amount of time has expired. The evtimer_set() function prepares an -+ event struct to be used as a timer. To activate the timer, call -+ evtimer_add(). Timers can be deactivated by calling evtimer_del(). -+ -+ @section timeouts Timeouts -+ -+ In addition to simple timers, libevent can assign timeout events to file -+ descriptors that are triggered whenever a certain amount of time has passed -+ with no activity on a file descriptor. The timeout_set() function -+ initializes an event struct for use as a timeout. Once initialized, the -+ event must be activated by using timeout_add(). To cancel the timeout, call -+ timeout_del(). -+ -+ @section evdns Asynchronous DNS resolution -+ -+ libevent provides an asynchronous DNS resolver that should be used instead -+ of the standard DNS resolver functions. These functions can be imported by -+ including the header in your program. Before using any of the -+ resolver functions, you must call evdns_init() to initialize the library. To -+ convert a hostname to an IP address, you call the evdns_resolve_ipv4() -+ function. To perform a reverse lookup, you would call the -+ evdns_resolve_reverse() function. All of these functions use callbacks to -+ avoid blocking while the lookup is performed. -+ -+ @section evhttp Event-driven HTTP servers -+ -+ libevent provides a very simple event-driven HTTP server that can be -+ embedded in your program and used to service HTTP requests. -+ -+ To use this capability, you need to include the header in your -+ program. You create the server by calling evhttp_new(). Add addresses and -+ ports to listen on with evhttp_bind_socket(). You then register one or more -+ callbacks to handle incoming requests. Each URI can be assigned a callback -+ via the evhttp_set_cb() function. A generic callback function can also be -+ registered via evhttp_set_gencb(); this callback will be invoked if no other -+ callbacks have been registered for a given URI. -+ -+ @section evrpc A framework for RPC servers and clients -+ -+ libevents provides a framework for creating RPC servers and clients. It -+ takes care of marshaling and unmarshaling all data structures. -+ -+ @section api API Reference -+ -+ To browse the complete documentation of the libevent API, click on any of -+ the following links. -+ -+ event.h -+ The primary libevent header -+ -+ evdns.h -+ Asynchronous DNS resolution -+ -+ evhttp.h -+ An embedded libevent-based HTTP server -+ -+ evrpc.h -+ A framework for creating RPC servers and clients -+ -+ */ -+ -+/** @file event.h -+ -+ A library for writing event-driven network servers -+ -+ */ -+ -+#ifdef __cplusplus -+extern "C" { -+#endif -+ -+#include -+#ifdef _EVENT_HAVE_SYS_TYPES_H -+#include -+#endif -+#ifdef _EVENT_HAVE_SYS_TIME_H -+#include -+#endif -+#ifdef _EVENT_HAVE_STDINT_H -+#include -+#endif -+#include -+ -+/* Solaris does not have it */ -+#ifndef timersub -+ -+#define timeradd(tvp, uvp, vvp) \ -+ do { \ -+ (vvp)->tv_sec = (tvp)->tv_sec + (uvp)->tv_sec; \ -+ (vvp)->tv_usec = (tvp)->tv_usec + (uvp)->tv_usec; \ -+ if ((vvp)->tv_usec >= 1000000) { \ -+ (vvp)->tv_sec++; \ -+ (vvp)->tv_usec -= 1000000; \ -+ } \ -+ } while (0) -+ -+#define timersub(tvp, uvp, vvp) \ -+ do { \ -+ (vvp)->tv_sec = (tvp)->tv_sec - (uvp)->tv_sec; \ -+ (vvp)->tv_usec = (tvp)->tv_usec - (uvp)->tv_usec; \ -+ if ((vvp)->tv_usec < 0) { \ -+ (vvp)->tv_sec--; \ -+ (vvp)->tv_usec += 1000000; \ -+ } \ -+ } while (0) -+ -+#endif -+ -+/* For int types. */ -+#include -+ -+#ifdef WIN32 -+#define WIN32_LEAN_AND_MEAN -+#include -+#undef WIN32_LEAN_AND_MEAN -+typedef unsigned char u_char; -+typedef unsigned short u_short; -+#endif -+ -+#define EVLIST_TIMEOUT 0x01 -+#define EVLIST_INSERTED 0x02 -+#define EVLIST_SIGNAL 0x04 -+#define EVLIST_ACTIVE 0x08 -+#define EVLIST_INTERNAL 0x10 -+#define EVLIST_INIT 0x80 -+ -+/* EVLIST_X_ Private space: 0x1000-0xf000 */ -+#define EVLIST_ALL (0xf000 | 0x9f) -+ -+#define EV_TIMEOUT 0x01 -+#define EV_READ 0x02 -+#define EV_WRITE 0x04 -+#define EV_SIGNAL 0x08 -+#define EV_PERSIST 0x10 /* Persistant event */ -+ -+/* Fix so that ppl dont have to run with */ -+#ifndef TAILQ_ENTRY -+#define _EVENT_DEFINED_TQENTRY -+#define TAILQ_ENTRY(type) \ -+struct { \ -+ struct type *tqe_next; /* next element */ \ -+ struct type **tqe_prev; /* address of previous next element */ \ -+} -+#endif /* !TAILQ_ENTRY */ -+ -+struct event_base; -+struct event { -+ TAILQ_ENTRY (event) ev_next; -+ TAILQ_ENTRY (event) ev_active_next; -+ TAILQ_ENTRY (event) ev_signal_next; -+ unsigned int min_heap_idx; /* for managing timeouts */ -+ -+ struct event_base *ev_base; -+ -+ int ev_fd; -+ short ev_events; -+ short ev_ncalls; -+ short *ev_pncalls; /* Allows deletes in callback */ -+ -+ struct timeval ev_timeout; -+ -+ int ev_pri; /* smaller numbers are higher priority */ -+ -+ void (*ev_callback)(int, short, void *arg); -+ void *ev_arg; -+ -+ int ev_res; /* result passed to event callback */ -+ int ev_flags; -+}; -+ -+#define EVENT_SIGNAL(ev) (int)(ev)->ev_fd -+#define EVENT_FD(ev) (int)(ev)->ev_fd -+ -+/* -+ * Key-Value pairs. Can be used for HTTP headers but also for -+ * query argument parsing. -+ */ -+struct evkeyval { -+ TAILQ_ENTRY(evkeyval) next; -+ -+ char *key; -+ char *value; -+}; -+ -+#ifdef _EVENT_DEFINED_TQENTRY -+#undef TAILQ_ENTRY -+struct event_list; -+struct evkeyvalq; -+#undef _EVENT_DEFINED_TQENTRY -+#else -+TAILQ_HEAD (event_list, event); -+TAILQ_HEAD (evkeyvalq, evkeyval); -+#endif /* _EVENT_DEFINED_TQENTRY */ -+ -+/** -+ Initialize the event API. -+ -+ Use event_base_new() to initialize a new event base, but does not set -+ the current_base global. If using only event_base_new(), each event -+ added must have an event base set with event_base_set() -+ -+ @see event_base_set(), event_base_free(), event_init() -+ */ -+struct event_base *event_base_new(void); -+ -+/** -+ Initialize the event API. -+ -+ The event API needs to be initialized with event_init() before it can be -+ used. Sets the current_base global representing the default base for -+ events that have no base associated with them. -+ -+ @see event_base_set(), event_base_new() -+ */ -+struct event_base *event_init(void); -+ -+/** -+ Reinitialized the event base after a fork -+ -+ Some event mechanisms do not survive across fork. The event base needs -+ to be reinitialized with the event_reinit() function. -+ -+ @param base the event base that needs to be re-initialized -+ @return 0 if successful, or -1 if some events could not be re-added. -+ @see event_base_new(), event_init() -+*/ -+int event_reinit(struct event_base *base); -+ -+/** -+ Loop to process events. -+ -+ In order to process events, an application needs to call -+ event_dispatch(). This function only returns on error, and should -+ replace the event core of the application program. -+ -+ @see event_base_dispatch() -+ */ -+int event_dispatch(void); -+ -+ -+/** -+ Threadsafe event dispatching loop. -+ -+ @param eb the event_base structure returned by event_init() -+ @see event_init(), event_dispatch() -+ */ -+int event_base_dispatch(struct event_base *); -+ -+ -+/** -+ Get the kernel event notification mechanism used by libevent. -+ -+ @param eb the event_base structure returned by event_base_new() -+ @return a string identifying the kernel event mechanism (kqueue, epoll, etc.) -+ */ -+const char *event_base_get_method(struct event_base *); -+ -+ -+/** -+ Deallocate all memory associated with an event_base, and free the base. -+ -+ Note that this function will not close any fds or free any memory passed -+ to event_set as the argument to callback. -+ -+ @param eb an event_base to be freed -+ */ -+void event_base_free(struct event_base *); -+ -+ -+#define _EVENT_LOG_DEBUG 0 -+#define _EVENT_LOG_MSG 1 -+#define _EVENT_LOG_WARN 2 -+#define _EVENT_LOG_ERR 3 -+typedef void (*event_log_cb)(int severity, const char *msg); -+/** -+ Redirect libevent's log messages. -+ -+ @param cb a function taking two arguments: an integer severity between -+ _EVENT_LOG_DEBUG and _EVENT_LOG_ERR, and a string. If cb is NULL, -+ then the default log is used. -+ */ -+void event_set_log_callback(event_log_cb cb); -+ -+/** -+ Associate a different event base with an event. -+ -+ @param eb the event base -+ @param ev the event -+ */ -+int event_base_set(struct event_base *, struct event *); -+ -+/** -+ event_loop() flags -+ */ -+/*@{*/ -+#define EVLOOP_ONCE 0x01 /**< Block at most once. */ -+#define EVLOOP_NONBLOCK 0x02 /**< Do not block. */ -+/*@}*/ -+ -+/** -+ Handle events. -+ -+ This is a more flexible version of event_dispatch(). -+ -+ @param flags any combination of EVLOOP_ONCE | EVLOOP_NONBLOCK -+ @return 0 if successful, -1 if an error occurred, or 1 if no events were -+ registered. -+ @see event_loopexit(), event_base_loop() -+*/ -+int event_loop(int); -+ -+/** -+ Handle events (threadsafe version). -+ -+ This is a more flexible version of event_base_dispatch(). -+ -+ @param eb the event_base structure returned by event_init() -+ @param flags any combination of EVLOOP_ONCE | EVLOOP_NONBLOCK -+ @return 0 if successful, -1 if an error occurred, or 1 if no events were -+ registered. -+ @see event_loopexit(), event_base_loop() -+ */ -+int event_base_loop(struct event_base *, int); -+ -+/** -+ Exit the event loop after the specified time. -+ -+ The next event_loop() iteration after the given timer expires will -+ complete normally (handling all queued events) then exit without -+ blocking for events again. -+ -+ Subsequent invocations of event_loop() will proceed normally. -+ -+ @param tv the amount of time after which the loop should terminate. -+ @return 0 if successful, or -1 if an error occurred -+ @see event_loop(), event_base_loop(), event_base_loopexit() -+ */ -+int event_loopexit(const struct timeval *); -+ -+ -+/** -+ Exit the event loop after the specified time (threadsafe variant). -+ -+ The next event_base_loop() iteration after the given timer expires will -+ complete normally (handling all queued events) then exit without -+ blocking for events again. -+ -+ Subsequent invocations of event_base_loop() will proceed normally. -+ -+ @param eb the event_base structure returned by event_init() -+ @param tv the amount of time after which the loop should terminate. -+ @return 0 if successful, or -1 if an error occurred -+ @see event_loopexit() -+ */ -+int event_base_loopexit(struct event_base *, const struct timeval *); -+ -+/** -+ Abort the active event_loop() immediately. -+ -+ event_loop() will abort the loop after the next event is completed; -+ event_loopbreak() is typically invoked from this event's callback. -+ This behavior is analogous to the "break;" statement. -+ -+ Subsequent invocations of event_loop() will proceed normally. -+ -+ @return 0 if successful, or -1 if an error occurred -+ @see event_base_loopbreak(), event_loopexit() -+ */ -+int event_loopbreak(void); -+ -+/** -+ Abort the active event_base_loop() immediately. -+ -+ event_base_loop() will abort the loop after the next event is completed; -+ event_base_loopbreak() is typically invoked from this event's callback. -+ This behavior is analogous to the "break;" statement. -+ -+ Subsequent invocations of event_loop() will proceed normally. -+ -+ @param eb the event_base structure returned by event_init() -+ @return 0 if successful, or -1 if an error occurred -+ @see event_base_loopexit -+ */ -+int event_base_loopbreak(struct event_base *); -+ -+ -+/** -+ Add a timer event. -+ -+ @param ev the event struct -+ @param tv timeval struct -+ */ -+#define evtimer_add(ev, tv) event_add(ev, tv) -+ -+ -+/** -+ Define a timer event. -+ -+ @param ev event struct to be modified -+ @param cb callback function -+ @param arg argument that will be passed to the callback function -+ */ -+#define evtimer_set(ev, cb, arg) event_set(ev, -1, 0, cb, arg) -+ -+ -+/** -+ * Delete a timer event. -+ * -+ * @param ev the event struct to be disabled -+ */ -+#define evtimer_del(ev) event_del(ev) -+#define evtimer_pending(ev, tv) event_pending(ev, EV_TIMEOUT, tv) -+#define evtimer_initialized(ev) ((ev)->ev_flags & EVLIST_INIT) -+ -+/** -+ * Add a timeout event. -+ * -+ * @param ev the event struct to be disabled -+ * @param tv the timeout value, in seconds -+ */ -+#define timeout_add(ev, tv) event_add(ev, tv) -+ -+ -+/** -+ * Define a timeout event. -+ * -+ * @param ev the event struct to be defined -+ * @param cb the callback to be invoked when the timeout expires -+ * @param arg the argument to be passed to the callback -+ */ -+#define timeout_set(ev, cb, arg) event_set(ev, -1, 0, cb, arg) -+ -+ -+/** -+ * Disable a timeout event. -+ * -+ * @param ev the timeout event to be disabled -+ */ -+#define timeout_del(ev) event_del(ev) -+ -+#define timeout_pending(ev, tv) event_pending(ev, EV_TIMEOUT, tv) -+#define timeout_initialized(ev) ((ev)->ev_flags & EVLIST_INIT) -+ -+#define signal_add(ev, tv) event_add(ev, tv) -+#define signal_set(ev, x, cb, arg) \ -+ event_set(ev, x, EV_SIGNAL|EV_PERSIST, cb, arg) -+#define signal_del(ev) event_del(ev) -+#define signal_pending(ev, tv) event_pending(ev, EV_SIGNAL, tv) -+#define signal_initialized(ev) ((ev)->ev_flags & EVLIST_INIT) -+ -+/** -+ Prepare an event structure to be added. -+ -+ The function event_set() prepares the event structure ev to be used in -+ future calls to event_add() and event_del(). The event will be prepared to -+ call the function specified by the fn argument with an int argument -+ indicating the file descriptor, a short argument indicating the type of -+ event, and a void * argument given in the arg argument. The fd indicates -+ the file descriptor that should be monitored for events. The events can be -+ either EV_READ, EV_WRITE, or both. Indicating that an application can read -+ or write from the file descriptor respectively without blocking. -+ -+ The function fn will be called with the file descriptor that triggered the -+ event and the type of event which will be either EV_TIMEOUT, EV_SIGNAL, -+ EV_READ, or EV_WRITE. The additional flag EV_PERSIST makes an event_add() -+ persistent until event_del() has been called. -+ -+ @param ev an event struct to be modified -+ @param fd the file descriptor to be monitored -+ @param event desired events to monitor; can be EV_READ and/or EV_WRITE -+ @param fn callback function to be invoked when the event occurs -+ @param arg an argument to be passed to the callback function -+ -+ @see event_add(), event_del(), event_once() -+ -+ */ -+void event_set(struct event *, int, short, void (*)(int, short, void *), void *); -+ -+/** -+ Schedule a one-time event to occur. -+ -+ The function event_once() is similar to event_set(). However, it schedules -+ a callback to be called exactly once and does not require the caller to -+ prepare an event structure. -+ -+ @param fd a file descriptor to monitor -+ @param events event(s) to monitor; can be any of EV_TIMEOUT | EV_READ | -+ EV_WRITE -+ @param callback callback function to be invoked when the event occurs -+ @param arg an argument to be passed to the callback function -+ @param timeout the maximum amount of time to wait for the event, or NULL -+ to wait forever -+ @return 0 if successful, or -1 if an error occurred -+ @see event_set() -+ -+ */ -+int event_once(int, short, void (*)(int, short, void *), void *, -+ const struct timeval *); -+ -+ -+/** -+ Schedule a one-time event (threadsafe variant) -+ -+ The function event_base_once() is similar to event_set(). However, it -+ schedules a callback to be called exactly once and does not require the -+ caller to prepare an event structure. -+ -+ @param base an event_base returned by event_init() -+ @param fd a file descriptor to monitor -+ @param events event(s) to monitor; can be any of EV_TIMEOUT | EV_READ | -+ EV_WRITE -+ @param callback callback function to be invoked when the event occurs -+ @param arg an argument to be passed to the callback function -+ @param timeout the maximum amount of time to wait for the event, or NULL -+ to wait forever -+ @return 0 if successful, or -1 if an error occurred -+ @see event_once() -+ */ -+int event_base_once(struct event_base *base, int fd, short events, -+ void (*callback)(int, short, void *), void *arg, -+ const struct timeval *timeout); -+ -+ -+/** -+ Add an event to the set of monitored events. -+ -+ The function event_add() schedules the execution of the ev event when the -+ event specified in event_set() occurs or in at least the time specified in -+ the tv. If tv is NULL, no timeout occurs and the function will only be -+ called if a matching event occurs on the file descriptor. The event in the -+ ev argument must be already initialized by event_set() and may not be used -+ in calls to event_set() until it has timed out or been removed with -+ event_del(). If the event in the ev argument already has a scheduled -+ timeout, the old timeout will be replaced by the new one. -+ -+ @param ev an event struct initialized via event_set() -+ @param timeout the maximum amount of time to wait for the event, or NULL -+ to wait forever -+ @return 0 if successful, or -1 if an error occurred -+ @see event_del(), event_set() -+ */ -+int event_add(struct event *ev, const struct timeval *timeout); -+ -+ -+/** -+ Remove an event from the set of monitored events. -+ -+ The function event_del() will cancel the event in the argument ev. If the -+ event has already executed or has never been added the call will have no -+ effect. -+ -+ @param ev an event struct to be removed from the working set -+ @return 0 if successful, or -1 if an error occurred -+ @see event_add() -+ */ -+int event_del(struct event *); -+ -+void event_active(struct event *, int, short); -+ -+ -+/** -+ Checks if a specific event is pending or scheduled. -+ -+ @param ev an event struct previously passed to event_add() -+ @param event the requested event type; any of EV_TIMEOUT|EV_READ| -+ EV_WRITE|EV_SIGNAL -+ @param tv an alternate timeout (FIXME - is this true?) -+ -+ @return 1 if the event is pending, or 0 if the event has not occurred -+ -+ */ -+int event_pending(struct event *ev, short event, struct timeval *tv); -+ -+ -+/** -+ Test if an event structure has been initialized. -+ -+ The event_initialized() macro can be used to check if an event has been -+ initialized. -+ -+ @param ev an event structure to be tested -+ @return 1 if the structure has been initialized, or 0 if it has not been -+ initialized -+ */ -+#ifdef WIN32 -+#define event_initialized(ev) ((ev)->ev_flags & EVLIST_INIT && (ev)->ev_fd != (int)INVALID_HANDLE_VALUE) -+#else -+#define event_initialized(ev) ((ev)->ev_flags & EVLIST_INIT) -+#endif -+ -+ -+/** -+ Get the libevent version number. -+ -+ @return a string containing the version number of libevent -+ */ -+const char *event_get_version(void); -+ -+ -+/** -+ Get the kernel event notification mechanism used by libevent. -+ -+ @return a string identifying the kernel event mechanism (kqueue, epoll, etc.) -+ */ -+const char *event_get_method(void); -+ -+ -+/** -+ Set the number of different event priorities. -+ -+ By default libevent schedules all active events with the same priority. -+ However, some time it is desirable to process some events with a higher -+ priority than others. For that reason, libevent supports strict priority -+ queues. Active events with a lower priority are always processed before -+ events with a higher priority. -+ -+ The number of different priorities can be set initially with the -+ event_priority_init() function. This function should be called before the -+ first call to event_dispatch(). The event_priority_set() function can be -+ used to assign a priority to an event. By default, libevent assigns the -+ middle priority to all events unless their priority is explicitly set. -+ -+ @param npriorities the maximum number of priorities -+ @return 0 if successful, or -1 if an error occurred -+ @see event_base_priority_init(), event_priority_set() -+ -+ */ -+int event_priority_init(int); -+ -+ -+/** -+ Set the number of different event priorities (threadsafe variant). -+ -+ See the description of event_priority_init() for more information. -+ -+ @param eb the event_base structure returned by event_init() -+ @param npriorities the maximum number of priorities -+ @return 0 if successful, or -1 if an error occurred -+ @see event_priority_init(), event_priority_set() -+ */ -+int event_base_priority_init(struct event_base *, int); -+ -+ -+/** -+ Assign a priority to an event. -+ -+ @param ev an event struct -+ @param priority the new priority to be assigned -+ @return 0 if successful, or -1 if an error occurred -+ @see event_priority_init() -+ */ -+int event_priority_set(struct event *, int); -+ -+ -+/* These functions deal with buffering input and output */ -+ -+struct evbuffer { -+ u_char *buffer; -+ u_char *orig_buffer; -+ -+ size_t misalign; -+ size_t totallen; -+ size_t off; -+ -+ void (*cb)(struct evbuffer *, size_t, size_t, void *); -+ void *cbarg; -+}; -+ -+/* Just for error reporting - use other constants otherwise */ -+#define EVBUFFER_READ 0x01 -+#define EVBUFFER_WRITE 0x02 -+#define EVBUFFER_EOF 0x10 -+#define EVBUFFER_ERROR 0x20 -+#define EVBUFFER_TIMEOUT 0x40 -+ -+struct bufferevent; -+typedef void (*evbuffercb)(struct bufferevent *, void *); -+typedef void (*everrorcb)(struct bufferevent *, short what, void *); -+ -+struct event_watermark { -+ size_t low; -+ size_t high; -+}; -+ -+struct bufferevent { -+ struct event_base *ev_base; -+ -+ struct event ev_read; -+ struct event ev_write; -+ -+ struct evbuffer *input; -+ struct evbuffer *output; -+ -+ struct event_watermark wm_read; -+ struct event_watermark wm_write; -+ -+ evbuffercb readcb; -+ evbuffercb writecb; -+ everrorcb errorcb; -+ void *cbarg; -+ -+ int timeout_read; /* in seconds */ -+ int timeout_write; /* in seconds */ -+ -+ short enabled; /* events that are currently enabled */ -+}; -+ -+ -+/** -+ Create a new bufferevent. -+ -+ libevent provides an abstraction on top of the regular event callbacks. -+ This abstraction is called a buffered event. A buffered event provides -+ input and output buffers that get filled and drained automatically. The -+ user of a buffered event no longer deals directly with the I/O, but -+ instead is reading from input and writing to output buffers. -+ -+ Once initialized, the bufferevent structure can be used repeatedly with -+ bufferevent_enable() and bufferevent_disable(). -+ -+ When read enabled the bufferevent will try to read from the file descriptor -+ and call the read callback. The write callback is executed whenever the -+ output buffer is drained below the write low watermark, which is 0 by -+ default. -+ -+ If multiple bases are in use, bufferevent_base_set() must be called before -+ enabling the bufferevent for the first time. -+ -+ @param fd the file descriptor from which data is read and written to. -+ This file descriptor is not allowed to be a pipe(2). -+ @param readcb callback to invoke when there is data to be read, or NULL if -+ no callback is desired -+ @param writecb callback to invoke when the file descriptor is ready for -+ writing, or NULL if no callback is desired -+ @param errorcb callback to invoke when there is an error on the file -+ descriptor -+ @param cbarg an argument that will be supplied to each of the callbacks -+ (readcb, writecb, and errorcb) -+ @return a pointer to a newly allocated bufferevent struct, or NULL if an -+ error occurred -+ @see bufferevent_base_set(), bufferevent_free() -+ */ -+struct bufferevent *bufferevent_new(int fd, -+ evbuffercb readcb, evbuffercb writecb, everrorcb errorcb, void *cbarg); -+ -+ -+/** -+ Assign a bufferevent to a specific event_base. -+ -+ @param base an event_base returned by event_init() -+ @param bufev a bufferevent struct returned by bufferevent_new() -+ @return 0 if successful, or -1 if an error occurred -+ @see bufferevent_new() -+ */ -+int bufferevent_base_set(struct event_base *base, struct bufferevent *bufev); -+ -+ -+/** -+ Assign a priority to a bufferevent. -+ -+ @param bufev a bufferevent struct -+ @param pri the priority to be assigned -+ @return 0 if successful, or -1 if an error occurred -+ */ -+int bufferevent_priority_set(struct bufferevent *bufev, int pri); -+ -+ -+/** -+ Deallocate the storage associated with a bufferevent structure. -+ -+ @param bufev the bufferevent structure to be freed. -+ */ -+void bufferevent_free(struct bufferevent *bufev); -+ -+ -+/** -+ Changes the callbacks for a bufferevent. -+ -+ @param bufev the bufferevent object for which to change callbacks -+ @param readcb callback to invoke when there is data to be read, or NULL if -+ no callback is desired -+ @param writecb callback to invoke when the file descriptor is ready for -+ writing, or NULL if no callback is desired -+ @param errorcb callback to invoke when there is an error on the file -+ descriptor -+ @param cbarg an argument that will be supplied to each of the callbacks -+ (readcb, writecb, and errorcb) -+ @see bufferevent_new() -+ */ -+void bufferevent_setcb(struct bufferevent *bufev, -+ evbuffercb readcb, evbuffercb writecb, everrorcb errorcb, void *cbarg); -+ -+/** -+ Changes the file descriptor on which the bufferevent operates. -+ -+ @param bufev the bufferevent object for which to change the file descriptor -+ @param fd the file descriptor to operate on -+*/ -+void bufferevent_setfd(struct bufferevent *bufev, int fd); -+ -+/** -+ Write data to a bufferevent buffer. -+ -+ The bufferevent_write() function can be used to write data to the file -+ descriptor. The data is appended to the output buffer and written to the -+ descriptor automatically as it becomes available for writing. -+ -+ @param bufev the bufferevent to be written to -+ @param data a pointer to the data to be written -+ @param size the length of the data, in bytes -+ @return 0 if successful, or -1 if an error occurred -+ @see bufferevent_write_buffer() -+ */ -+int bufferevent_write(struct bufferevent *bufev, -+ const void *data, size_t size); -+ -+ -+/** -+ Write data from an evbuffer to a bufferevent buffer. The evbuffer is -+ being drained as a result. -+ -+ @param bufev the bufferevent to be written to -+ @param buf the evbuffer to be written -+ @return 0 if successful, or -1 if an error occurred -+ @see bufferevent_write() -+ */ -+int bufferevent_write_buffer(struct bufferevent *bufev, struct evbuffer *buf); -+ -+ -+/** -+ Read data from a bufferevent buffer. -+ -+ The bufferevent_read() function is used to read data from the input buffer. -+ -+ @param bufev the bufferevent to be read from -+ @param data pointer to a buffer that will store the data -+ @param size the size of the data buffer, in bytes -+ @return the amount of data read, in bytes. -+ */ -+size_t bufferevent_read(struct bufferevent *bufev, void *data, size_t size); -+ -+/** -+ Enable a bufferevent. -+ -+ @param bufev the bufferevent to be enabled -+ @param event any combination of EV_READ | EV_WRITE. -+ @return 0 if successful, or -1 if an error occurred -+ @see bufferevent_disable() -+ */ -+int bufferevent_enable(struct bufferevent *bufev, short event); -+ -+ -+/** -+ Disable a bufferevent. -+ -+ @param bufev the bufferevent to be disabled -+ @param event any combination of EV_READ | EV_WRITE. -+ @return 0 if successful, or -1 if an error occurred -+ @see bufferevent_enable() -+ */ -+int bufferevent_disable(struct bufferevent *bufev, short event); -+ -+ -+/** -+ Set the read and write timeout for a buffered event. -+ -+ @param bufev the bufferevent to be modified -+ @param timeout_read the read timeout -+ @param timeout_write the write timeout -+ */ -+void bufferevent_settimeout(struct bufferevent *bufev, -+ int timeout_read, int timeout_write); -+ -+ -+/** -+ Sets the watermarks for read and write events. -+ -+ On input, a bufferevent does not invoke the user read callback unless -+ there is at least low watermark data in the buffer. If the read buffer -+ is beyond the high watermark, the buffevent stops reading from the network. -+ -+ On output, the user write callback is invoked whenever the buffered data -+ falls below the low watermark. -+ -+ @param bufev the bufferevent to be modified -+ @param events EV_READ, EV_WRITE or both -+ @param lowmark the lower watermark to set -+ @param highmark the high watermark to set -+*/ -+ -+void bufferevent_setwatermark(struct bufferevent *bufev, short events, -+ size_t lowmark, size_t highmark); -+ -+#define EVBUFFER_LENGTH(x) (x)->off -+#define EVBUFFER_DATA(x) (x)->buffer -+#define EVBUFFER_INPUT(x) (x)->input -+#define EVBUFFER_OUTPUT(x) (x)->output -+ -+ -+/** -+ Allocate storage for a new evbuffer. -+ -+ @return a pointer to a newly allocated evbuffer struct, or NULL if an error -+ occurred -+ */ -+struct evbuffer *evbuffer_new(void); -+ -+ -+/** -+ Deallocate storage for an evbuffer. -+ -+ @param pointer to the evbuffer to be freed -+ */ -+void evbuffer_free(struct evbuffer *); -+ -+ -+/** -+ Expands the available space in an event buffer. -+ -+ Expands the available space in the event buffer to at least datlen -+ -+ @param buf the event buffer to be expanded -+ @param datlen the new minimum length requirement -+ @return 0 if successful, or -1 if an error occurred -+*/ -+int evbuffer_expand(struct evbuffer *, size_t); -+ -+ -+/** -+ Append data to the end of an evbuffer. -+ -+ @param buf the event buffer to be appended to -+ @param data pointer to the beginning of the data buffer -+ @param datlen the number of bytes to be copied from the data buffer -+ */ -+int evbuffer_add(struct evbuffer *, const void *, size_t); -+ -+ -+ -+/** -+ Read data from an event buffer and drain the bytes read. -+ -+ @param buf the event buffer to be read from -+ @param data the destination buffer to store the result -+ @param datlen the maximum size of the destination buffer -+ @return the number of bytes read -+ */ -+int evbuffer_remove(struct evbuffer *, void *, size_t); -+ -+ -+/** -+ * Read a single line from an event buffer. -+ * -+ * Reads a line terminated by either '\r\n', '\n\r' or '\r' or '\n'. -+ * The returned buffer needs to be freed by the caller. -+ * -+ * @param buffer the evbuffer to read from -+ * @return pointer to a single line, or NULL if an error occurred -+ */ -+char *evbuffer_readline(struct evbuffer *); -+ -+ -+/** -+ Move data from one evbuffer into another evbuffer. -+ -+ This is a destructive add. The data from one buffer moves into -+ the other buffer. The destination buffer is expanded as needed. -+ -+ @param outbuf the output buffer -+ @param inbuf the input buffer -+ @return 0 if successful, or -1 if an error occurred -+ */ -+int evbuffer_add_buffer(struct evbuffer *, struct evbuffer *); -+ -+ -+/** -+ Append a formatted string to the end of an evbuffer. -+ -+ @param buf the evbuffer that will be appended to -+ @param fmt a format string -+ @param ... arguments that will be passed to printf(3) -+ @return The number of bytes added if successful, or -1 if an error occurred. -+ */ -+int evbuffer_add_printf(struct evbuffer *, const char *fmt, ...) -+#ifdef __GNUC__ -+ __attribute__((format(printf, 2, 3))) -+#endif -+; -+ -+ -+/** -+ Append a va_list formatted string to the end of an evbuffer. -+ -+ @param buf the evbuffer that will be appended to -+ @param fmt a format string -+ @param ap a varargs va_list argument array that will be passed to vprintf(3) -+ @return The number of bytes added if successful, or -1 if an error occurred. -+ */ -+int evbuffer_add_vprintf(struct evbuffer *, const char *fmt, va_list ap); -+ -+ -+/** -+ Remove a specified number of bytes data from the beginning of an evbuffer. -+ -+ @param buf the evbuffer to be drained -+ @param len the number of bytes to drain from the beginning of the buffer -+ @return 0 if successful, or -1 if an error occurred -+ */ -+void evbuffer_drain(struct evbuffer *, size_t); -+ -+ -+/** -+ Write the contents of an evbuffer to a file descriptor. -+ -+ The evbuffer will be drained after the bytes have been successfully written. -+ -+ @param buffer the evbuffer to be written and drained -+ @param fd the file descriptor to be written to -+ @return the number of bytes written, or -1 if an error occurred -+ @see evbuffer_read() -+ */ -+int evbuffer_write(struct evbuffer *, int); -+ -+ -+/** -+ Read from a file descriptor and store the result in an evbuffer. -+ -+ @param buf the evbuffer to store the result -+ @param fd the file descriptor to read from -+ @param howmuch the number of bytes to be read -+ @return the number of bytes read, or -1 if an error occurred -+ @see evbuffer_write() -+ */ -+int evbuffer_read(struct evbuffer *, int, int); -+ -+ -+/** -+ Find a string within an evbuffer. -+ -+ @param buffer the evbuffer to be searched -+ @param what the string to be searched for -+ @param len the length of the search string -+ @return a pointer to the beginning of the search string, or NULL if the search failed. -+ */ -+u_char *evbuffer_find(struct evbuffer *, const u_char *, size_t); -+ -+/** -+ Set a callback to invoke when the evbuffer is modified. -+ -+ @param buffer the evbuffer to be monitored -+ @param cb the callback function to invoke when the evbuffer is modified -+ @param cbarg an argument to be provided to the callback function -+ */ -+void evbuffer_setcb(struct evbuffer *, void (*)(struct evbuffer *, size_t, size_t, void *), void *); -+ -+/* -+ * Marshaling tagged data - We assume that all tags are inserted in their -+ * numeric order - so that unknown tags will always be higher than the -+ * known ones - and we can just ignore the end of an event buffer. -+ */ -+ -+void evtag_init(void); -+ -+void evtag_marshal(struct evbuffer *evbuf, ev_uint32_t tag, const void *data, -+ ev_uint32_t len); -+ -+/** -+ Encode an integer and store it in an evbuffer. -+ -+ We encode integer's by nibbles; the first nibble contains the number -+ of significant nibbles - 1; this allows us to encode up to 64-bit -+ integers. This function is byte-order independent. -+ -+ @param evbuf evbuffer to store the encoded number -+ @param number a 32-bit integer -+ */ -+void encode_int(struct evbuffer *evbuf, ev_uint32_t number); -+ -+void evtag_marshal_int(struct evbuffer *evbuf, ev_uint32_t tag, -+ ev_uint32_t integer); -+ -+void evtag_marshal_string(struct evbuffer *buf, ev_uint32_t tag, -+ const char *string); -+ -+void evtag_marshal_timeval(struct evbuffer *evbuf, ev_uint32_t tag, -+ struct timeval *tv); -+ -+int evtag_unmarshal(struct evbuffer *src, ev_uint32_t *ptag, -+ struct evbuffer *dst); -+int evtag_peek(struct evbuffer *evbuf, ev_uint32_t *ptag); -+int evtag_peek_length(struct evbuffer *evbuf, ev_uint32_t *plength); -+int evtag_payload_length(struct evbuffer *evbuf, ev_uint32_t *plength); -+int evtag_consume(struct evbuffer *evbuf); -+ -+int evtag_unmarshal_int(struct evbuffer *evbuf, ev_uint32_t need_tag, -+ ev_uint32_t *pinteger); -+ -+int evtag_unmarshal_fixed(struct evbuffer *src, ev_uint32_t need_tag, -+ void *data, size_t len); -+ -+int evtag_unmarshal_string(struct evbuffer *evbuf, ev_uint32_t need_tag, -+ char **pstring); -+ -+int evtag_unmarshal_timeval(struct evbuffer *evbuf, ev_uint32_t need_tag, -+ struct timeval *ptv); -+ -+#ifdef __cplusplus -+} -+#endif -+ -+#endif /* _EVENT_H_ */ -diff --git a/libevent/evhttp.h b/libevent/evhttp.h -new file mode 100644 -index 0000000..0d35f9e ---- /dev/null -+++ b/libevent/evhttp.h -@@ -0,0 +1,357 @@ -+/* -+ * Copyright (c) 2000-2004 Niels Provos -+ * All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. The name of the author may not be used to endorse or promote products -+ * derived from this software without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR -+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES -+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. -+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, -+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT -+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF -+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+ */ -+#ifndef _EVHTTP_H_ -+#define _EVHTTP_H_ -+ -+#include -+ -+#ifdef __cplusplus -+extern "C" { -+#endif -+ -+#ifdef WIN32 -+#define WIN32_LEAN_AND_MEAN -+#include -+#include -+#undef WIN32_LEAN_AND_MEAN -+#endif -+ -+/** @file evhttp.h -+ * -+ * Basic support for HTTP serving. -+ * -+ * As libevent is a library for dealing with event notification and most -+ * interesting applications are networked today, I have often found the -+ * need to write HTTP code. The following prototypes and definitions provide -+ * an application with a minimal interface for making HTTP requests and for -+ * creating a very simple HTTP server. -+ */ -+ -+/* Response codes */ -+#define HTTP_OK 200 -+#define HTTP_NOCONTENT 204 -+#define HTTP_MOVEPERM 301 -+#define HTTP_MOVETEMP 302 -+#define HTTP_NOTMODIFIED 304 -+#define HTTP_BADREQUEST 400 -+#define HTTP_NOTFOUND 404 -+#define HTTP_SERVUNAVAIL 503 -+ -+struct evhttp; -+struct evhttp_request; -+struct evkeyvalq; -+ -+/** Create a new HTTP server -+ * -+ * @param base (optional) the event base to receive the HTTP events -+ * @return a pointer to a newly initialized evhttp server structure -+ */ -+struct evhttp *evhttp_new(struct event_base *base); -+ -+/** -+ * Binds an HTTP server on the specified address and port. -+ * -+ * Can be called multiple times to bind the same http server -+ * to multiple different ports. -+ * -+ * @param http a pointer to an evhttp object -+ * @param address a string containing the IP address to listen(2) on -+ * @param port the port number to listen on -+ * @return a newly allocated evhttp struct -+ * @see evhttp_free() -+ */ -+int evhttp_bind_socket(struct evhttp *http, const char *address, u_short port); -+ -+/** -+ * Makes an HTTP server accept connections on the specified socket -+ * -+ * This may be useful to create a socket and then fork multiple instances -+ * of an http server, or when a socket has been communicated via file -+ * descriptor passing in situations where an http servers does not have -+ * permissions to bind to a low-numbered port. -+ * -+ * Can be called multiple times to have the http server listen to -+ * multiple different sockets. -+ * -+ * @param http a pointer to an evhttp object -+ * @param fd a socket fd that is ready for accepting connections -+ * @return 0 on success, -1 on failure. -+ * @see evhttp_free(), evhttp_bind_socket() -+ */ -+int evhttp_accept_socket(struct evhttp *http, int fd); -+ -+/** -+ * Free the previously created HTTP server. -+ * -+ * Works only if no requests are currently being served. -+ * -+ * @param http the evhttp server object to be freed -+ * @see evhttp_start() -+ */ -+void evhttp_free(struct evhttp* http); -+ -+/** Set a callback for a specified URI */ -+void evhttp_set_cb(struct evhttp *, const char *, -+ void (*)(struct evhttp_request *, void *), void *); -+ -+/** Removes the callback for a specified URI */ -+int evhttp_del_cb(struct evhttp *, const char *); -+ -+/** Set a callback for all requests that are not caught by specific callbacks -+ */ -+void evhttp_set_gencb(struct evhttp *, -+ void (*)(struct evhttp_request *, void *), void *); -+ -+/** -+ * Set the timeout for an HTTP request. -+ * -+ * @param http an evhttp object -+ * @param timeout_in_secs the timeout, in seconds -+ */ -+void evhttp_set_timeout(struct evhttp *, int timeout_in_secs); -+ -+/* Request/Response functionality */ -+ -+/** -+ * Send an HTML error message to the client. -+ * -+ * @param req a request object -+ * @param error the HTTP error code -+ * @param reason a brief explanation of the error -+ */ -+void evhttp_send_error(struct evhttp_request *req, int error, -+ const char *reason); -+ -+/** -+ * Send an HTML reply to the client. -+ * -+ * @param req a request object -+ * @param code the HTTP response code to send -+ * @param reason a brief message to send with the response code -+ * @param databuf the body of the response -+ */ -+void evhttp_send_reply(struct evhttp_request *req, int code, -+ const char *reason, struct evbuffer *databuf); -+ -+/* Low-level response interface, for streaming/chunked replies */ -+void evhttp_send_reply_start(struct evhttp_request *, int, const char *); -+void evhttp_send_reply_chunk(struct evhttp_request *, struct evbuffer *); -+void evhttp_send_reply_end(struct evhttp_request *); -+ -+/** -+ * Start an HTTP server on the specified address and port -+ * -+ * DEPRECATED: it does not allow an event base to be specified -+ * -+ * @param address the address to which the HTTP server should be bound -+ * @param port the port number on which the HTTP server should listen -+ * @return an struct evhttp object -+ */ -+struct evhttp *evhttp_start(const char *address, u_short port); -+ -+/* -+ * Interfaces for making requests -+ */ -+enum evhttp_cmd_type { EVHTTP_REQ_GET, EVHTTP_REQ_POST, EVHTTP_REQ_HEAD }; -+ -+enum evhttp_request_kind { EVHTTP_REQUEST, EVHTTP_RESPONSE }; -+ -+/** -+ * the request structure that a server receives. -+ * WARNING: expect this structure to change. I will try to provide -+ * reasonable accessors. -+ */ -+struct evhttp_request { -+#if defined(TAILQ_ENTRY) -+ TAILQ_ENTRY(evhttp_request) next; -+#else -+struct { -+ struct evhttp_request *tqe_next; -+ struct evhttp_request **tqe_prev; -+} next; -+#endif -+ -+ /* the connection object that this request belongs to */ -+ struct evhttp_connection *evcon; -+ int flags; -+#define EVHTTP_REQ_OWN_CONNECTION 0x0001 -+#define EVHTTP_PROXY_REQUEST 0x0002 -+ -+ struct evkeyvalq *input_headers; -+ struct evkeyvalq *output_headers; -+ -+ /* address of the remote host and the port connection came from */ -+ char *remote_host; -+ u_short remote_port; -+ -+ enum evhttp_request_kind kind; -+ enum evhttp_cmd_type type; -+ -+ char *uri; /* uri after HTTP request was parsed */ -+ -+ char major; /* HTTP Major number */ -+ char minor; /* HTTP Minor number */ -+ -+ int response_code; /* HTTP Response code */ -+ char *response_code_line; /* Readable response */ -+ -+ struct evbuffer *input_buffer; /* read data */ -+ ev_int64_t ntoread; -+ int chunked; -+ -+ struct evbuffer *output_buffer; /* outgoing post or data */ -+ -+ /* Callback */ -+ void (*cb)(struct evhttp_request *, void *); -+ void *cb_arg; -+ -+ /* -+ * Chunked data callback - call for each completed chunk if -+ * specified. If not specified, all the data is delivered via -+ * the regular callback. -+ */ -+ void (*chunk_cb)(struct evhttp_request *, void *); -+}; -+ -+/** -+ * Creates a new request object that needs to be filled in with the request -+ * parameters. The callback is executed when the request completed or an -+ * error occurred. -+ */ -+struct evhttp_request *evhttp_request_new( -+ void (*cb)(struct evhttp_request *, void *), void *arg); -+ -+/** enable delivery of chunks to requestor */ -+void evhttp_request_set_chunked_cb(struct evhttp_request *, -+ void (*cb)(struct evhttp_request *, void *)); -+ -+/** Frees the request object and removes associated events. */ -+void evhttp_request_free(struct evhttp_request *req); -+ -+/** -+ * A connection object that can be used to for making HTTP requests. The -+ * connection object tries to establish the connection when it is given an -+ * http request object. -+ */ -+struct evhttp_connection *evhttp_connection_new( -+ const char *address, unsigned short port); -+ -+/** Frees an http connection */ -+void evhttp_connection_free(struct evhttp_connection *evcon); -+ -+/** sets the ip address from which http connections are made */ -+void evhttp_connection_set_local_address(struct evhttp_connection *evcon, -+ const char *address); -+ -+/** Sets the timeout for events related to this connection */ -+void evhttp_connection_set_timeout(struct evhttp_connection *evcon, -+ int timeout_in_secs); -+ -+/** Sets the retry limit for this connection - -1 repeats indefnitely */ -+void evhttp_connection_set_retries(struct evhttp_connection *evcon, -+ int retry_max); -+ -+/** Set a callback for connection close. */ -+void evhttp_connection_set_closecb(struct evhttp_connection *evcon, -+ void (*)(struct evhttp_connection *, void *), void *); -+ -+/** -+ * Associates an event base with the connection - can only be called -+ * on a freshly created connection object that has not been used yet. -+ */ -+void evhttp_connection_set_base(struct evhttp_connection *evcon, -+ struct event_base *base); -+ -+/** Get the remote address and port associated with this connection. */ -+void evhttp_connection_get_peer(struct evhttp_connection *evcon, -+ char **address, u_short *port); -+ -+/** The connection gets ownership of the request */ -+int evhttp_make_request(struct evhttp_connection *evcon, -+ struct evhttp_request *req, -+ enum evhttp_cmd_type type, const char *uri); -+ -+const char *evhttp_request_uri(struct evhttp_request *req); -+ -+/* Interfaces for dealing with HTTP headers */ -+ -+const char *evhttp_find_header(const struct evkeyvalq *, const char *); -+int evhttp_remove_header(struct evkeyvalq *, const char *); -+int evhttp_add_header(struct evkeyvalq *, const char *, const char *); -+void evhttp_clear_headers(struct evkeyvalq *); -+ -+/* Miscellaneous utility functions */ -+ -+ -+/** -+ Helper function to encode a URI. -+ -+ The returned string must be freed by the caller. -+ -+ @param uri an unencoded URI -+ @return a newly allocated URI-encoded string -+ */ -+char *evhttp_encode_uri(const char *uri); -+ -+ -+/** -+ Helper function to decode a URI. -+ -+ The returned string must be freed by the caller. -+ -+ @param uri an encoded URI -+ @return a newly allocated unencoded URI -+ */ -+char *evhttp_decode_uri(const char *uri); -+ -+ -+/** -+ * Helper function to parse out arguments in a query. -+ * The arguments are separated by key and value. -+ * URI should already be decoded. -+ */ -+void evhttp_parse_query(const char *uri, struct evkeyvalq *); -+ -+ -+/** -+ * Escape HTML character entities in a string. -+ * -+ * Replaces <, >, ", ' and & with <, >, ", -+ * ' and & correspondingly. -+ * -+ * The returned string needs to be freed by the caller. -+ * -+ * @param html an unescaped HTML string -+ * @return an escaped HTML string -+ */ -+char *evhttp_htmlescape(const char *html); -+ -+#ifdef __cplusplus -+} -+#endif -+ -+#endif /* _EVHTTP_H_ */ -diff --git a/libevent/evport.c b/libevent/evport.c -new file mode 100644 -index 0000000..31523b4 ---- /dev/null -+++ b/libevent/evport.c -@@ -0,0 +1,513 @@ -+/* -+ * Submitted by David Pacheco (dp.spambait@gmail.com) -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. The name of the author may not be used to endorse or promote products -+ * derived from this software without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY SUN MICROSYSTEMS, INC. ``AS IS'' AND ANY -+ * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED -+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE -+ * DISCLAIMED. IN NO EVENT SHALL SUN MICROSYSTEMS, INC. BE LIABLE FOR ANY -+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES -+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND -+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS -+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+ */ -+ -+/* -+ * Copyright (c) 2007 Sun Microsystems. All rights reserved. -+ * Use is subject to license terms. -+ */ -+ -+/* -+ * evport.c: event backend using Solaris 10 event ports. See port_create(3C). -+ * This implementation is loosely modeled after the one used for select(2) (in -+ * select.c). -+ * -+ * The outstanding events are tracked in a data structure called evport_data. -+ * Each entry in the ed_fds array corresponds to a file descriptor, and contains -+ * pointers to the read and write events that correspond to that fd. (That is, -+ * when the file is readable, the "read" event should handle it, etc.) -+ * -+ * evport_add and evport_del update this data structure. evport_dispatch uses it -+ * to determine where to callback when an event occurs (which it gets from -+ * port_getn). -+ * -+ * Helper functions are used: grow() grows the file descriptor array as -+ * necessary when large fd's come in. reassociate() takes care of maintaining -+ * the proper file-descriptor/event-port associations. -+ * -+ * As in the select(2) implementation, signals are handled by evsignal. -+ */ -+ -+#ifdef HAVE_CONFIG_H -+#include "config.h" -+#endif -+ -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#ifdef CHECK_INVARIANTS -+#include -+#endif -+ -+#include "event.h" -+#include "event-internal.h" -+#include "log.h" -+#include "evsignal.h" -+ -+ -+/* -+ * Default value for ed_nevents, which is the maximum file descriptor number we -+ * can handle. If an event comes in for a file descriptor F > nevents, we will -+ * grow the array of file descriptors, doubling its size. -+ */ -+#define DEFAULT_NFDS 16 -+ -+ -+/* -+ * EVENTS_PER_GETN is the maximum number of events to retrieve from port_getn on -+ * any particular call. You can speed things up by increasing this, but it will -+ * (obviously) require more memory. -+ */ -+#define EVENTS_PER_GETN 8 -+ -+/* -+ * Per-file-descriptor information about what events we're subscribed to. These -+ * fields are NULL if no event is subscribed to either of them. -+ */ -+ -+struct fd_info { -+ struct event* fdi_revt; /* the event responsible for the "read" */ -+ struct event* fdi_wevt; /* the event responsible for the "write" */ -+}; -+ -+#define FDI_HAS_READ(fdi) ((fdi)->fdi_revt != NULL) -+#define FDI_HAS_WRITE(fdi) ((fdi)->fdi_wevt != NULL) -+#define FDI_HAS_EVENTS(fdi) (FDI_HAS_READ(fdi) || FDI_HAS_WRITE(fdi)) -+#define FDI_TO_SYSEVENTS(fdi) (FDI_HAS_READ(fdi) ? POLLIN : 0) | \ -+ (FDI_HAS_WRITE(fdi) ? POLLOUT : 0) -+ -+struct evport_data { -+ int ed_port; /* event port for system events */ -+ int ed_nevents; /* number of allocated fdi's */ -+ struct fd_info *ed_fds; /* allocated fdi table */ -+ /* fdi's that we need to reassoc */ -+ int ed_pending[EVENTS_PER_GETN]; /* fd's with pending events */ -+}; -+ -+static void* evport_init (struct event_base *); -+static int evport_add (void *, struct event *); -+static int evport_del (void *, struct event *); -+static int evport_dispatch (struct event_base *, void *, struct timeval *); -+static void evport_dealloc (struct event_base *, void *); -+ -+const struct eventop evportops = { -+ "event ports", -+ evport_init, -+ evport_add, -+ evport_del, -+ evport_dispatch, -+ evport_dealloc, -+ 1 /* need reinit */ -+}; -+ -+/* -+ * Initialize the event port implementation. -+ */ -+ -+static void* -+evport_init(struct event_base *base) -+{ -+ struct evport_data *evpd; -+ int i; -+ /* -+ * Disable event ports when this environment variable is set -+ */ -+ if (getenv("EVENT_NOEVPORT")) -+ return (NULL); -+ -+ if (!(evpd = calloc(1, sizeof(struct evport_data)))) -+ return (NULL); -+ -+ if ((evpd->ed_port = port_create()) == -1) { -+ free(evpd); -+ return (NULL); -+ } -+ -+ /* -+ * Initialize file descriptor structure -+ */ -+ evpd->ed_fds = calloc(DEFAULT_NFDS, sizeof(struct fd_info)); -+ if (evpd->ed_fds == NULL) { -+ close(evpd->ed_port); -+ free(evpd); -+ return (NULL); -+ } -+ evpd->ed_nevents = DEFAULT_NFDS; -+ for (i = 0; i < EVENTS_PER_GETN; i++) -+ evpd->ed_pending[i] = -1; -+ -+ evsignal_init(base); -+ -+ return (evpd); -+} -+ -+#ifdef CHECK_INVARIANTS -+/* -+ * Checks some basic properties about the evport_data structure. Because it -+ * checks all file descriptors, this function can be expensive when the maximum -+ * file descriptor ever used is rather large. -+ */ -+ -+static void -+check_evportop(struct evport_data *evpd) -+{ -+ assert(evpd); -+ assert(evpd->ed_nevents > 0); -+ assert(evpd->ed_port > 0); -+ assert(evpd->ed_fds > 0); -+ -+ /* -+ * Verify the integrity of the fd_info struct as well as the events to -+ * which it points (at least, that they're valid references and correct -+ * for their position in the structure). -+ */ -+ int i; -+ for (i = 0; i < evpd->ed_nevents; ++i) { -+ struct event *ev; -+ struct fd_info *fdi; -+ -+ fdi = &evpd->ed_fds[i]; -+ if ((ev = fdi->fdi_revt) != NULL) { -+ assert(ev->ev_fd == i); -+ } -+ if ((ev = fdi->fdi_wevt) != NULL) { -+ assert(ev->ev_fd == i); -+ } -+ } -+} -+ -+/* -+ * Verifies very basic integrity of a given port_event. -+ */ -+static void -+check_event(port_event_t* pevt) -+{ -+ /* -+ * We've only registered for PORT_SOURCE_FD events. The only -+ * other thing we can legitimately receive is PORT_SOURCE_ALERT, -+ * but since we're not using port_alert either, we can assume -+ * PORT_SOURCE_FD. -+ */ -+ assert(pevt->portev_source == PORT_SOURCE_FD); -+ assert(pevt->portev_user == NULL); -+} -+ -+#else -+#define check_evportop(epop) -+#define check_event(pevt) -+#endif /* CHECK_INVARIANTS */ -+ -+/* -+ * Doubles the size of the allocated file descriptor array. -+ */ -+static int -+grow(struct evport_data *epdp, int factor) -+{ -+ struct fd_info *tmp; -+ int oldsize = epdp->ed_nevents; -+ int newsize = factor * oldsize; -+ assert(factor > 1); -+ -+ check_evportop(epdp); -+ -+ tmp = realloc(epdp->ed_fds, sizeof(struct fd_info) * newsize); -+ if (NULL == tmp) -+ return -1; -+ epdp->ed_fds = tmp; -+ memset((char*) (epdp->ed_fds + oldsize), 0, -+ (newsize - oldsize)*sizeof(struct fd_info)); -+ epdp->ed_nevents = newsize; -+ -+ check_evportop(epdp); -+ -+ return 0; -+} -+ -+ -+/* -+ * (Re)associates the given file descriptor with the event port. The OS events -+ * are specified (implicitly) from the fd_info struct. -+ */ -+static int -+reassociate(struct evport_data *epdp, struct fd_info *fdip, int fd) -+{ -+ int sysevents = FDI_TO_SYSEVENTS(fdip); -+ -+ if (sysevents != 0) { -+ if (port_associate(epdp->ed_port, PORT_SOURCE_FD, -+ fd, sysevents, NULL) == -1) { -+ event_warn("port_associate"); -+ return (-1); -+ } -+ } -+ -+ check_evportop(epdp); -+ -+ return (0); -+} -+ -+/* -+ * Main event loop - polls port_getn for some number of events, and processes -+ * them. -+ */ -+ -+static int -+evport_dispatch(struct event_base *base, void *arg, struct timeval *tv) -+{ -+ int i, res; -+ struct evport_data *epdp = arg; -+ port_event_t pevtlist[EVENTS_PER_GETN]; -+ -+ /* -+ * port_getn will block until it has at least nevents events. It will -+ * also return how many it's given us (which may be more than we asked -+ * for, as long as it's less than our maximum (EVENTS_PER_GETN)) in -+ * nevents. -+ */ -+ int nevents = 1; -+ -+ /* -+ * We have to convert a struct timeval to a struct timespec -+ * (only difference is nanoseconds vs. microseconds). If no time-based -+ * events are active, we should wait for I/O (and tv == NULL). -+ */ -+ struct timespec ts; -+ struct timespec *ts_p = NULL; -+ if (tv != NULL) { -+ ts.tv_sec = tv->tv_sec; -+ ts.tv_nsec = tv->tv_usec * 1000; -+ ts_p = &ts; -+ } -+ -+ /* -+ * Before doing anything else, we need to reassociate the events we hit -+ * last time which need reassociation. See comment at the end of the -+ * loop below. -+ */ -+ for (i = 0; i < EVENTS_PER_GETN; ++i) { -+ struct fd_info *fdi = NULL; -+ if (epdp->ed_pending[i] != -1) { -+ fdi = &(epdp->ed_fds[epdp->ed_pending[i]]); -+ } -+ -+ if (fdi != NULL && FDI_HAS_EVENTS(fdi)) { -+ int fd = FDI_HAS_READ(fdi) ? fdi->fdi_revt->ev_fd : -+ fdi->fdi_wevt->ev_fd; -+ reassociate(epdp, fdi, fd); -+ epdp->ed_pending[i] = -1; -+ } -+ } -+ -+ if ((res = port_getn(epdp->ed_port, pevtlist, EVENTS_PER_GETN, -+ (unsigned int *) &nevents, ts_p)) == -1) { -+ if (errno == EINTR || errno == EAGAIN) { -+ evsignal_process(base); -+ return (0); -+ } else if (errno == ETIME) { -+ if (nevents == 0) -+ return (0); -+ } else { -+ event_warn("port_getn"); -+ return (-1); -+ } -+ } else if (base->sig.evsignal_caught) { -+ evsignal_process(base); -+ } -+ -+ event_debug(("%s: port_getn reports %d events", __func__, nevents)); -+ -+ for (i = 0; i < nevents; ++i) { -+ struct event *ev; -+ struct fd_info *fdi; -+ port_event_t *pevt = &pevtlist[i]; -+ int fd = (int) pevt->portev_object; -+ -+ check_evportop(epdp); -+ check_event(pevt); -+ epdp->ed_pending[i] = fd; -+ -+ /* -+ * Figure out what kind of event it was -+ * (because we have to pass this to the callback) -+ */ -+ res = 0; -+ if (pevt->portev_events & POLLIN) -+ res |= EV_READ; -+ if (pevt->portev_events & POLLOUT) -+ res |= EV_WRITE; -+ -+ assert(epdp->ed_nevents > fd); -+ fdi = &(epdp->ed_fds[fd]); -+ -+ /* -+ * We now check for each of the possible events (READ -+ * or WRITE). Then, we activate the event (which will -+ * cause its callback to be executed). -+ */ -+ -+ if ((res & EV_READ) && ((ev = fdi->fdi_revt) != NULL)) { -+ event_active(ev, res, 1); -+ } -+ -+ if ((res & EV_WRITE) && ((ev = fdi->fdi_wevt) != NULL)) { -+ event_active(ev, res, 1); -+ } -+ } /* end of all events gotten */ -+ -+ check_evportop(epdp); -+ -+ return (0); -+} -+ -+ -+/* -+ * Adds the given event (so that you will be notified when it happens via -+ * the callback function). -+ */ -+ -+static int -+evport_add(void *arg, struct event *ev) -+{ -+ struct evport_data *evpd = arg; -+ struct fd_info *fdi; -+ int factor; -+ -+ check_evportop(evpd); -+ -+ /* -+ * Delegate, if it's not ours to handle. -+ */ -+ if (ev->ev_events & EV_SIGNAL) -+ return (evsignal_add(ev)); -+ -+ /* -+ * If necessary, grow the file descriptor info table -+ */ -+ -+ factor = 1; -+ while (ev->ev_fd >= factor * evpd->ed_nevents) -+ factor *= 2; -+ -+ if (factor > 1) { -+ if (-1 == grow(evpd, factor)) { -+ return (-1); -+ } -+ } -+ -+ fdi = &evpd->ed_fds[ev->ev_fd]; -+ if (ev->ev_events & EV_READ) -+ fdi->fdi_revt = ev; -+ if (ev->ev_events & EV_WRITE) -+ fdi->fdi_wevt = ev; -+ -+ return reassociate(evpd, fdi, ev->ev_fd); -+} -+ -+/* -+ * Removes the given event from the list of events to wait for. -+ */ -+ -+static int -+evport_del(void *arg, struct event *ev) -+{ -+ struct evport_data *evpd = arg; -+ struct fd_info *fdi; -+ int i; -+ int associated = 1; -+ -+ check_evportop(evpd); -+ -+ /* -+ * Delegate, if it's not ours to handle -+ */ -+ if (ev->ev_events & EV_SIGNAL) { -+ return (evsignal_del(ev)); -+ } -+ -+ if (evpd->ed_nevents < ev->ev_fd) { -+ return (-1); -+ } -+ -+ for (i = 0; i < EVENTS_PER_GETN; ++i) { -+ if (evpd->ed_pending[i] == ev->ev_fd) { -+ associated = 0; -+ break; -+ } -+ } -+ -+ fdi = &evpd->ed_fds[ev->ev_fd]; -+ if (ev->ev_events & EV_READ) -+ fdi->fdi_revt = NULL; -+ if (ev->ev_events & EV_WRITE) -+ fdi->fdi_wevt = NULL; -+ -+ if (associated) { -+ if (!FDI_HAS_EVENTS(fdi) && -+ port_dissociate(evpd->ed_port, PORT_SOURCE_FD, -+ ev->ev_fd) == -1) { -+ /* -+ * Ignre EBADFD error the fd could have been closed -+ * before event_del() was called. -+ */ -+ if (errno != EBADFD) { -+ event_warn("port_dissociate"); -+ return (-1); -+ } -+ } else { -+ if (FDI_HAS_EVENTS(fdi)) { -+ return (reassociate(evpd, fdi, ev->ev_fd)); -+ } -+ } -+ } else { -+ if (fdi->fdi_revt == NULL && fdi->fdi_wevt == NULL) { -+ evpd->ed_pending[i] = -1; -+ } -+ } -+ return 0; -+} -+ -+ -+static void -+evport_dealloc(struct event_base *base, void *arg) -+{ -+ struct evport_data *evpd = arg; -+ -+ evsignal_dealloc(base); -+ -+ close(evpd->ed_port); -+ -+ if (evpd->ed_fds) -+ free(evpd->ed_fds); -+ free(evpd); -+} -diff --git a/libevent/evsignal.h b/libevent/evsignal.h -new file mode 100644 -index 0000000..8be9cbd ---- /dev/null -+++ b/libevent/evsignal.h -@@ -0,0 +1,52 @@ -+/* -+ * Copyright 2000-2002 Niels Provos -+ * All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. The name of the author may not be used to endorse or promote products -+ * derived from this software without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR -+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES -+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. -+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, -+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT -+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF -+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+ */ -+#ifndef _EVSIGNAL_H_ -+#define _EVSIGNAL_H_ -+ -+typedef void (*ev_sighandler_t)(int); -+ -+struct evsignal_info { -+ struct event ev_signal; -+ int ev_signal_pair[2]; -+ int ev_signal_added; -+ volatile sig_atomic_t evsignal_caught; -+ struct event_list evsigevents[NSIG]; -+ sig_atomic_t evsigcaught[NSIG]; -+#ifdef HAVE_SIGACTION -+ struct sigaction **sh_old; -+#else -+ ev_sighandler_t **sh_old; -+#endif -+ int sh_old_max; -+}; -+void evsignal_init(struct event_base *); -+void evsignal_process(struct event_base *); -+int evsignal_add(struct event *); -+int evsignal_del(struct event *); -+void evsignal_dealloc(struct event_base *); -+ -+#endif /* _EVSIGNAL_H_ */ -diff --git a/libevent/evutil.c b/libevent/evutil.c -new file mode 100644 -index 0000000..86205b2 ---- /dev/null -+++ b/libevent/evutil.c -@@ -0,0 +1,248 @@ -+/* -+ * Copyright (c) 2007 Niels Provos -+ * All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. The name of the author may not be used to endorse or promote products -+ * derived from this software without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR -+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES -+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. -+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, -+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT -+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF -+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+ */ -+ -+#include "event-fpm.h" -+ -+#ifdef HAVE_CONFIG_H -+#include "config.h" -+#endif -+ -+#ifdef WIN32 -+#include -+#define WIN32_LEAN_AND_MEAN -+#include -+#undef WIN32_LEAN_AND_MEAN -+#endif -+ -+#include -+#ifdef HAVE_SYS_SOCKET_H -+#include -+#endif -+#ifdef HAVE_UNISTD_H -+#include -+#endif -+#ifdef HAVE_FCNTL_H -+#include -+#endif -+#ifdef HAVE_STDLIB_H -+#include -+#endif -+#include -+#if defined WIN32 && !defined(HAVE_GETTIMEOFDAY_H) -+#include -+#endif -+#include -+ -+#include "evutil.h" -+#include "log.h" -+ -+int -+evutil_socketpair(int family, int type, int protocol, int fd[2]) -+{ -+#ifndef WIN32 -+ return socketpair(family, type, protocol, fd); -+#else -+ /* This code is originally from Tor. Used with permission. */ -+ -+ /* This socketpair does not work when localhost is down. So -+ * it's really not the same thing at all. But it's close enough -+ * for now, and really, when localhost is down sometimes, we -+ * have other problems too. -+ */ -+ int listener = -1; -+ int connector = -1; -+ int acceptor = -1; -+ struct sockaddr_in listen_addr; -+ struct sockaddr_in connect_addr; -+ int size; -+ int saved_errno = -1; -+ -+ if (protocol -+#ifdef AF_UNIX -+ || family != AF_UNIX -+#endif -+ ) { -+ EVUTIL_SET_SOCKET_ERROR(WSAEAFNOSUPPORT); -+ return -1; -+ } -+ if (!fd) { -+ EVUTIL_SET_SOCKET_ERROR(WSAEINVAL); -+ return -1; -+ } -+ -+ listener = socket(AF_INET, type, 0); -+ if (listener < 0) -+ return -1; -+ memset(&listen_addr, 0, sizeof(listen_addr)); -+ listen_addr.sin_family = AF_INET; -+ listen_addr.sin_addr.s_addr = htonl(INADDR_LOOPBACK); -+ listen_addr.sin_port = 0; /* kernel chooses port. */ -+ if (bind(listener, (struct sockaddr *) &listen_addr, sizeof (listen_addr)) -+ == -1) -+ goto tidy_up_and_fail; -+ if (listen(listener, 1) == -1) -+ goto tidy_up_and_fail; -+ -+ connector = socket(AF_INET, type, 0); -+ if (connector < 0) -+ goto tidy_up_and_fail; -+ /* We want to find out the port number to connect to. */ -+ size = sizeof(connect_addr); -+ if (getsockname(listener, (struct sockaddr *) &connect_addr, &size) == -1) -+ goto tidy_up_and_fail; -+ if (size != sizeof (connect_addr)) -+ goto abort_tidy_up_and_fail; -+ if (connect(connector, (struct sockaddr *) &connect_addr, -+ sizeof(connect_addr)) == -1) -+ goto tidy_up_and_fail; -+ -+ size = sizeof(listen_addr); -+ acceptor = accept(listener, (struct sockaddr *) &listen_addr, &size); -+ if (acceptor < 0) -+ goto tidy_up_and_fail; -+ if (size != sizeof(listen_addr)) -+ goto abort_tidy_up_and_fail; -+ EVUTIL_CLOSESOCKET(listener); -+ /* Now check we are talking to ourself by matching port and host on the -+ two sockets. */ -+ if (getsockname(connector, (struct sockaddr *) &connect_addr, &size) == -1) -+ goto tidy_up_and_fail; -+ if (size != sizeof (connect_addr) -+ || listen_addr.sin_family != connect_addr.sin_family -+ || listen_addr.sin_addr.s_addr != connect_addr.sin_addr.s_addr -+ || listen_addr.sin_port != connect_addr.sin_port) -+ goto abort_tidy_up_and_fail; -+ fd[0] = connector; -+ fd[1] = acceptor; -+ -+ return 0; -+ -+ abort_tidy_up_and_fail: -+ saved_errno = WSAECONNABORTED; -+ tidy_up_and_fail: -+ if (saved_errno < 0) -+ saved_errno = WSAGetLastError(); -+ if (listener != -1) -+ EVUTIL_CLOSESOCKET(listener); -+ if (connector != -1) -+ EVUTIL_CLOSESOCKET(connector); -+ if (acceptor != -1) -+ EVUTIL_CLOSESOCKET(acceptor); -+ -+ EVUTIL_SET_SOCKET_ERROR(saved_errno); -+ return -1; -+#endif -+} -+ -+int -+evutil_make_socket_nonblocking(int fd) -+{ -+#ifdef WIN32 -+ { -+ unsigned long nonblocking = 1; -+ ioctlsocket(fd, FIONBIO, (unsigned long*) &nonblocking); -+ } -+#else -+ if (fcntl(fd, F_SETFL, O_NONBLOCK) == -1) { -+ event_warn("fcntl(O_NONBLOCK)"); -+ return -1; -+} -+#endif -+ return 0; -+} -+ -+ev_int64_t -+evutil_strtoll(const char *s, char **endptr, int base) -+{ -+#ifdef HAVE_STRTOLL -+ return (ev_int64_t)strtoll(s, endptr, base); -+#elif SIZEOF_LONG == 8 -+ return (ev_int64_t)strtol(s, endptr, base); -+#elif defined(WIN32) && defined(_MSC_VER) && _MSC_VER < 1300 -+ /* XXXX on old versions of MS APIs, we only support base -+ * 10. */ -+ ev_int64_t r; -+ if (base != 10) -+ return 0; -+ r = (ev_int64_t) _atoi64(s); -+ while (isspace(*s)) -+ ++s; -+ while (isdigit(*s)) -+ ++s; -+ if (endptr) -+ *endptr = (char*) s; -+ return r; -+#elif defined(WIN32) -+ return (ev_int64_t) _strtoi64(s, endptr, base); -+#else -+#error "I don't know how to parse 64-bit integers." -+#endif -+} -+ -+#ifndef _EVENT_HAVE_GETTIMEOFDAY -+int -+evutil_gettimeofday(struct timeval *tv, struct timezone *tz) -+{ -+ struct _timeb tb; -+ -+ if(tv == NULL) -+ return -1; -+ -+ _ftime(&tb); -+ tv->tv_sec = (long) tb.time; -+ tv->tv_usec = ((int) tb.millitm) * 1000; -+ return 0; -+} -+#endif -+ -+int -+evutil_snprintf(char *buf, size_t buflen, const char *format, ...) -+{ -+ int r; -+ va_list ap; -+ va_start(ap, format); -+ r = evutil_vsnprintf(buf, buflen, format, ap); -+ va_end(ap); -+ return r; -+} -+ -+int -+evutil_vsnprintf(char *buf, size_t buflen, const char *format, va_list ap) -+{ -+#ifdef _MSC_VER -+ int r = _vsnprintf(buf, buflen, format, ap); -+ buf[buflen-1] = '\0'; -+ if (r >= 0) -+ return r; -+ else -+ return _vscprintf(format, ap); -+#else -+ int r = vsnprintf(buf, buflen, format, ap); -+ buf[buflen-1] = '\0'; -+ return r; -+#endif -+} -diff --git a/libevent/evutil.h b/libevent/evutil.h -new file mode 100644 -index 0000000..0a018b8 ---- /dev/null -+++ b/libevent/evutil.h -@@ -0,0 +1,185 @@ -+/* -+ * Copyright (c) 2007 Niels Provos -+ * All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. The name of the author may not be used to endorse or promote products -+ * derived from this software without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR -+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES -+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. -+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, -+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT -+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF -+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+ */ -+#ifndef _EVUTIL_H_ -+#define _EVUTIL_H_ -+ -+/** @file evutil.h -+ -+ Common convenience functions for cross-platform portability and -+ related socket manipulations. -+ -+ */ -+ -+#ifdef __cplusplus -+extern "C" { -+#endif -+ -+#include -+#ifdef _EVENT_HAVE_SYS_TIME_H -+#include -+#endif -+#ifdef _EVENT_HAVE_STDINT_H -+#include -+#elif defined(_EVENT_HAVE_INTTYPES_H) -+#include -+#endif -+#ifdef _EVENT_HAVE_SYS_TYPES_H -+#include -+#endif -+#include -+ -+#ifdef _EVENT_HAVE_UINT64_T -+#define ev_uint64_t uint64_t -+#define ev_int64_t int64_t -+#elif defined(WIN32) -+#define ev_uint64_t unsigned __int64 -+#define ev_int64_t signed __int64 -+#elif _EVENT_SIZEOF_LONG_LONG == 8 -+#define ev_uint64_t unsigned long long -+#define ev_int64_t long long -+#elif _EVENT_SIZEOF_LONG == 8 -+#define ev_uint64_t unsigned long -+#define ev_int64_t long -+#else -+#error "No way to define ev_uint64_t" -+#endif -+ -+#ifdef _EVENT_HAVE_UINT32_T -+#define ev_uint32_t uint32_t -+#elif defined(WIN32) -+#define ev_uint32_t unsigned int -+#elif _EVENT_SIZEOF_LONG == 4 -+#define ev_uint32_t unsigned long -+#elif _EVENT_SIZEOF_INT == 4 -+#define ev_uint32_t unsigned int -+#else -+#error "No way to define ev_uint32_t" -+#endif -+ -+#ifdef _EVENT_HAVE_UINT16_T -+#define ev_uint16_t uint16_t -+#elif defined(WIN32) -+#define ev_uint16_t unsigned short -+#elif _EVENT_SIZEOF_INT == 2 -+#define ev_uint16_t unsigned int -+#elif _EVENT_SIZEOF_SHORT == 2 -+#define ev_uint16_t unsigned short -+#else -+#error "No way to define ev_uint16_t" -+#endif -+ -+#ifdef _EVENT_HAVE_UINT8_T -+#define ev_uint8_t uint8_t -+#else -+#define ev_uint8_t unsigned char -+#endif -+ -+int evutil_socketpair(int d, int type, int protocol, int sv[2]); -+int evutil_make_socket_nonblocking(int sock); -+#ifdef WIN32 -+#define EVUTIL_CLOSESOCKET(s) closesocket(s) -+#else -+#define EVUTIL_CLOSESOCKET(s) close(s) -+#endif -+ -+#ifdef WIN32 -+#define EVUTIL_SOCKET_ERROR() WSAGetLastError() -+#define EVUTIL_SET_SOCKET_ERROR(errcode) \ -+ do { WSASetLastError(errcode); } while (0) -+#else -+#define EVUTIL_SOCKET_ERROR() (errno) -+#define EVUTIL_SET_SOCKET_ERROR(errcode) \ -+ do { errno = (errcode); } while (0) -+#endif -+ -+/* -+ * Manipulation functions for struct timeval -+ */ -+#ifdef _EVENT_HAVE_TIMERADD -+#define evutil_timeradd(tvp, uvp, vvp) timeradd((tvp), (uvp), (vvp)) -+#define evutil_timersub(tvp, uvp, vvp) timersub((tvp), (uvp), (vvp)) -+#else -+#define evutil_timeradd(tvp, uvp, vvp) \ -+ do { \ -+ (vvp)->tv_sec = (tvp)->tv_sec + (uvp)->tv_sec; \ -+ (vvp)->tv_usec = (tvp)->tv_usec + (uvp)->tv_usec; \ -+ if ((vvp)->tv_usec >= 1000000) { \ -+ (vvp)->tv_sec++; \ -+ (vvp)->tv_usec -= 1000000; \ -+ } \ -+ } while (0) -+#define evutil_timersub(tvp, uvp, vvp) \ -+ do { \ -+ (vvp)->tv_sec = (tvp)->tv_sec - (uvp)->tv_sec; \ -+ (vvp)->tv_usec = (tvp)->tv_usec - (uvp)->tv_usec; \ -+ if ((vvp)->tv_usec < 0) { \ -+ (vvp)->tv_sec--; \ -+ (vvp)->tv_usec += 1000000; \ -+ } \ -+ } while (0) -+#endif /* !_EVENT_HAVE_HAVE_TIMERADD */ -+ -+#ifdef _EVENT_HAVE_TIMERCLEAR -+#define evutil_timerclear(tvp) timerclear(tvp) -+#else -+#define evutil_timerclear(tvp) (tvp)->tv_sec = (tvp)->tv_usec = 0 -+#endif -+ -+#define evutil_timercmp(tvp, uvp, cmp) \ -+ (((tvp)->tv_sec == (uvp)->tv_sec) ? \ -+ ((tvp)->tv_usec cmp (uvp)->tv_usec) : \ -+ ((tvp)->tv_sec cmp (uvp)->tv_sec)) -+ -+#ifdef _EVENT_HAVE_TIMERISSET -+#define evutil_timerisset(tvp) timerisset(tvp) -+#else -+#define evutil_timerisset(tvp) ((tvp)->tv_sec || (tvp)->tv_usec) -+#endif -+ -+ -+/* big-int related functions */ -+ev_int64_t evutil_strtoll(const char *s, char **endptr, int base); -+ -+ -+#ifdef _EVENT_HAVE_GETTIMEOFDAY -+#define evutil_gettimeofday(tv, tz) gettimeofday((tv), (tz)) -+#else -+int evutil_gettimeofday(struct timeval *tv, struct timezone *tz); -+#endif -+ -+int evutil_snprintf(char *buf, size_t buflen, const char *format, ...) -+#ifdef __GNUC__ -+ __attribute__((format(printf, 3, 4))) -+#endif -+ ; -+int evutil_vsnprintf(char *buf, size_t buflen, const char *format, va_list ap); -+ -+#ifdef __cplusplus -+} -+#endif -+ -+#endif /* _EVUTIL_H_ */ -diff --git a/libevent/http-internal.h b/libevent/http-internal.h -new file mode 100644 -index 0000000..bc9a1ed ---- /dev/null -+++ b/libevent/http-internal.h -@@ -0,0 +1,153 @@ -+/* -+ * Copyright 2001 Niels Provos -+ * All rights reserved. -+ * -+ * This header file contains definitions for dealing with HTTP requests -+ * that are internal to libevent. As user of the library, you should not -+ * need to know about these. -+ */ -+ -+#ifndef _HTTP_H_ -+#define _HTTP_H_ -+ -+#define HTTP_CONNECT_TIMEOUT 45 -+#define HTTP_WRITE_TIMEOUT 50 -+#define HTTP_READ_TIMEOUT 50 -+ -+#define HTTP_PREFIX "http://" -+#define HTTP_DEFAULTPORT 80 -+ -+enum message_read_status { -+ ALL_DATA_READ = 1, -+ MORE_DATA_EXPECTED = 0, -+ DATA_CORRUPTED = -1, -+ REQUEST_CANCELED = -2 -+}; -+ -+enum evhttp_connection_error { -+ EVCON_HTTP_TIMEOUT, -+ EVCON_HTTP_EOF, -+ EVCON_HTTP_INVALID_HEADER -+}; -+ -+struct evbuffer; -+struct addrinfo; -+struct evhttp_request; -+ -+/* A stupid connection object - maybe make this a bufferevent later */ -+ -+enum evhttp_connection_state { -+ EVCON_DISCONNECTED, /**< not currently connected not trying either*/ -+ EVCON_CONNECTING, /**< tries to currently connect */ -+ EVCON_IDLE, /**< connection is established */ -+ EVCON_READING_FIRSTLINE,/**< reading Request-Line (incoming conn) or -+ **< Status-Line (outgoing conn) */ -+ EVCON_READING_HEADERS, /**< reading request/response headers */ -+ EVCON_READING_BODY, /**< reading request/response body */ -+ EVCON_READING_TRAILER, /**< reading request/response chunked trailer */ -+ EVCON_WRITING /**< writing request/response headers/body */ -+}; -+ -+struct event_base; -+ -+struct evhttp_connection { -+ /* we use tailq only if they were created for an http server */ -+ TAILQ_ENTRY(evhttp_connection) (next); -+ -+ int fd; -+ struct event ev; -+ struct event close_ev; -+ struct evbuffer *input_buffer; -+ struct evbuffer *output_buffer; -+ -+ char *bind_address; /* address to use for binding the src */ -+ -+ char *address; /* address to connect to */ -+ u_short port; -+ -+ int flags; -+#define EVHTTP_CON_INCOMING 0x0001 /* only one request on it ever */ -+#define EVHTTP_CON_OUTGOING 0x0002 /* multiple requests possible */ -+#define EVHTTP_CON_CLOSEDETECT 0x0004 /* detecting if persistent close */ -+ -+ int timeout; /* timeout in seconds for events */ -+ int retry_cnt; /* retry count */ -+ int retry_max; /* maximum number of retries */ -+ -+ enum evhttp_connection_state state; -+ -+ /* for server connections, the http server they are connected with */ -+ struct evhttp *http_server; -+ -+ TAILQ_HEAD(evcon_requestq, evhttp_request) requests; -+ -+ void (*cb)(struct evhttp_connection *, void *); -+ void *cb_arg; -+ -+ void (*closecb)(struct evhttp_connection *, void *); -+ void *closecb_arg; -+ -+ struct event_base *base; -+}; -+ -+struct evhttp_cb { -+ TAILQ_ENTRY(evhttp_cb) next; -+ -+ char *what; -+ -+ void (*cb)(struct evhttp_request *req, void *); -+ void *cbarg; -+}; -+ -+/* both the http server as well as the rpc system need to queue connections */ -+TAILQ_HEAD(evconq, evhttp_connection); -+ -+/* each bound socket is stored in one of these */ -+struct evhttp_bound_socket { -+ TAILQ_ENTRY(evhttp_bound_socket) (next); -+ -+ struct event bind_ev; -+}; -+ -+struct evhttp { -+ TAILQ_HEAD(boundq, evhttp_bound_socket) sockets; -+ -+ TAILQ_HEAD(httpcbq, evhttp_cb) callbacks; -+ struct evconq connections; -+ -+ int timeout; -+ -+ void (*gencb)(struct evhttp_request *req, void *); -+ void *gencbarg; -+ -+ struct event_base *base; -+}; -+ -+/* resets the connection; can be reused for more requests */ -+void evhttp_connection_reset(struct evhttp_connection *); -+ -+/* connects if necessary */ -+int evhttp_connection_connect(struct evhttp_connection *); -+ -+/* notifies the current request that it failed; resets connection */ -+void evhttp_connection_fail(struct evhttp_connection *, -+ enum evhttp_connection_error error); -+ -+void evhttp_get_request(struct evhttp *, int, struct sockaddr *, socklen_t); -+ -+int evhttp_hostportfile(char *, char **, u_short *, char **); -+ -+int evhttp_parse_firstline(struct evhttp_request *, struct evbuffer*); -+int evhttp_parse_headers(struct evhttp_request *, struct evbuffer*); -+ -+void evhttp_start_read(struct evhttp_connection *); -+void evhttp_make_header(struct evhttp_connection *, struct evhttp_request *); -+ -+void evhttp_write_buffer(struct evhttp_connection *, -+ void (*)(struct evhttp_connection *, void *), void *); -+ -+/* response sending HTML the data in the buffer */ -+void evhttp_response_code(struct evhttp_request *, int, const char *); -+void evhttp_send_page(struct evhttp_request *, struct evbuffer *); -+ -+#endif /* _HTTP_H */ -diff --git a/libevent/http.c b/libevent/http.c -new file mode 100644 -index 0000000..1d60fc5 ---- /dev/null -+++ b/libevent/http.c -@@ -0,0 +1,2768 @@ -+/* -+ * Copyright (c) 2002-2006 Niels Provos -+ * All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. The name of the author may not be used to endorse or promote products -+ * derived from this software without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR -+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES -+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. -+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, -+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT -+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF -+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+ */ -+ -+#ifdef HAVE_CONFIG_H -+#include "config.h" -+#endif -+ -+#ifdef HAVE_SYS_PARAM_H -+#include -+#endif -+#ifdef HAVE_SYS_TYPES_H -+#include -+#endif -+ -+#ifdef HAVE_SYS_TIME_H -+#include -+#endif -+#ifdef HAVE_SYS_IOCCOM_H -+#include -+#endif -+ -+#ifndef WIN32 -+#include -+#include -+#include -+#include -+#endif -+ -+#include -+ -+#ifndef WIN32 -+#include -+#include -+#endif -+ -+#ifdef WIN32 -+#include -+#endif -+ -+#include -+#include -+#include -+#include -+#include -+#include -+#ifndef WIN32 -+#include -+#endif -+#include -+#include -+#ifdef HAVE_UNISTD_H -+#include -+#endif -+#ifdef HAVE_FCNTL_H -+#include -+#endif -+ -+#undef timeout_pending -+#undef timeout_initialized -+ -+#include "strlcpy-internal.h" -+#include "event.h" -+#include "evhttp.h" -+#include "evutil.h" -+#include "log.h" -+#include "http-internal.h" -+ -+#ifdef WIN32 -+#define strcasecmp _stricmp -+#define strncasecmp _strnicmp -+#define strdup _strdup -+#endif -+ -+#ifndef HAVE_GETNAMEINFO -+#define NI_MAXSERV 32 -+#define NI_MAXHOST 1025 -+ -+#define NI_NUMERICHOST 1 -+#define NI_NUMERICSERV 2 -+ -+int -+fake_getnameinfo(const struct sockaddr *sa, size_t salen, char *host, -+ size_t hostlen, char *serv, size_t servlen, int flags) -+{ -+ struct sockaddr_in *sin = (struct sockaddr_in *)sa; -+ -+ if (serv != NULL) { -+ char tmpserv[16]; -+ evutil_snprintf(tmpserv, sizeof(tmpserv), -+ "%d", ntohs(sin->sin_port)); -+ if (strlcpy(serv, tmpserv, servlen) >= servlen) -+ return (-1); -+ } -+ -+ if (host != NULL) { -+ if (flags & NI_NUMERICHOST) { -+ if (strlcpy(host, inet_ntoa(sin->sin_addr), -+ hostlen) >= hostlen) -+ return (-1); -+ else -+ return (0); -+ } else { -+ struct hostent *hp; -+ hp = gethostbyaddr((char *)&sin->sin_addr, -+ sizeof(struct in_addr), AF_INET); -+ if (hp == NULL) -+ return (-2); -+ -+ if (strlcpy(host, hp->h_name, hostlen) >= hostlen) -+ return (-1); -+ else -+ return (0); -+ } -+ } -+ return (0); -+} -+ -+#endif -+ -+#ifndef HAVE_GETADDRINFO -+struct addrinfo { -+ int ai_family; -+ int ai_socktype; -+ int ai_protocol; -+ size_t ai_addrlen; -+ struct sockaddr *ai_addr; -+ struct addrinfo *ai_next; -+}; -+static int -+fake_getaddrinfo(const char *hostname, struct addrinfo *ai) -+{ -+ struct hostent *he = NULL; -+ struct sockaddr_in *sa; -+ if (hostname) { -+ he = gethostbyname(hostname); -+ if (!he) -+ return (-1); -+ } -+ ai->ai_family = he ? he->h_addrtype : AF_INET; -+ ai->ai_socktype = SOCK_STREAM; -+ ai->ai_protocol = 0; -+ ai->ai_addrlen = sizeof(struct sockaddr_in); -+ if (NULL == (ai->ai_addr = malloc(ai->ai_addrlen))) -+ return (-1); -+ sa = (struct sockaddr_in*)ai->ai_addr; -+ memset(sa, 0, ai->ai_addrlen); -+ if (he) { -+ sa->sin_family = he->h_addrtype; -+ memcpy(&sa->sin_addr, he->h_addr_list[0], he->h_length); -+ } else { -+ sa->sin_family = AF_INET; -+ sa->sin_addr.s_addr = INADDR_ANY; -+ } -+ ai->ai_next = NULL; -+ return (0); -+} -+static void -+fake_freeaddrinfo(struct addrinfo *ai) -+{ -+ free(ai->ai_addr); -+} -+#endif -+ -+#ifndef MIN -+#define MIN(a,b) (((a)<(b))?(a):(b)) -+#endif -+ -+/* wrapper for setting the base from the http server */ -+#define EVHTTP_BASE_SET(x, y) do { \ -+ if ((x)->base != NULL) event_base_set((x)->base, y); \ -+} while (0) -+ -+extern int debug; -+ -+static int socket_connect(int fd, const char *address, unsigned short port); -+static int bind_socket_ai(struct addrinfo *, int reuse); -+static int bind_socket(const char *, u_short, int reuse); -+static void name_from_addr(struct sockaddr *, socklen_t, char **, char **); -+static int evhttp_associate_new_request_with_connection( -+ struct evhttp_connection *evcon); -+static void evhttp_connection_start_detectclose( -+ struct evhttp_connection *evcon); -+static void evhttp_connection_stop_detectclose( -+ struct evhttp_connection *evcon); -+static void evhttp_request_dispatch(struct evhttp_connection* evcon); -+static void evhttp_read_firstline(struct evhttp_connection *evcon, -+ struct evhttp_request *req); -+static void evhttp_read_header(struct evhttp_connection *evcon, -+ struct evhttp_request *req); -+ -+void evhttp_read(int, short, void *); -+void evhttp_write(int, short, void *); -+ -+#ifndef HAVE_STRSEP -+/* strsep replacement for platforms that lack it. Only works if -+ * del is one character long. */ -+static char * -+strsep(char **s, const char *del) -+{ -+ char *d, *tok; -+ assert(strlen(del) == 1); -+ if (!s || !*s) -+ return NULL; -+ tok = *s; -+ d = strstr(tok, del); -+ if (d) { -+ *d = '\0'; -+ *s = d + 1; -+ } else -+ *s = NULL; -+ return tok; -+} -+#endif -+ -+static const char * -+html_replace(char ch, char *buf) -+{ -+ switch (ch) { -+ case '<': -+ return "<"; -+ case '>': -+ return ">"; -+ case '"': -+ return """; -+ case '\'': -+ return "'"; -+ case '&': -+ return "&"; -+ default: -+ break; -+ } -+ -+ /* Echo the character back */ -+ buf[0] = ch; -+ buf[1] = '\0'; -+ -+ return buf; -+} -+ -+/* -+ * Replaces <, >, ", ' and & with <, >, ", -+ * ' and & correspondingly. -+ * -+ * The returned string needs to be freed by the caller. -+ */ -+ -+char * -+evhttp_htmlescape(const char *html) -+{ -+ int i, new_size = 0, old_size = strlen(html); -+ char *escaped_html, *p; -+ char scratch_space[2]; -+ -+ for (i = 0; i < old_size; ++i) -+ new_size += strlen(html_replace(html[i], scratch_space)); -+ -+ p = escaped_html = malloc(new_size + 1); -+ if (escaped_html == NULL) -+ event_err(1, "%s: malloc(%d)", __func__, new_size + 1); -+ for (i = 0; i < old_size; ++i) { -+ const char *replaced = html_replace(html[i], scratch_space); -+ /* this is length checked */ -+ strcpy(p, replaced); -+ p += strlen(replaced); -+ } -+ -+ *p = '\0'; -+ -+ return (escaped_html); -+} -+ -+static const char * -+evhttp_method(enum evhttp_cmd_type type) -+{ -+ const char *method; -+ -+ switch (type) { -+ case EVHTTP_REQ_GET: -+ method = "GET"; -+ break; -+ case EVHTTP_REQ_POST: -+ method = "POST"; -+ break; -+ case EVHTTP_REQ_HEAD: -+ method = "HEAD"; -+ break; -+ default: -+ method = NULL; -+ break; -+ } -+ -+ return (method); -+} -+ -+static void -+evhttp_add_event(struct event *ev, int timeout, int default_timeout) -+{ -+ if (timeout != 0) { -+ struct timeval tv; -+ -+ evutil_timerclear(&tv); -+ tv.tv_sec = timeout != -1 ? timeout : default_timeout; -+ event_add(ev, &tv); -+ } else { -+ event_add(ev, NULL); -+ } -+} -+ -+void -+evhttp_write_buffer(struct evhttp_connection *evcon, -+ void (*cb)(struct evhttp_connection *, void *), void *arg) -+{ -+ event_debug(("%s: preparing to write buffer\n", __func__)); -+ -+ /* Set call back */ -+ evcon->cb = cb; -+ evcon->cb_arg = arg; -+ -+ /* check if the event is already pending */ -+ if (event_pending(&evcon->ev, EV_WRITE|EV_TIMEOUT, NULL)) -+ event_del(&evcon->ev); -+ -+ event_set(&evcon->ev, evcon->fd, EV_WRITE, evhttp_write, evcon); -+ EVHTTP_BASE_SET(evcon, &evcon->ev); -+ evhttp_add_event(&evcon->ev, evcon->timeout, HTTP_WRITE_TIMEOUT); -+} -+ -+static int -+evhttp_connected(struct evhttp_connection *evcon) -+{ -+ switch (evcon->state) { -+ case EVCON_DISCONNECTED: -+ case EVCON_CONNECTING: -+ return (0); -+ case EVCON_IDLE: -+ case EVCON_READING_FIRSTLINE: -+ case EVCON_READING_HEADERS: -+ case EVCON_READING_BODY: -+ case EVCON_READING_TRAILER: -+ case EVCON_WRITING: -+ default: -+ return (1); -+ } -+} -+ -+/* -+ * Create the headers needed for an HTTP request -+ */ -+static void -+evhttp_make_header_request(struct evhttp_connection *evcon, -+ struct evhttp_request *req) -+{ -+ char line[1024]; -+ const char *method; -+ -+ evhttp_remove_header(req->output_headers, "Proxy-Connection"); -+ -+ /* Generate request line */ -+ method = evhttp_method(req->type); -+ evutil_snprintf(line, sizeof(line), "%s %s HTTP/%d.%d\r\n", -+ method, req->uri, req->major, req->minor); -+ evbuffer_add(evcon->output_buffer, line, strlen(line)); -+ -+ /* Add the content length on a post request if missing */ -+ if (req->type == EVHTTP_REQ_POST && -+ evhttp_find_header(req->output_headers, "Content-Length") == NULL){ -+ char size[12]; -+ evutil_snprintf(size, sizeof(size), "%ld", -+ (long)EVBUFFER_LENGTH(req->output_buffer)); -+ evhttp_add_header(req->output_headers, "Content-Length", size); -+ } -+} -+ -+static int -+evhttp_is_connection_close(int flags, struct evkeyvalq* headers) -+{ -+ if (flags & EVHTTP_PROXY_REQUEST) { -+ /* proxy connection */ -+ const char *connection = evhttp_find_header(headers, "Proxy-Connection"); -+ return (connection == NULL || strcasecmp(connection, "keep-alive") != 0); -+ } else { -+ const char *connection = evhttp_find_header(headers, "Connection"); -+ return (connection != NULL && strcasecmp(connection, "close") == 0); -+ } -+} -+ -+static int -+evhttp_is_connection_keepalive(struct evkeyvalq* headers) -+{ -+ const char *connection = evhttp_find_header(headers, "Connection"); -+ return (connection != NULL -+ && strncasecmp(connection, "keep-alive", 10) == 0); -+} -+ -+static void -+evhttp_maybe_add_date_header(struct evkeyvalq *headers) -+{ -+ if (evhttp_find_header(headers, "Date") == NULL) { -+ char date[50]; -+#ifndef WIN32 -+ struct tm cur; -+#endif -+ struct tm *cur_p; -+ time_t t = time(NULL); -+#ifdef WIN32 -+ cur_p = gmtime(&t); -+#else -+ gmtime_r(&t, &cur); -+ cur_p = &cur; -+#endif -+ if (strftime(date, sizeof(date), -+ "%a, %d %b %Y %H:%M:%S GMT", cur_p) != 0) { -+ evhttp_add_header(headers, "Date", date); -+ } -+ } -+} -+ -+static void -+evhttp_maybe_add_content_length_header(struct evkeyvalq *headers, -+ long content_length) -+{ -+ if (evhttp_find_header(headers, "Transfer-Encoding") == NULL && -+ evhttp_find_header(headers, "Content-Length") == NULL) { -+ char len[12]; -+ evutil_snprintf(len, sizeof(len), "%ld", content_length); -+ evhttp_add_header(headers, "Content-Length", len); -+ } -+} -+ -+/* -+ * Create the headers needed for an HTTP reply -+ */ -+ -+static void -+evhttp_make_header_response(struct evhttp_connection *evcon, -+ struct evhttp_request *req) -+{ -+ int is_keepalive = evhttp_is_connection_keepalive(req->input_headers); -+ char line[1024]; -+ evutil_snprintf(line, sizeof(line), "HTTP/%d.%d %d %s\r\n", -+ req->major, req->minor, req->response_code, -+ req->response_code_line); -+ evbuffer_add(evcon->output_buffer, line, strlen(line)); -+ -+ if (req->major == 1) { -+ if (req->minor == 1) -+ evhttp_maybe_add_date_header(req->output_headers); -+ -+ /* -+ * if the protocol is 1.0; and the connection was keep-alive -+ * we need to add a keep-alive header, too. -+ */ -+ if (req->minor == 0 && is_keepalive) -+ evhttp_add_header(req->output_headers, -+ "Connection", "keep-alive"); -+ -+ if (req->minor == 1 || is_keepalive) { -+ /* -+ * we need to add the content length if the -+ * user did not give it, this is required for -+ * persistent connections to work. -+ */ -+ evhttp_maybe_add_content_length_header( -+ req->output_headers, -+ (long)EVBUFFER_LENGTH(req->output_buffer)); -+ } -+ } -+ -+ /* Potentially add headers for unidentified content. */ -+ if (EVBUFFER_LENGTH(req->output_buffer)) { -+ if (evhttp_find_header(req->output_headers, -+ "Content-Type") == NULL) { -+ evhttp_add_header(req->output_headers, -+ "Content-Type", "text/html; charset=ISO-8859-1"); -+ } -+ } -+ -+ /* if the request asked for a close, we send a close, too */ -+ if (evhttp_is_connection_close(req->flags, req->input_headers)) { -+ evhttp_remove_header(req->output_headers, "Connection"); -+ if (!(req->flags & EVHTTP_PROXY_REQUEST)) -+ evhttp_add_header(req->output_headers, "Connection", "close"); -+ evhttp_remove_header(req->output_headers, "Proxy-Connection"); -+ } -+} -+ -+void -+evhttp_make_header(struct evhttp_connection *evcon, struct evhttp_request *req) -+{ -+ char line[1024]; -+ struct evkeyval *header; -+ -+ /* -+ * Depending if this is a HTTP request or response, we might need to -+ * add some new headers or remove existing headers. -+ */ -+ if (req->kind == EVHTTP_REQUEST) { -+ evhttp_make_header_request(evcon, req); -+ } else { -+ evhttp_make_header_response(evcon, req); -+ } -+ -+ TAILQ_FOREACH(header, req->output_headers, next) { -+ evutil_snprintf(line, sizeof(line), "%s: %s\r\n", -+ header->key, header->value); -+ evbuffer_add(evcon->output_buffer, line, strlen(line)); -+ } -+ evbuffer_add(evcon->output_buffer, "\r\n", 2); -+ -+ if (EVBUFFER_LENGTH(req->output_buffer) > 0) { -+ /* -+ * For a request, we add the POST data, for a reply, this -+ * is the regular data. -+ */ -+ evbuffer_add_buffer(evcon->output_buffer, req->output_buffer); -+ } -+} -+ -+/* Separated host, port and file from URI */ -+ -+int -+evhttp_hostportfile(char *url, char **phost, u_short *pport, char **pfile) -+{ -+ /* XXX not threadsafe. */ -+ static char host[1024]; -+ static char file[1024]; -+ char *p; -+ const char *p2; -+ int len; -+ u_short port; -+ -+ len = strlen(HTTP_PREFIX); -+ if (strncasecmp(url, HTTP_PREFIX, len)) -+ return (-1); -+ -+ url += len; -+ -+ /* We might overrun */ -+ if (strlcpy(host, url, sizeof (host)) >= sizeof(host)) -+ return (-1); -+ -+ p = strchr(host, '/'); -+ if (p != NULL) { -+ *p = '\0'; -+ p2 = p + 1; -+ } else -+ p2 = NULL; -+ -+ if (pfile != NULL) { -+ /* Generate request file */ -+ if (p2 == NULL) -+ p2 = ""; -+ evutil_snprintf(file, sizeof(file), "/%s", p2); -+ } -+ -+ p = strchr(host, ':'); -+ if (p != NULL) { -+ *p = '\0'; -+ port = atoi(p + 1); -+ -+ if (port == 0) -+ return (-1); -+ } else -+ port = HTTP_DEFAULTPORT; -+ -+ if (phost != NULL) -+ *phost = host; -+ if (pport != NULL) -+ *pport = port; -+ if (pfile != NULL) -+ *pfile = file; -+ -+ return (0); -+} -+ -+static int -+evhttp_connection_incoming_fail(struct evhttp_request *req, -+ enum evhttp_connection_error error) -+{ -+ switch (error) { -+ case EVCON_HTTP_TIMEOUT: -+ case EVCON_HTTP_EOF: -+ /* -+ * these are cases in which we probably should just -+ * close the connection and not send a reply. this -+ * case may happen when a browser keeps a persistent -+ * connection open and we timeout on the read. -+ */ -+ return (-1); -+ case EVCON_HTTP_INVALID_HEADER: -+ default: /* xxx: probably should just error on default */ -+ /* the callback looks at the uri to determine errors */ -+ if (req->uri) { -+ free(req->uri); -+ req->uri = NULL; -+ } -+ -+ /* -+ * the callback needs to send a reply, once the reply has -+ * been send, the connection should get freed. -+ */ -+ (*req->cb)(req, req->cb_arg); -+ } -+ -+ return (0); -+} -+ -+void -+evhttp_connection_fail(struct evhttp_connection *evcon, -+ enum evhttp_connection_error error) -+{ -+ struct evhttp_request* req = TAILQ_FIRST(&evcon->requests); -+ void (*cb)(struct evhttp_request *, void *); -+ void *cb_arg; -+ assert(req != NULL); -+ -+ if (evcon->flags & EVHTTP_CON_INCOMING) { -+ /* -+ * for incoming requests, there are two different -+ * failure cases. it's either a network level error -+ * or an http layer error. for problems on the network -+ * layer like timeouts we just drop the connections. -+ * For HTTP problems, we might have to send back a -+ * reply before the connection can be freed. -+ */ -+ if (evhttp_connection_incoming_fail(req, error) == -1) -+ evhttp_connection_free(evcon); -+ return; -+ } -+ -+ /* save the callback for later; the cb might free our object */ -+ cb = req->cb; -+ cb_arg = req->cb_arg; -+ -+ TAILQ_REMOVE(&evcon->requests, req, next); -+ evhttp_request_free(req); -+ -+ /* xxx: maybe we should fail all requests??? */ -+ -+ /* reset the connection */ -+ evhttp_connection_reset(evcon); -+ -+ /* We are trying the next request that was queued on us */ -+ if (TAILQ_FIRST(&evcon->requests) != NULL) -+ evhttp_connection_connect(evcon); -+ -+ /* inform the user */ -+ if (cb != NULL) -+ (*cb)(NULL, cb_arg); -+} -+ -+void -+evhttp_write(int fd, short what, void *arg) -+{ -+ struct evhttp_connection *evcon = arg; -+ int n; -+ -+ if (what == EV_TIMEOUT) { -+ evhttp_connection_fail(evcon, EVCON_HTTP_TIMEOUT); -+ return; -+ } -+ -+ n = evbuffer_write(evcon->output_buffer, fd); -+ if (n == -1) { -+ event_debug(("%s: evbuffer_write", __func__)); -+ evhttp_connection_fail(evcon, EVCON_HTTP_EOF); -+ return; -+ } -+ -+ if (n == 0) { -+ event_debug(("%s: write nothing", __func__)); -+ evhttp_connection_fail(evcon, EVCON_HTTP_EOF); -+ return; -+ } -+ -+ if (EVBUFFER_LENGTH(evcon->output_buffer) != 0) { -+ evhttp_add_event(&evcon->ev, -+ evcon->timeout, HTTP_WRITE_TIMEOUT); -+ return; -+ } -+ -+ /* Activate our call back */ -+ if (evcon->cb != NULL) -+ (*evcon->cb)(evcon, evcon->cb_arg); -+} -+ -+/** -+ * Advance the connection state. -+ * - If this is an outgoing connection, we've just processed the response; -+ * idle or close the connection. -+ * - If this is an incoming connection, we've just processed the request; -+ * respond. -+ */ -+static void -+evhttp_connection_done(struct evhttp_connection *evcon) -+{ -+ struct evhttp_request *req = TAILQ_FIRST(&evcon->requests); -+ int con_outgoing = evcon->flags & EVHTTP_CON_OUTGOING; -+ -+ if (con_outgoing) { -+ /* idle or close the connection */ -+ int need_close; -+ TAILQ_REMOVE(&evcon->requests, req, next); -+ req->evcon = NULL; -+ -+ evcon->state = EVCON_IDLE; -+ -+ need_close = -+ evhttp_is_connection_close(req->flags, req->input_headers)|| -+ evhttp_is_connection_close(req->flags, req->output_headers); -+ -+ /* check if we got asked to close the connection */ -+ if (need_close) -+ evhttp_connection_reset(evcon); -+ -+ if (TAILQ_FIRST(&evcon->requests) != NULL) { -+ /* -+ * We have more requests; reset the connection -+ * and deal with the next request. -+ */ -+ if (!evhttp_connected(evcon)) -+ evhttp_connection_connect(evcon); -+ else -+ evhttp_request_dispatch(evcon); -+ } else if (!need_close) { -+ /* -+ * The connection is going to be persistent, but we -+ * need to detect if the other side closes it. -+ */ -+ evhttp_connection_start_detectclose(evcon); -+ } -+ } else { -+ /* -+ * incoming connection - we need to leave the request on the -+ * connection so that we can reply to it. -+ */ -+ evcon->state = EVCON_WRITING; -+ } -+ -+ /* notify the user of the request */ -+ (*req->cb)(req, req->cb_arg); -+ -+ /* if this was an outgoing request, we own and it's done. so free it */ -+ if (con_outgoing) { -+ evhttp_request_free(req); -+ } -+} -+ -+/* -+ * Handles reading from a chunked request. -+ * return ALL_DATA_READ: -+ * all data has been read -+ * return MORE_DATA_EXPECTED: -+ * more data is expected -+ * return DATA_CORRUPTED: -+ * data is corrupted -+ * return REQUEST_CANCLED: -+ * request was canceled by the user calling evhttp_cancel_request -+ */ -+ -+static enum message_read_status -+evhttp_handle_chunked_read(struct evhttp_request *req, struct evbuffer *buf) -+{ -+ int len; -+ -+ while ((len = EVBUFFER_LENGTH(buf)) > 0) { -+ if (req->ntoread < 0) { -+ /* Read chunk size */ -+ ev_int64_t ntoread; -+ char *p = evbuffer_readline(buf); -+ char *endp; -+ int error; -+ if (p == NULL) -+ break; -+ /* the last chunk is on a new line? */ -+ if (strlen(p) == 0) { -+ free(p); -+ continue; -+ } -+ ntoread = evutil_strtoll(p, &endp, 16); -+ error = (*p == '\0' || -+ (*endp != '\0' && *endp != ' ') || -+ ntoread < 0); -+ free(p); -+ if (error) { -+ /* could not get chunk size */ -+ return (DATA_CORRUPTED); -+ } -+ req->ntoread = ntoread; -+ if (req->ntoread == 0) { -+ /* Last chunk */ -+ return (ALL_DATA_READ); -+ } -+ continue; -+ } -+ -+ /* don't have enough to complete a chunk; wait for more */ -+ if (len < req->ntoread) -+ return (MORE_DATA_EXPECTED); -+ -+ /* Completed chunk */ -+ evbuffer_add(req->input_buffer, -+ EVBUFFER_DATA(buf), req->ntoread); -+ evbuffer_drain(buf, req->ntoread); -+ req->ntoread = -1; -+ if (req->chunk_cb != NULL) { -+ (*req->chunk_cb)(req, req->cb_arg); -+ evbuffer_drain(req->input_buffer, -+ EVBUFFER_LENGTH(req->input_buffer)); -+ } -+ } -+ -+ return (MORE_DATA_EXPECTED); -+} -+ -+static void -+evhttp_read_trailer(struct evhttp_connection *evcon, struct evhttp_request *req) -+{ -+ struct evbuffer *buf = evcon->input_buffer; -+ -+ switch (evhttp_parse_headers(req, buf)) { -+ case DATA_CORRUPTED: -+ evhttp_connection_fail(evcon, EVCON_HTTP_INVALID_HEADER); -+ break; -+ case ALL_DATA_READ: -+ event_del(&evcon->ev); -+ evhttp_connection_done(evcon); -+ break; -+ case MORE_DATA_EXPECTED: -+ default: -+ evhttp_add_event(&evcon->ev, evcon->timeout, -+ HTTP_READ_TIMEOUT); -+ break; -+ } -+} -+ -+static void -+evhttp_read_body(struct evhttp_connection *evcon, struct evhttp_request *req) -+{ -+ struct evbuffer *buf = evcon->input_buffer; -+ -+ if (req->chunked) { -+ switch (evhttp_handle_chunked_read(req, buf)) { -+ case ALL_DATA_READ: -+ /* finished last chunk */ -+ evcon->state = EVCON_READING_TRAILER; -+ evhttp_read_trailer(evcon, req); -+ return; -+ case DATA_CORRUPTED: -+ /* corrupted data */ -+ evhttp_connection_fail(evcon, -+ EVCON_HTTP_INVALID_HEADER); -+ return; -+ case REQUEST_CANCELED: -+ /* request canceled */ -+ evhttp_request_free(req); -+ return; -+ case MORE_DATA_EXPECTED: -+ default: -+ break; -+ } -+ } else if (req->ntoread < 0) { -+ /* Read until connection close. */ -+ evbuffer_add_buffer(req->input_buffer, buf); -+ } else if (EVBUFFER_LENGTH(buf) >= req->ntoread) { -+ /* Completed content length */ -+ evbuffer_add(req->input_buffer, EVBUFFER_DATA(buf), -+ req->ntoread); -+ evbuffer_drain(buf, req->ntoread); -+ req->ntoread = 0; -+ evhttp_connection_done(evcon); -+ return; -+ } -+ /* Read more! */ -+ event_set(&evcon->ev, evcon->fd, EV_READ, evhttp_read, evcon); -+ EVHTTP_BASE_SET(evcon, &evcon->ev); -+ evhttp_add_event(&evcon->ev, evcon->timeout, HTTP_READ_TIMEOUT); -+} -+ -+/* -+ * Reads data into a buffer structure until no more data -+ * can be read on the file descriptor or we have read all -+ * the data that we wanted to read. -+ * Execute callback when done. -+ */ -+ -+void -+evhttp_read(int fd, short what, void *arg) -+{ -+ struct evhttp_connection *evcon = arg; -+ struct evhttp_request *req = TAILQ_FIRST(&evcon->requests); -+ struct evbuffer *buf = evcon->input_buffer; -+ int n, len; -+ -+ if (what == EV_TIMEOUT) { -+ evhttp_connection_fail(evcon, EVCON_HTTP_TIMEOUT); -+ return; -+ } -+ n = evbuffer_read(buf, fd, -1); -+ len = EVBUFFER_LENGTH(buf); -+ event_debug(("%s: got %d on %d\n", __func__, n, fd)); -+ -+ if (n == -1) { -+ if (errno != EINTR && errno != EAGAIN) { -+ event_debug(("%s: evbuffer_read", __func__)); -+ evhttp_connection_fail(evcon, EVCON_HTTP_EOF); -+ } else { -+ evhttp_add_event(&evcon->ev, evcon->timeout, -+ HTTP_READ_TIMEOUT); -+ } -+ return; -+ } else if (n == 0) { -+ /* Connection closed */ -+ evhttp_connection_done(evcon); -+ return; -+ } -+ -+ switch (evcon->state) { -+ case EVCON_READING_FIRSTLINE: -+ evhttp_read_firstline(evcon, req); -+ break; -+ case EVCON_READING_HEADERS: -+ evhttp_read_header(evcon, req); -+ break; -+ case EVCON_READING_BODY: -+ evhttp_read_body(evcon, req); -+ break; -+ case EVCON_READING_TRAILER: -+ evhttp_read_trailer(evcon, req); -+ break; -+ case EVCON_DISCONNECTED: -+ case EVCON_CONNECTING: -+ case EVCON_IDLE: -+ case EVCON_WRITING: -+ default: -+ event_errx(1, "%s: illegal connection state %d", -+ __func__, evcon->state); -+ } -+} -+ -+static void -+evhttp_write_connectioncb(struct evhttp_connection *evcon, void *arg) -+{ -+ /* This is after writing the request to the server */ -+ struct evhttp_request *req = TAILQ_FIRST(&evcon->requests); -+ assert(req != NULL); -+ -+ assert(evcon->state == EVCON_WRITING); -+ -+ /* We are done writing our header and are now expecting the response */ -+ req->kind = EVHTTP_RESPONSE; -+ -+ evhttp_start_read(evcon); -+} -+ -+/* -+ * Clean up a connection object -+ */ -+ -+void -+evhttp_connection_free(struct evhttp_connection *evcon) -+{ -+ struct evhttp_request *req; -+ -+ /* notify interested parties that this connection is going down */ -+ if (evcon->fd != -1) { -+ if (evhttp_connected(evcon) && evcon->closecb != NULL) -+ (*evcon->closecb)(evcon, evcon->closecb_arg); -+ } -+ -+ /* remove all requests that might be queued on this connection */ -+ while ((req = TAILQ_FIRST(&evcon->requests)) != NULL) { -+ TAILQ_REMOVE(&evcon->requests, req, next); -+ evhttp_request_free(req); -+ } -+ -+ if (evcon->http_server != NULL) { -+ struct evhttp *http = evcon->http_server; -+ TAILQ_REMOVE(&http->connections, evcon, next); -+ } -+ -+ if (event_initialized(&evcon->close_ev)) -+ event_del(&evcon->close_ev); -+ -+ if (event_initialized(&evcon->ev)) -+ event_del(&evcon->ev); -+ -+ if (evcon->fd != -1) -+ EVUTIL_CLOSESOCKET(evcon->fd); -+ -+ if (evcon->bind_address != NULL) -+ free(evcon->bind_address); -+ -+ if (evcon->address != NULL) -+ free(evcon->address); -+ -+ if (evcon->input_buffer != NULL) -+ evbuffer_free(evcon->input_buffer); -+ -+ if (evcon->output_buffer != NULL) -+ evbuffer_free(evcon->output_buffer); -+ -+ free(evcon); -+} -+ -+void -+evhttp_connection_set_local_address(struct evhttp_connection *evcon, -+ const char *address) -+{ -+ assert(evcon->state == EVCON_DISCONNECTED); -+ if (evcon->bind_address) -+ free(evcon->bind_address); -+ if ((evcon->bind_address = strdup(address)) == NULL) -+ event_err(1, "%s: strdup", __func__); -+} -+ -+ -+static void -+evhttp_request_dispatch(struct evhttp_connection* evcon) -+{ -+ struct evhttp_request *req = TAILQ_FIRST(&evcon->requests); -+ -+ /* this should not usually happy but it's possible */ -+ if (req == NULL) -+ return; -+ -+ /* delete possible close detection events */ -+ evhttp_connection_stop_detectclose(evcon); -+ -+ /* we assume that the connection is connected already */ -+ assert(evcon->state == EVCON_IDLE); -+ -+ evcon->state = EVCON_WRITING; -+ -+ /* Create the header from the store arguments */ -+ evhttp_make_header(evcon, req); -+ -+ evhttp_write_buffer(evcon, evhttp_write_connectioncb, NULL); -+} -+ -+/* Reset our connection state */ -+void -+evhttp_connection_reset(struct evhttp_connection *evcon) -+{ -+ if (event_initialized(&evcon->ev)) -+ event_del(&evcon->ev); -+ -+ if (evcon->fd != -1) { -+ /* inform interested parties about connection close */ -+ if (evhttp_connected(evcon) && evcon->closecb != NULL) -+ (*evcon->closecb)(evcon, evcon->closecb_arg); -+ -+ EVUTIL_CLOSESOCKET(evcon->fd); -+ evcon->fd = -1; -+ } -+ evcon->state = EVCON_DISCONNECTED; -+} -+ -+static void -+evhttp_detect_close_cb(int fd, short what, void *arg) -+{ -+ struct evhttp_connection *evcon = arg; -+ evhttp_connection_reset(evcon); -+} -+ -+static void -+evhttp_connection_start_detectclose(struct evhttp_connection *evcon) -+{ -+ evcon->flags |= EVHTTP_CON_CLOSEDETECT; -+ -+ if (event_initialized(&evcon->close_ev)) -+ event_del(&evcon->close_ev); -+ event_set(&evcon->close_ev, evcon->fd, EV_READ, -+ evhttp_detect_close_cb, evcon); -+ EVHTTP_BASE_SET(evcon, &evcon->close_ev); -+ event_add(&evcon->close_ev, NULL); -+} -+ -+static void -+evhttp_connection_stop_detectclose(struct evhttp_connection *evcon) -+{ -+ evcon->flags &= ~EVHTTP_CON_CLOSEDETECT; -+ event_del(&evcon->close_ev); -+} -+ -+static void -+evhttp_connection_retry(int fd, short what, void *arg) -+{ -+ struct evhttp_connection *evcon = arg; -+ -+ evcon->state = EVCON_DISCONNECTED; -+ evhttp_connection_connect(evcon); -+} -+ -+/* -+ * Call back for asynchronous connection attempt. -+ */ -+ -+static void -+evhttp_connectioncb(int fd, short what, void *arg) -+{ -+ struct evhttp_connection *evcon = arg; -+ int error; -+ socklen_t errsz = sizeof(error); -+ -+ if (what == EV_TIMEOUT) { -+ event_debug(("%s: connection timeout for \"%s:%d\" on %d", -+ __func__, evcon->address, evcon->port, evcon->fd)); -+ goto cleanup; -+ } -+ -+ /* Check if the connection completed */ -+ if (getsockopt(evcon->fd, SOL_SOCKET, SO_ERROR, (void*)&error, -+ &errsz) == -1) { -+ event_debug(("%s: getsockopt for \"%s:%d\" on %d", -+ __func__, evcon->address, evcon->port, evcon->fd)); -+ goto cleanup; -+ } -+ -+ if (error) { -+ event_debug(("%s: connect failed for \"%s:%d\" on %d: %s", -+ __func__, evcon->address, evcon->port, evcon->fd, -+ strerror(error))); -+ goto cleanup; -+ } -+ -+ /* We are connected to the server now */ -+ event_debug(("%s: connected to \"%s:%d\" on %d\n", -+ __func__, evcon->address, evcon->port, evcon->fd)); -+ -+ /* Reset the retry count as we were successful in connecting */ -+ evcon->retry_cnt = 0; -+ evcon->state = EVCON_IDLE; -+ -+ /* try to start requests that have queued up on this connection */ -+ evhttp_request_dispatch(evcon); -+ return; -+ -+ cleanup: -+ if (evcon->retry_max < 0 || evcon->retry_cnt < evcon->retry_max) { -+ evtimer_set(&evcon->ev, evhttp_connection_retry, evcon); -+ EVHTTP_BASE_SET(evcon, &evcon->ev); -+ evhttp_add_event(&evcon->ev, MIN(3600, 2 << evcon->retry_cnt), -+ HTTP_CONNECT_TIMEOUT); -+ evcon->retry_cnt++; -+ return; -+ } -+ evhttp_connection_reset(evcon); -+ -+ /* for now, we just signal all requests by executing their callbacks */ -+ while (TAILQ_FIRST(&evcon->requests) != NULL) { -+ struct evhttp_request *request = TAILQ_FIRST(&evcon->requests); -+ TAILQ_REMOVE(&evcon->requests, request, next); -+ request->evcon = NULL; -+ -+ /* we might want to set an error here */ -+ request->cb(request, request->cb_arg); -+ evhttp_request_free(request); -+ } -+} -+ -+/* -+ * Check if we got a valid response code. -+ */ -+ -+static int -+evhttp_valid_response_code(int code) -+{ -+ if (code == 0) -+ return (0); -+ -+ return (1); -+} -+ -+/* Parses the status line of a web server */ -+ -+static int -+evhttp_parse_response_line(struct evhttp_request *req, char *line) -+{ -+ char *protocol; -+ char *number; -+ char *readable; -+ -+ protocol = strsep(&line, " "); -+ if (line == NULL) -+ return (-1); -+ number = strsep(&line, " "); -+ if (line == NULL) -+ return (-1); -+ readable = line; -+ -+ if (strcmp(protocol, "HTTP/1.0") == 0) { -+ req->major = 1; -+ req->minor = 0; -+ } else if (strcmp(protocol, "HTTP/1.1") == 0) { -+ req->major = 1; -+ req->minor = 1; -+ } else { -+ event_debug(("%s: bad protocol \"%s\"", -+ __func__, protocol)); -+ return (-1); -+ } -+ -+ req->response_code = atoi(number); -+ if (!evhttp_valid_response_code(req->response_code)) { -+ event_debug(("%s: bad response code \"%s\"", -+ __func__, number)); -+ return (-1); -+ } -+ -+ if ((req->response_code_line = strdup(readable)) == NULL) -+ event_err(1, "%s: strdup", __func__); -+ -+ return (0); -+} -+ -+/* Parse the first line of a HTTP request */ -+ -+static int -+evhttp_parse_request_line(struct evhttp_request *req, char *line) -+{ -+ char *method; -+ char *uri; -+ char *version; -+ -+ /* Parse the request line */ -+ method = strsep(&line, " "); -+ if (line == NULL) -+ return (-1); -+ uri = strsep(&line, " "); -+ if (line == NULL) -+ return (-1); -+ version = strsep(&line, " "); -+ if (line != NULL) -+ return (-1); -+ -+ /* First line */ -+ if (strcmp(method, "GET") == 0) { -+ req->type = EVHTTP_REQ_GET; -+ } else if (strcmp(method, "POST") == 0) { -+ req->type = EVHTTP_REQ_POST; -+ } else if (strcmp(method, "HEAD") == 0) { -+ req->type = EVHTTP_REQ_HEAD; -+ } else { -+ event_debug(("%s: bad method %s on request %p from %s", -+ __func__, method, req, req->remote_host)); -+ return (-1); -+ } -+ -+ if (strcmp(version, "HTTP/1.0") == 0) { -+ req->major = 1; -+ req->minor = 0; -+ } else if (strcmp(version, "HTTP/1.1") == 0) { -+ req->major = 1; -+ req->minor = 1; -+ } else { -+ event_debug(("%s: bad version %s on request %p from %s", -+ __func__, version, req, req->remote_host)); -+ return (-1); -+ } -+ -+ if ((req->uri = strdup(uri)) == NULL) { -+ event_debug(("%s: evhttp_decode_uri", __func__)); -+ return (-1); -+ } -+ -+ /* determine if it's a proxy request */ -+ if (strlen(req->uri) > 0 && req->uri[0] != '/') -+ req->flags |= EVHTTP_PROXY_REQUEST; -+ -+ return (0); -+} -+ -+const char * -+evhttp_find_header(const struct evkeyvalq *headers, const char *key) -+{ -+ struct evkeyval *header; -+ -+ TAILQ_FOREACH(header, headers, next) { -+ if (strcasecmp(header->key, key) == 0) -+ return (header->value); -+ } -+ -+ return (NULL); -+} -+ -+void -+evhttp_clear_headers(struct evkeyvalq *headers) -+{ -+ struct evkeyval *header; -+ -+ for (header = TAILQ_FIRST(headers); -+ header != NULL; -+ header = TAILQ_FIRST(headers)) { -+ TAILQ_REMOVE(headers, header, next); -+ free(header->key); -+ free(header->value); -+ free(header); -+ } -+} -+ -+/* -+ * Returns 0, if the header was successfully removed. -+ * Returns -1, if the header could not be found. -+ */ -+ -+int -+evhttp_remove_header(struct evkeyvalq *headers, const char *key) -+{ -+ struct evkeyval *header; -+ -+ TAILQ_FOREACH(header, headers, next) { -+ if (strcasecmp(header->key, key) == 0) -+ break; -+ } -+ -+ if (header == NULL) -+ return (-1); -+ -+ /* Free and remove the header that we found */ -+ TAILQ_REMOVE(headers, header, next); -+ free(header->key); -+ free(header->value); -+ free(header); -+ -+ return (0); -+} -+ -+int -+evhttp_add_header(struct evkeyvalq *headers, -+ const char *key, const char *value) -+{ -+ struct evkeyval *header = NULL; -+ -+ event_debug(("%s: key: %s val: %s\n", __func__, key, value)); -+ -+ if (strchr(value, '\r') != NULL || strchr(value, '\n') != NULL || -+ strchr(key, '\r') != NULL || strchr(key, '\n') != NULL) { -+ /* drop illegal headers */ -+ event_debug(("%s: dropping illegal header\n", __func__)); -+ return (-1); -+ } -+ -+ header = calloc(1, sizeof(struct evkeyval)); -+ if (header == NULL) { -+ event_warn("%s: calloc", __func__); -+ return (-1); -+ } -+ if ((header->key = strdup(key)) == NULL) { -+ free(header); -+ event_warn("%s: strdup", __func__); -+ return (-1); -+ } -+ if ((header->value = strdup(value)) == NULL) { -+ free(header->key); -+ free(header); -+ event_warn("%s: strdup", __func__); -+ return (-1); -+ } -+ -+ TAILQ_INSERT_TAIL(headers, header, next); -+ -+ return (0); -+} -+ -+/* -+ * Parses header lines from a request or a response into the specified -+ * request object given an event buffer. -+ * -+ * Returns -+ * DATA_CORRUPTED on error -+ * MORE_DATA_EXPECTED when we need to read more headers -+ * ALL_DATA_READ when all headers have been read. -+ */ -+ -+enum message_read_status -+evhttp_parse_firstline(struct evhttp_request *req, struct evbuffer *buffer) -+{ -+ char *line; -+ enum message_read_status status = ALL_DATA_READ; -+ -+ line = evbuffer_readline(buffer); -+ if (line == NULL) -+ return (MORE_DATA_EXPECTED); -+ -+ switch (req->kind) { -+ case EVHTTP_REQUEST: -+ if (evhttp_parse_request_line(req, line) == -1) -+ status = DATA_CORRUPTED; -+ break; -+ case EVHTTP_RESPONSE: -+ if (evhttp_parse_response_line(req, line) == -1) -+ status = DATA_CORRUPTED; -+ break; -+ default: -+ status = DATA_CORRUPTED; -+ } -+ -+ free(line); -+ return (status); -+} -+ -+static int -+evhttp_append_to_last_header(struct evkeyvalq *headers, const char *line) -+{ -+ struct evkeyval *header = TAILQ_LAST(headers, evkeyvalq); -+ char *newval; -+ size_t old_len, line_len; -+ -+ if (header == NULL) -+ return (-1); -+ -+ old_len = strlen(header->value); -+ line_len = strlen(line); -+ -+ newval = realloc(header->value, old_len + line_len + 1); -+ if (newval == NULL) -+ return (-1); -+ -+ memcpy(newval + old_len, line, line_len + 1); -+ header->value = newval; -+ -+ return (0); -+} -+ -+enum message_read_status -+evhttp_parse_headers(struct evhttp_request *req, struct evbuffer* buffer) -+{ -+ char *line; -+ enum message_read_status status = MORE_DATA_EXPECTED; -+ -+ struct evkeyvalq* headers = req->input_headers; -+ while ((line = evbuffer_readline(buffer)) -+ != NULL) { -+ char *skey, *svalue; -+ -+ if (*line == '\0') { /* Last header - Done */ -+ status = ALL_DATA_READ; -+ free(line); -+ break; -+ } -+ -+ /* Check if this is a continuation line */ -+ if (*line == ' ' || *line == '\t') { -+ if (evhttp_append_to_last_header(headers, line) == -1) -+ goto error; -+ continue; -+ } -+ -+ /* Processing of header lines */ -+ svalue = line; -+ skey = strsep(&svalue, ":"); -+ if (svalue == NULL) -+ goto error; -+ -+ svalue += strspn(svalue, " "); -+ -+ if (evhttp_add_header(headers, skey, svalue) == -1) -+ goto error; -+ -+ free(line); -+ } -+ -+ return (status); -+ -+ error: -+ free(line); -+ return (DATA_CORRUPTED); -+} -+ -+static int -+evhttp_get_body_length(struct evhttp_request *req) -+{ -+ struct evkeyvalq *headers = req->input_headers; -+ const char *content_length; -+ const char *connection; -+ -+ content_length = evhttp_find_header(headers, "Content-Length"); -+ connection = evhttp_find_header(headers, "Connection"); -+ -+ if (content_length == NULL && connection == NULL) -+ req->ntoread = -1; -+ else if (content_length == NULL && -+ strcasecmp(connection, "Close") != 0) { -+ /* Bad combination, we don't know when it will end */ -+ event_warnx("%s: we got no content length, but the " -+ "server wants to keep the connection open: %s.", -+ __func__, connection); -+ return (-1); -+ } else if (content_length == NULL) { -+ req->ntoread = -1; -+ } else { -+ char *endp; -+ ev_int64_t ntoread = evutil_strtoll(content_length, &endp, 10); -+ if (*content_length == '\0' || *endp != '\0' || ntoread < 0) { -+ event_debug(("%s: illegal content length: %s", -+ __func__, content_length)); -+ return (-1); -+ } -+ req->ntoread = ntoread; -+ } -+ -+ event_debug(("%s: bytes to read: %lld (in buffer %ld)\n", -+ __func__, req->ntoread, -+ EVBUFFER_LENGTH(req->evcon->input_buffer))); -+ -+ return (0); -+} -+ -+static void -+evhttp_get_body(struct evhttp_connection *evcon, struct evhttp_request *req) -+{ -+ const char *xfer_enc; -+ -+ /* If this is a request without a body, then we are done */ -+ if (req->kind == EVHTTP_REQUEST && req->type != EVHTTP_REQ_POST) { -+ evhttp_connection_done(evcon); -+ return; -+ } -+ evcon->state = EVCON_READING_BODY; -+ xfer_enc = evhttp_find_header(req->input_headers, "Transfer-Encoding"); -+ if (xfer_enc != NULL && strcasecmp(xfer_enc, "chunked") == 0) { -+ req->chunked = 1; -+ req->ntoread = -1; -+ } else { -+ if (evhttp_get_body_length(req) == -1) { -+ evhttp_connection_fail(evcon, -+ EVCON_HTTP_INVALID_HEADER); -+ return; -+ } -+ } -+ evhttp_read_body(evcon, req); -+} -+ -+static void -+evhttp_read_firstline(struct evhttp_connection *evcon, -+ struct evhttp_request *req) -+{ -+ enum message_read_status res; -+ -+ res = evhttp_parse_firstline(req, evcon->input_buffer); -+ if (res == DATA_CORRUPTED) { -+ /* Error while reading, terminate */ -+ event_debug(("%s: bad header lines on %d\n", -+ __func__, evcon->fd)); -+ evhttp_connection_fail(evcon, EVCON_HTTP_INVALID_HEADER); -+ return; -+ } else if (res == MORE_DATA_EXPECTED) { -+ /* Need more header lines */ -+ evhttp_add_event(&evcon->ev, -+ evcon->timeout, HTTP_READ_TIMEOUT); -+ return; -+ } -+ -+ evcon->state = EVCON_READING_HEADERS; -+ evhttp_read_header(evcon, req); -+} -+ -+static void -+evhttp_read_header(struct evhttp_connection *evcon, struct evhttp_request *req) -+{ -+ enum message_read_status res; -+ int fd = evcon->fd; -+ -+ res = evhttp_parse_headers(req, evcon->input_buffer); -+ if (res == DATA_CORRUPTED) { -+ /* Error while reading, terminate */ -+ event_debug(("%s: bad header lines on %d\n", __func__, fd)); -+ evhttp_connection_fail(evcon, EVCON_HTTP_INVALID_HEADER); -+ return; -+ } else if (res == MORE_DATA_EXPECTED) { -+ /* Need more header lines */ -+ evhttp_add_event(&evcon->ev, -+ evcon->timeout, HTTP_READ_TIMEOUT); -+ return; -+ } -+ -+ /* Done reading headers, do the real work */ -+ switch (req->kind) { -+ case EVHTTP_REQUEST: -+ event_debug(("%s: checking for post data on %d\n", -+ __func__, fd)); -+ evhttp_get_body(evcon, req); -+ break; -+ -+ case EVHTTP_RESPONSE: -+ if (req->response_code == HTTP_NOCONTENT || -+ req->response_code == HTTP_NOTMODIFIED || -+ (req->response_code >= 100 && req->response_code < 200)) { -+ event_debug(("%s: skipping body for code %d\n", -+ __func__, req->response_code)); -+ evhttp_connection_done(evcon); -+ } else { -+ event_debug(("%s: start of read body for %s on %d\n", -+ __func__, req->remote_host, fd)); -+ evhttp_get_body(evcon, req); -+ } -+ break; -+ -+ default: -+ event_warnx("%s: bad header on %d", __func__, fd); -+ evhttp_connection_fail(evcon, EVCON_HTTP_INVALID_HEADER); -+ break; -+ } -+} -+ -+/* -+ * Creates a TCP connection to the specified port and executes a callback -+ * when finished. Failure or sucess is indicate by the passed connection -+ * object. -+ * -+ * Although this interface accepts a hostname, it is intended to take -+ * only numeric hostnames so that non-blocking DNS resolution can -+ * happen elsewhere. -+ */ -+ -+struct evhttp_connection * -+evhttp_connection_new(const char *address, unsigned short port) -+{ -+ struct evhttp_connection *evcon = NULL; -+ -+ event_debug(("Attempting connection to %s:%d\n", address, port)); -+ -+ if ((evcon = calloc(1, sizeof(struct evhttp_connection))) == NULL) { -+ event_warn("%s: calloc failed", __func__); -+ goto error; -+ } -+ -+ evcon->fd = -1; -+ evcon->port = port; -+ -+ evcon->timeout = -1; -+ evcon->retry_cnt = evcon->retry_max = 0; -+ -+ if ((evcon->address = strdup(address)) == NULL) { -+ event_warn("%s: strdup failed", __func__); -+ goto error; -+ } -+ -+ if ((evcon->input_buffer = evbuffer_new()) == NULL) { -+ event_warn("%s: evbuffer_new failed", __func__); -+ goto error; -+ } -+ -+ if ((evcon->output_buffer = evbuffer_new()) == NULL) { -+ event_warn("%s: evbuffer_new failed", __func__); -+ goto error; -+ } -+ -+ evcon->state = EVCON_DISCONNECTED; -+ TAILQ_INIT(&evcon->requests); -+ -+ return (evcon); -+ -+ error: -+ if (evcon != NULL) -+ evhttp_connection_free(evcon); -+ return (NULL); -+} -+ -+void evhttp_connection_set_base(struct evhttp_connection *evcon, -+ struct event_base *base) -+{ -+ assert(evcon->base == NULL); -+ assert(evcon->state == EVCON_DISCONNECTED); -+ evcon->base = base; -+} -+ -+void -+evhttp_connection_set_timeout(struct evhttp_connection *evcon, -+ int timeout_in_secs) -+{ -+ evcon->timeout = timeout_in_secs; -+} -+ -+void -+evhttp_connection_set_retries(struct evhttp_connection *evcon, -+ int retry_max) -+{ -+ evcon->retry_max = retry_max; -+} -+ -+void -+evhttp_connection_set_closecb(struct evhttp_connection *evcon, -+ void (*cb)(struct evhttp_connection *, void *), void *cbarg) -+{ -+ evcon->closecb = cb; -+ evcon->closecb_arg = cbarg; -+} -+ -+void -+evhttp_connection_get_peer(struct evhttp_connection *evcon, -+ char **address, u_short *port) -+{ -+ *address = evcon->address; -+ *port = evcon->port; -+} -+ -+int -+evhttp_connection_connect(struct evhttp_connection *evcon) -+{ -+ if (evcon->state == EVCON_CONNECTING) -+ return (0); -+ -+ evhttp_connection_reset(evcon); -+ -+ assert(!(evcon->flags & EVHTTP_CON_INCOMING)); -+ evcon->flags |= EVHTTP_CON_OUTGOING; -+ -+ evcon->fd = bind_socket(evcon->bind_address, 0 /*port*/, 0 /*reuse*/); -+ if (evcon->fd == -1) { -+ event_debug(("%s: failed to bind to \"%s\"", -+ __func__, evcon->bind_address)); -+ return (-1); -+ } -+ -+ if (socket_connect(evcon->fd, evcon->address, evcon->port) == -1) { -+ EVUTIL_CLOSESOCKET(evcon->fd); evcon->fd = -1; -+ return (-1); -+ } -+ -+ /* Set up a callback for successful connection setup */ -+ event_set(&evcon->ev, evcon->fd, EV_WRITE, evhttp_connectioncb, evcon); -+ EVHTTP_BASE_SET(evcon, &evcon->ev); -+ evhttp_add_event(&evcon->ev, evcon->timeout, HTTP_CONNECT_TIMEOUT); -+ -+ evcon->state = EVCON_CONNECTING; -+ -+ return (0); -+} -+ -+/* -+ * Starts an HTTP request on the provided evhttp_connection object. -+ * If the connection object is not connected to the web server already, -+ * this will start the connection. -+ */ -+ -+int -+evhttp_make_request(struct evhttp_connection *evcon, -+ struct evhttp_request *req, -+ enum evhttp_cmd_type type, const char *uri) -+{ -+ /* We are making a request */ -+ req->kind = EVHTTP_REQUEST; -+ req->type = type; -+ if (req->uri != NULL) -+ free(req->uri); -+ if ((req->uri = strdup(uri)) == NULL) -+ event_err(1, "%s: strdup", __func__); -+ -+ /* Set the protocol version if it is not supplied */ -+ if (!req->major && !req->minor) { -+ req->major = 1; -+ req->minor = 1; -+ } -+ -+ assert(req->evcon == NULL); -+ req->evcon = evcon; -+ assert(!(req->flags & EVHTTP_REQ_OWN_CONNECTION)); -+ -+ TAILQ_INSERT_TAIL(&evcon->requests, req, next); -+ -+ /* If the connection object is not connected; make it so */ -+ if (!evhttp_connected(evcon)) -+ return (evhttp_connection_connect(evcon)); -+ -+ /* -+ * If it's connected already and we are the first in the queue, -+ * then we can dispatch this request immediately. Otherwise, it -+ * will be dispatched once the pending requests are completed. -+ */ -+ if (TAILQ_FIRST(&evcon->requests) == req) -+ evhttp_request_dispatch(evcon); -+ -+ return (0); -+} -+ -+/* -+ * Reads data from file descriptor into request structure -+ * Request structure needs to be set up correctly. -+ */ -+ -+void -+evhttp_start_read(struct evhttp_connection *evcon) -+{ -+ /* Set up an event to read the headers */ -+ if (event_initialized(&evcon->ev)) -+ event_del(&evcon->ev); -+ event_set(&evcon->ev, evcon->fd, EV_READ, evhttp_read, evcon); -+ EVHTTP_BASE_SET(evcon, &evcon->ev); -+ -+ evhttp_add_event(&evcon->ev, evcon->timeout, HTTP_READ_TIMEOUT); -+ evcon->state = EVCON_READING_FIRSTLINE; -+} -+ -+static void -+evhttp_send_done(struct evhttp_connection *evcon, void *arg) -+{ -+ int need_close; -+ struct evhttp_request *req = TAILQ_FIRST(&evcon->requests); -+ TAILQ_REMOVE(&evcon->requests, req, next); -+ -+ /* delete possible close detection events */ -+ evhttp_connection_stop_detectclose(evcon); -+ -+ need_close = -+ (req->minor == 0 && -+ !evhttp_is_connection_keepalive(req->input_headers))|| -+ evhttp_is_connection_close(req->flags, req->input_headers) || -+ evhttp_is_connection_close(req->flags, req->output_headers); -+ -+ assert(req->flags & EVHTTP_REQ_OWN_CONNECTION); -+ evhttp_request_free(req); -+ -+ if (need_close) { -+ evhttp_connection_free(evcon); -+ return; -+ } -+ -+ /* we have a persistent connection; try to accept another request. */ -+ if (evhttp_associate_new_request_with_connection(evcon) == -1) -+ evhttp_connection_free(evcon); -+} -+ -+/* -+ * Returns an error page. -+ */ -+ -+void -+evhttp_send_error(struct evhttp_request *req, int error, const char *reason) -+{ -+#define ERR_FORMAT "\n" \ -+ "%d %s\n" \ -+ "\n" \ -+ "

Method Not Implemented

\n" \ -+ "Invalid method in request

\n" \ -+ "\n" -+ -+ struct evbuffer *buf = evbuffer_new(); -+ -+ /* close the connection on error */ -+ evhttp_add_header(req->output_headers, "Connection", "close"); -+ -+ evhttp_response_code(req, error, reason); -+ -+ evbuffer_add_printf(buf, ERR_FORMAT, error, reason); -+ -+ evhttp_send_page(req, buf); -+ -+ evbuffer_free(buf); -+#undef ERR_FORMAT -+} -+ -+/* Requires that headers and response code are already set up */ -+ -+static inline void -+evhttp_send(struct evhttp_request *req, struct evbuffer *databuf) -+{ -+ struct evhttp_connection *evcon = req->evcon; -+ -+ assert(TAILQ_FIRST(&evcon->requests) == req); -+ -+ /* xxx: not sure if we really should expose the data buffer this way */ -+ if (databuf != NULL) -+ evbuffer_add_buffer(req->output_buffer, databuf); -+ -+ /* Adds headers to the response */ -+ evhttp_make_header(evcon, req); -+ -+ evhttp_write_buffer(evcon, evhttp_send_done, NULL); -+} -+ -+void -+evhttp_send_reply(struct evhttp_request *req, int code, const char *reason, -+ struct evbuffer *databuf) -+{ -+ /* set up to watch for client close */ -+ evhttp_connection_start_detectclose(req->evcon); -+ evhttp_response_code(req, code, reason); -+ -+ evhttp_send(req, databuf); -+} -+ -+void -+evhttp_send_reply_start(struct evhttp_request *req, int code, -+ const char *reason) -+{ -+ /* set up to watch for client close */ -+ evhttp_connection_start_detectclose(req->evcon); -+ evhttp_response_code(req, code, reason); -+ if (req->major == 1 && req->minor == 1) { -+ /* use chunked encoding for HTTP/1.1 */ -+ evhttp_add_header(req->output_headers, "Transfer-Encoding", -+ "chunked"); -+ req->chunked = 1; -+ } -+ evhttp_make_header(req->evcon, req); -+ evhttp_write_buffer(req->evcon, NULL, NULL); -+} -+ -+void -+evhttp_send_reply_chunk(struct evhttp_request *req, struct evbuffer *databuf) -+{ -+ if (req->chunked) { -+ evbuffer_add_printf(req->evcon->output_buffer, "%x\r\n", -+ (unsigned)EVBUFFER_LENGTH(databuf)); -+ } -+ evbuffer_add_buffer(req->evcon->output_buffer, databuf); -+ if (req->chunked) { -+ evbuffer_add(req->evcon->output_buffer, "\r\n", 2); -+ } -+ evhttp_write_buffer(req->evcon, NULL, NULL); -+} -+ -+void -+evhttp_send_reply_end(struct evhttp_request *req) -+{ -+ struct evhttp_connection *evcon = req->evcon; -+ -+ if (req->chunked) { -+ evbuffer_add(req->evcon->output_buffer, "0\r\n\r\n", 5); -+ evhttp_write_buffer(req->evcon, evhttp_send_done, NULL); -+ req->chunked = 0; -+ } else if (!event_pending(&evcon->ev, EV_WRITE|EV_TIMEOUT, NULL)) { -+ /* let the connection know that we are done with the request */ -+ evhttp_send_done(evcon, NULL); -+ } else { -+ /* make the callback execute after all data has been written */ -+ evcon->cb = evhttp_send_done; -+ evcon->cb_arg = NULL; -+ } -+} -+ -+void -+evhttp_response_code(struct evhttp_request *req, int code, const char *reason) -+{ -+ req->kind = EVHTTP_RESPONSE; -+ req->response_code = code; -+ if (req->response_code_line != NULL) -+ free(req->response_code_line); -+ req->response_code_line = strdup(reason); -+} -+ -+void -+evhttp_send_page(struct evhttp_request *req, struct evbuffer *databuf) -+{ -+ if (!req->major || !req->minor) { -+ req->major = 1; -+ req->minor = 1; -+ } -+ -+ if (req->kind != EVHTTP_RESPONSE) -+ evhttp_response_code(req, 200, "OK"); -+ -+ evhttp_clear_headers(req->output_headers); -+ evhttp_add_header(req->output_headers, "Content-Type", "text/html"); -+ evhttp_add_header(req->output_headers, "Connection", "close"); -+ -+ evhttp_send(req, databuf); -+} -+ -+static const char uri_chars[256] = { -+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -+ 0, 1, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, -+ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 0, 0, -+ /* 64 */ -+ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, -+ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, -+ 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, -+ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 0, -+ /* 128 */ -+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -+ /* 192 */ -+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -+}; -+ -+/* -+ * Helper functions to encode/decode a URI. -+ * The returned string must be freed by the caller. -+ */ -+char * -+evhttp_encode_uri(const char *uri) -+{ -+ struct evbuffer *buf = evbuffer_new(); -+ char *p; -+ -+ for (p = (char *)uri; *p != '\0'; p++) { -+ if (uri_chars[(u_char)(*p)]) { -+ evbuffer_add(buf, p, 1); -+ } else { -+ evbuffer_add_printf(buf, "%%%02X", (u_char)(*p)); -+ } -+ } -+ evbuffer_add(buf, "", 1); -+ p = strdup((char *)EVBUFFER_DATA(buf)); -+ evbuffer_free(buf); -+ -+ return (p); -+} -+ -+char * -+evhttp_decode_uri(const char *uri) -+{ -+ char c, *ret; -+ int i, j, in_query = 0; -+ -+ ret = malloc(strlen(uri) + 1); -+ if (ret == NULL) -+ event_err(1, "%s: malloc(%lu)", __func__, -+ (unsigned long)(strlen(uri) + 1)); -+ -+ for (i = j = 0; uri[i] != '\0'; i++) { -+ c = uri[i]; -+ if (c == '?') { -+ in_query = 1; -+ } else if (c == '+' && in_query) { -+ c = ' '; -+ } else if (c == '%' && isxdigit((unsigned char)uri[i+1]) && -+ isxdigit((unsigned char)uri[i+2])) { -+ char tmp[] = { uri[i+1], uri[i+2], '\0' }; -+ c = (char)strtol(tmp, NULL, 16); -+ i += 2; -+ } -+ ret[j++] = c; -+ } -+ ret[j] = '\0'; -+ -+ return (ret); -+} -+ -+/* -+ * Helper function to parse out arguments in a query. -+ * The arguments are separated by key and value. -+ * URI should already be decoded. -+ */ -+ -+void -+evhttp_parse_query(const char *uri, struct evkeyvalq *headers) -+{ -+ char *line; -+ char *argument; -+ char *p; -+ -+ TAILQ_INIT(headers); -+ -+ /* No arguments - we are done */ -+ if (strchr(uri, '?') == NULL) -+ return; -+ -+ if ((line = strdup(uri)) == NULL) -+ event_err(1, "%s: strdup", __func__); -+ -+ -+ argument = line; -+ -+ /* We already know that there has to be a ? */ -+ strsep(&argument, "?"); -+ -+ p = argument; -+ while (p != NULL && *p != '\0') { -+ char *key, *value; -+ argument = strsep(&p, "&"); -+ -+ value = argument; -+ key = strsep(&value, "="); -+ if (value == NULL) -+ goto error; -+ -+ value = evhttp_decode_uri(value); -+ event_debug(("Query Param: %s -> %s\n", key, value)); -+ evhttp_add_header(headers, key, value); -+ free(value); -+ } -+ -+ error: -+ free(line); -+} -+ -+static struct evhttp_cb * -+evhttp_dispatch_callback(struct httpcbq *callbacks, struct evhttp_request *req) -+{ -+ struct evhttp_cb *cb; -+ size_t offset = 0; -+ -+ /* Test for different URLs */ -+ char *p = strchr(req->uri, '?'); -+ if (p != NULL) -+ offset = (size_t)(p - req->uri); -+ -+ TAILQ_FOREACH(cb, callbacks, next) { -+ int res = 0; -+ if (p == NULL) { -+ res = strcmp(cb->what, req->uri) == 0; -+ } else { -+ res = ((strncmp(cb->what, req->uri, offset) == 0) && -+ (cb->what[offset] == '\0')); -+ } -+ -+ if (res) -+ return (cb); -+ } -+ -+ return (NULL); -+} -+ -+static void -+evhttp_handle_request(struct evhttp_request *req, void *arg) -+{ -+ struct evhttp *http = arg; -+ struct evhttp_cb *cb = NULL; -+ -+ if (req->uri == NULL) { -+ evhttp_send_error(req, HTTP_BADREQUEST, "Bad Request"); -+ return; -+ } -+ -+ if ((cb = evhttp_dispatch_callback(&http->callbacks, req)) != NULL) { -+ (*cb->cb)(req, cb->cbarg); -+ return; -+ } -+ -+ /* Generic call back */ -+ if (http->gencb) { -+ (*http->gencb)(req, http->gencbarg); -+ return; -+ } else { -+ /* We need to send a 404 here */ -+#define ERR_FORMAT "" \ -+ "404 Not Found" \ -+ "" \ -+ "

Not Found

" \ -+ "

The requested URL %s was not found on this server.

"\ -+ "\n" -+ -+ char *escaped_html = evhttp_htmlescape(req->uri); -+ struct evbuffer *buf = evbuffer_new(); -+ -+ evhttp_response_code(req, HTTP_NOTFOUND, "Not Found"); -+ -+ evbuffer_add_printf(buf, ERR_FORMAT, escaped_html); -+ -+ free(escaped_html); -+ -+ evhttp_send_page(req, buf); -+ -+ evbuffer_free(buf); -+#undef ERR_FORMAT -+ } -+} -+ -+static void -+accept_socket(int fd, short what, void *arg) -+{ -+ struct evhttp *http = arg; -+ struct sockaddr_storage ss; -+ socklen_t addrlen = sizeof(ss); -+ int nfd; -+ -+ if ((nfd = accept(fd, (struct sockaddr *)&ss, &addrlen)) == -1) { -+ if (errno != EAGAIN && errno != EINTR) -+ event_warn("%s: bad accept", __func__); -+ return; -+ } -+ if (evutil_make_socket_nonblocking(nfd) < 0) -+ return; -+ -+ evhttp_get_request(http, nfd, (struct sockaddr *)&ss, addrlen); -+} -+ -+int -+evhttp_bind_socket(struct evhttp *http, const char *address, u_short port) -+{ -+ int fd; -+ int res; -+ -+ if ((fd = bind_socket(address, port, 1 /*reuse*/)) == -1) -+ return (-1); -+ -+ if (listen(fd, 128) == -1) { -+ event_warn("%s: listen", __func__); -+ EVUTIL_CLOSESOCKET(fd); -+ return (-1); -+ } -+ -+ res = evhttp_accept_socket(http, fd); -+ -+ if (res != -1) -+ event_debug(("Bound to port %d - Awaiting connections ... ", -+ port)); -+ -+ return (res); -+} -+ -+int -+evhttp_accept_socket(struct evhttp *http, int fd) -+{ -+ struct evhttp_bound_socket *bound; -+ struct event *ev; -+ int res; -+ -+ bound = malloc(sizeof(struct evhttp_bound_socket)); -+ if (bound == NULL) -+ return (-1); -+ -+ ev = &bound->bind_ev; -+ -+ /* Schedule the socket for accepting */ -+ event_set(ev, fd, EV_READ | EV_PERSIST, accept_socket, http); -+ EVHTTP_BASE_SET(http, ev); -+ -+ res = event_add(ev, NULL); -+ -+ if (res == -1) { -+ free(bound); -+ return (-1); -+ } -+ -+ TAILQ_INSERT_TAIL(&http->sockets, bound, next); -+ -+ return (0); -+} -+ -+static struct evhttp* -+evhttp_new_object(void) -+{ -+ struct evhttp *http = NULL; -+ -+ if ((http = calloc(1, sizeof(struct evhttp))) == NULL) { -+ event_warn("%s: calloc", __func__); -+ return (NULL); -+ } -+ -+ http->timeout = -1; -+ -+ TAILQ_INIT(&http->sockets); -+ TAILQ_INIT(&http->callbacks); -+ TAILQ_INIT(&http->connections); -+ -+ return (http); -+} -+ -+struct evhttp * -+evhttp_new(struct event_base *base) -+{ -+ struct evhttp *http = evhttp_new_object(); -+ -+ http->base = base; -+ -+ return (http); -+} -+ -+/* -+ * Start a web server on the specified address and port. -+ */ -+ -+struct evhttp * -+evhttp_start(const char *address, u_short port) -+{ -+ struct evhttp *http = evhttp_new_object(); -+ -+ if (evhttp_bind_socket(http, address, port) == -1) { -+ free(http); -+ return (NULL); -+ } -+ -+ return (http); -+} -+ -+void -+evhttp_free(struct evhttp* http) -+{ -+ struct evhttp_cb *http_cb; -+ struct evhttp_connection *evcon; -+ struct evhttp_bound_socket *bound; -+ int fd; -+ -+ /* Remove the accepting part */ -+ while ((bound = TAILQ_FIRST(&http->sockets)) != NULL) { -+ TAILQ_REMOVE(&http->sockets, bound, next); -+ -+ fd = bound->bind_ev.ev_fd; -+ event_del(&bound->bind_ev); -+ EVUTIL_CLOSESOCKET(fd); -+ -+ free(bound); -+ } -+ -+ while ((evcon = TAILQ_FIRST(&http->connections)) != NULL) { -+ /* evhttp_connection_free removes the connection */ -+ evhttp_connection_free(evcon); -+ } -+ -+ while ((http_cb = TAILQ_FIRST(&http->callbacks)) != NULL) { -+ TAILQ_REMOVE(&http->callbacks, http_cb, next); -+ free(http_cb->what); -+ free(http_cb); -+ } -+ -+ free(http); -+} -+ -+void -+evhttp_set_timeout(struct evhttp* http, int timeout_in_secs) -+{ -+ http->timeout = timeout_in_secs; -+} -+ -+void -+evhttp_set_cb(struct evhttp *http, const char *uri, -+ void (*cb)(struct evhttp_request *, void *), void *cbarg) -+{ -+ struct evhttp_cb *http_cb; -+ -+ if ((http_cb = calloc(1, sizeof(struct evhttp_cb))) == NULL) -+ event_err(1, "%s: calloc", __func__); -+ -+ http_cb->what = strdup(uri); -+ http_cb->cb = cb; -+ http_cb->cbarg = cbarg; -+ -+ TAILQ_INSERT_TAIL(&http->callbacks, http_cb, next); -+} -+ -+int -+evhttp_del_cb(struct evhttp *http, const char *uri) -+{ -+ struct evhttp_cb *http_cb; -+ -+ TAILQ_FOREACH(http_cb, &http->callbacks, next) { -+ if (strcmp(http_cb->what, uri) == 0) -+ break; -+ } -+ if (http_cb == NULL) -+ return (-1); -+ -+ TAILQ_REMOVE(&http->callbacks, http_cb, next); -+ free(http_cb->what); -+ free(http_cb); -+ -+ return (0); -+} -+ -+void -+evhttp_set_gencb(struct evhttp *http, -+ void (*cb)(struct evhttp_request *, void *), void *cbarg) -+{ -+ http->gencb = cb; -+ http->gencbarg = cbarg; -+} -+ -+/* -+ * Request related functions -+ */ -+ -+struct evhttp_request * -+evhttp_request_new(void (*cb)(struct evhttp_request *, void *), void *arg) -+{ -+ struct evhttp_request *req = NULL; -+ -+ /* Allocate request structure */ -+ if ((req = calloc(1, sizeof(struct evhttp_request))) == NULL) { -+ event_warn("%s: calloc", __func__); -+ goto error; -+ } -+ -+ req->kind = EVHTTP_RESPONSE; -+ req->input_headers = calloc(1, sizeof(struct evkeyvalq)); -+ if (req->input_headers == NULL) { -+ event_warn("%s: calloc", __func__); -+ goto error; -+ } -+ TAILQ_INIT(req->input_headers); -+ -+ req->output_headers = calloc(1, sizeof(struct evkeyvalq)); -+ if (req->output_headers == NULL) { -+ event_warn("%s: calloc", __func__); -+ goto error; -+ } -+ TAILQ_INIT(req->output_headers); -+ -+ if ((req->input_buffer = evbuffer_new()) == NULL) { -+ event_warn("%s: evbuffer_new", __func__); -+ goto error; -+ } -+ -+ if ((req->output_buffer = evbuffer_new()) == NULL) { -+ event_warn("%s: evbuffer_new", __func__); -+ goto error; -+ } -+ -+ req->cb = cb; -+ req->cb_arg = arg; -+ -+ return (req); -+ -+ error: -+ if (req != NULL) -+ evhttp_request_free(req); -+ return (NULL); -+} -+ -+void -+evhttp_request_free(struct evhttp_request *req) -+{ -+ if (req->remote_host != NULL) -+ free(req->remote_host); -+ if (req->uri != NULL) -+ free(req->uri); -+ if (req->response_code_line != NULL) -+ free(req->response_code_line); -+ -+ evhttp_clear_headers(req->input_headers); -+ free(req->input_headers); -+ -+ evhttp_clear_headers(req->output_headers); -+ free(req->output_headers); -+ -+ if (req->input_buffer != NULL) -+ evbuffer_free(req->input_buffer); -+ -+ if (req->output_buffer != NULL) -+ evbuffer_free(req->output_buffer); -+ -+ free(req); -+} -+ -+void -+evhttp_request_set_chunked_cb(struct evhttp_request *req, -+ void (*cb)(struct evhttp_request *, void *)) -+{ -+ req->chunk_cb = cb; -+} -+ -+/* -+ * Allows for inspection of the request URI -+ */ -+ -+const char * -+evhttp_request_uri(struct evhttp_request *req) { -+ if (req->uri == NULL) -+ event_debug(("%s: request %p has no uri\n", __func__, req)); -+ return (req->uri); -+} -+ -+/* -+ * Takes a file descriptor to read a request from. -+ * The callback is executed once the whole request has been read. -+ */ -+ -+static struct evhttp_connection* -+evhttp_get_request_connection( -+ struct evhttp* http, -+ int fd, struct sockaddr *sa, socklen_t salen) -+{ -+ struct evhttp_connection *evcon; -+ char *hostname = NULL, *portname = NULL; -+ -+ name_from_addr(sa, salen, &hostname, &portname); -+ if (hostname == NULL || portname == NULL) { -+ if (hostname) free(hostname); -+ if (portname) free(portname); -+ return (NULL); -+ } -+ -+ event_debug(("%s: new request from %s:%s on %d\n", -+ __func__, hostname, portname, fd)); -+ -+ /* we need a connection object to put the http request on */ -+ evcon = evhttp_connection_new(hostname, atoi(portname)); -+ free(hostname); -+ free(portname); -+ if (evcon == NULL) -+ return (NULL); -+ -+ /* associate the base if we have one*/ -+ evhttp_connection_set_base(evcon, http->base); -+ -+ evcon->flags |= EVHTTP_CON_INCOMING; -+ evcon->state = EVCON_READING_FIRSTLINE; -+ -+ evcon->fd = fd; -+ -+ return (evcon); -+} -+ -+static int -+evhttp_associate_new_request_with_connection(struct evhttp_connection *evcon) -+{ -+ struct evhttp *http = evcon->http_server; -+ struct evhttp_request *req; -+ if ((req = evhttp_request_new(evhttp_handle_request, http)) == NULL) -+ return (-1); -+ -+ req->evcon = evcon; /* the request ends up owning the connection */ -+ req->flags |= EVHTTP_REQ_OWN_CONNECTION; -+ -+ TAILQ_INSERT_TAIL(&evcon->requests, req, next); -+ -+ req->kind = EVHTTP_REQUEST; -+ -+ if ((req->remote_host = strdup(evcon->address)) == NULL) -+ event_err(1, "%s: strdup", __func__); -+ req->remote_port = evcon->port; -+ -+ evhttp_start_read(evcon); -+ -+ return (0); -+} -+ -+void -+evhttp_get_request(struct evhttp *http, int fd, -+ struct sockaddr *sa, socklen_t salen) -+{ -+ struct evhttp_connection *evcon; -+ -+ evcon = evhttp_get_request_connection(http, fd, sa, salen); -+ if (evcon == NULL) -+ return; -+ -+ /* the timeout can be used by the server to close idle connections */ -+ if (http->timeout != -1) -+ evhttp_connection_set_timeout(evcon, http->timeout); -+ -+ /* -+ * if we want to accept more than one request on a connection, -+ * we need to know which http server it belongs to. -+ */ -+ evcon->http_server = http; -+ TAILQ_INSERT_TAIL(&http->connections, evcon, next); -+ -+ if (evhttp_associate_new_request_with_connection(evcon) == -1) -+ evhttp_connection_free(evcon); -+} -+ -+ -+/* -+ * Network helper functions that we do not want to export to the rest of -+ * the world. -+ */ -+#if 0 /* Unused */ -+static struct addrinfo * -+addr_from_name(char *address) -+{ -+#ifdef HAVE_GETADDRINFO -+ struct addrinfo ai, *aitop; -+ int ai_result; -+ -+ memset(&ai, 0, sizeof(ai)); -+ ai.ai_family = AF_INET; -+ ai.ai_socktype = SOCK_RAW; -+ ai.ai_flags = 0; -+ if ((ai_result = getaddrinfo(address, NULL, &ai, &aitop)) != 0) { -+ if ( ai_result == EAI_SYSTEM ) -+ event_warn("getaddrinfo"); -+ else -+ event_warnx("getaddrinfo: %s", gai_strerror(ai_result)); -+ } -+ -+ return (aitop); -+#else -+ assert(0); -+ return NULL; /* XXXXX Use gethostbyname, if this function is ever used. */ -+#endif -+} -+#endif -+ -+static void -+name_from_addr(struct sockaddr *sa, socklen_t salen, -+ char **phost, char **pport) -+{ -+ char ntop[NI_MAXHOST]; -+ char strport[NI_MAXSERV]; -+ int ni_result; -+ -+#ifdef HAVE_GETNAMEINFO -+ ni_result = getnameinfo(sa, salen, -+ ntop, sizeof(ntop), strport, sizeof(strport), -+ NI_NUMERICHOST|NI_NUMERICSERV); -+ -+ if (ni_result != 0) { -+ if (ni_result == EAI_SYSTEM) -+ event_err(1, "getnameinfo failed"); -+ else -+ event_errx(1, "getnameinfo failed: %s", gai_strerror(ni_result)); -+ return; -+ } -+#else -+ ni_result = fake_getnameinfo(sa, salen, -+ ntop, sizeof(ntop), strport, sizeof(strport), -+ NI_NUMERICHOST|NI_NUMERICSERV); -+ if (ni_result != 0) -+ return; -+#endif -+ *phost = strdup(ntop); -+ *pport = strdup(strport); -+} -+ -+/* Either connect or bind */ -+ -+static int -+bind_socket_ai(struct addrinfo *ai, int reuse) -+{ -+ int fd, on = 1, r; -+ int serrno; -+ -+ /* Create listen socket */ -+ fd = socket(AF_INET, SOCK_STREAM, 0); -+ if (fd == -1) { -+ event_warn("socket"); -+ return (-1); -+ } -+ -+ if (evutil_make_socket_nonblocking(fd) < 0) -+ goto out; -+ -+#ifndef WIN32 -+ if (fcntl(fd, F_SETFD, 1) == -1) { -+ event_warn("fcntl(F_SETFD)"); -+ goto out; -+ } -+#endif -+ -+ setsockopt(fd, SOL_SOCKET, SO_KEEPALIVE, (void *)&on, sizeof(on)); -+ if (reuse) { -+ setsockopt(fd, SOL_SOCKET, SO_REUSEADDR, -+ (void *)&on, sizeof(on)); -+ } -+ -+ r = bind(fd, ai->ai_addr, ai->ai_addrlen); -+ if (r == -1) -+ goto out; -+ -+ return (fd); -+ -+ out: -+ serrno = EVUTIL_SOCKET_ERROR(); -+ EVUTIL_CLOSESOCKET(fd); -+ EVUTIL_SET_SOCKET_ERROR(serrno); -+ return (-1); -+} -+ -+static struct addrinfo * -+make_addrinfo(const char *address, u_short port) -+{ -+ struct addrinfo *aitop = NULL; -+ -+#ifdef HAVE_GETADDRINFO -+ struct addrinfo ai; -+ char strport[NI_MAXSERV]; -+ int ai_result; -+ -+ memset(&ai, 0, sizeof(ai)); -+ ai.ai_family = AF_INET; -+ ai.ai_socktype = SOCK_STREAM; -+ ai.ai_flags = AI_PASSIVE; /* turn NULL host name into INADDR_ANY */ -+ evutil_snprintf(strport, sizeof(strport), "%d", port); -+ if ((ai_result = getaddrinfo(address, strport, &ai, &aitop)) != 0) { -+ if ( ai_result == EAI_SYSTEM ) -+ event_warn("getaddrinfo"); -+ else -+ event_warnx("getaddrinfo: %s", gai_strerror(ai_result)); -+ return (NULL); -+ } -+#else -+ static int cur; -+ static struct addrinfo ai[2]; /* We will be returning the address of some of this memory so it has to last even after this call. */ -+ if (++cur == 2) cur = 0; /* allow calling this function twice */ -+ -+ if (fake_getaddrinfo(address, &ai[cur]) < 0) { -+ event_warn("fake_getaddrinfo"); -+ return (NULL); -+ } -+ aitop = &ai[cur]; -+ ((struct sockaddr_in *) aitop->ai_addr)->sin_port = htons(port); -+#endif -+ -+ return (aitop); -+} -+ -+static int -+bind_socket(const char *address, u_short port, int reuse) -+{ -+ int fd; -+ struct addrinfo *aitop = make_addrinfo(address, port); -+ -+ if (aitop == NULL) -+ return (-1); -+ -+ fd = bind_socket_ai(aitop, reuse); -+ -+#ifdef HAVE_GETADDRINFO -+ freeaddrinfo(aitop); -+#else -+ fake_freeaddrinfo(aitop); -+#endif -+ -+ return (fd); -+} -+ -+static int -+socket_connect(int fd, const char *address, unsigned short port) -+{ -+ struct addrinfo *ai = make_addrinfo(address, port); -+ int res = -1; -+ -+ if (ai == NULL) { -+ event_debug(("%s: make_addrinfo: \"%s:%d\"", -+ __func__, address, port)); -+ return (-1); -+ } -+ -+ if (connect(fd, ai->ai_addr, ai->ai_addrlen) == -1) { -+#ifdef WIN32 -+ int tmp_error = WSAGetLastError(); -+ if (tmp_error != WSAEWOULDBLOCK && tmp_error != WSAEINVAL && -+ tmp_error != WSAEINPROGRESS) { -+ goto out; -+ } -+#else -+ if (errno != EINPROGRESS) { -+ goto out; -+ } -+#endif -+ } -+ -+ /* everything is fine */ -+ res = 0; -+ -+out: -+#ifdef HAVE_GETADDRINFO -+ freeaddrinfo(ai); -+#else -+ fake_freeaddrinfo(ai); -+#endif -+ -+ return (res); -+} -diff --git a/libevent/install-sh b/libevent/install-sh -new file mode 100644 -index 0000000..1a83534 ---- /dev/null -+++ b/libevent/install-sh -@@ -0,0 +1,323 @@ -+#!/bin/sh -+# install - install a program, script, or datafile -+ -+scriptversion=2005-02-02.21 -+ -+# This originates from X11R5 (mit/util/scripts/install.sh), which was -+# later released in X11R6 (xc/config/util/install.sh) with the -+# following copyright and license. -+# -+# Copyright (C) 1994 X Consortium -+# -+# Permission is hereby granted, free of charge, to any person obtaining a copy -+# of this software and associated documentation files (the "Software"), to -+# deal in the Software without restriction, including without limitation the -+# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or -+# sell copies of the Software, and to permit persons to whom the Software is -+# furnished to do so, subject to the following conditions: -+# -+# The above copyright notice and this permission notice shall be included in -+# all copies or substantial portions of the Software. -+# -+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -+# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -+# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -+# X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -+# AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC- -+# TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. -+# -+# Except as contained in this notice, the name of the X Consortium shall not -+# be used in advertising or otherwise to promote the sale, use or other deal- -+# ings in this Software without prior written authorization from the X Consor- -+# tium. -+# -+# -+# FSF changes to this file are in the public domain. -+# -+# Calling this script install-sh is preferred over install.sh, to prevent -+# `make' implicit rules from creating a file called install from it -+# when there is no Makefile. -+# -+# This script is compatible with the BSD install script, but was written -+# from scratch. It can only install one file at a time, a restriction -+# shared with many OS's install programs. -+ -+# set DOITPROG to echo to test this script -+ -+# Don't use :- since 4.3BSD and earlier shells don't like it. -+doit="${DOITPROG-}" -+ -+# put in absolute paths if you don't have them in your path; or use env. vars. -+ -+mvprog="${MVPROG-mv}" -+cpprog="${CPPROG-cp}" -+chmodprog="${CHMODPROG-chmod}" -+chownprog="${CHOWNPROG-chown}" -+chgrpprog="${CHGRPPROG-chgrp}" -+stripprog="${STRIPPROG-strip}" -+rmprog="${RMPROG-rm}" -+mkdirprog="${MKDIRPROG-mkdir}" -+ -+chmodcmd="$chmodprog 0755" -+chowncmd= -+chgrpcmd= -+stripcmd= -+rmcmd="$rmprog -f" -+mvcmd="$mvprog" -+src= -+dst= -+dir_arg= -+dstarg= -+no_target_directory= -+ -+usage="Usage: $0 [OPTION]... [-T] SRCFILE DSTFILE -+ or: $0 [OPTION]... SRCFILES... DIRECTORY -+ or: $0 [OPTION]... -t DIRECTORY SRCFILES... -+ or: $0 [OPTION]... -d DIRECTORIES... -+ -+In the 1st form, copy SRCFILE to DSTFILE. -+In the 2nd and 3rd, copy all SRCFILES to DIRECTORY. -+In the 4th, create DIRECTORIES. -+ -+Options: -+-c (ignored) -+-d create directories instead of installing files. -+-g GROUP $chgrpprog installed files to GROUP. -+-m MODE $chmodprog installed files to MODE. -+-o USER $chownprog installed files to USER. -+-s $stripprog installed files. -+-t DIRECTORY install into DIRECTORY. -+-T report an error if DSTFILE is a directory. -+--help display this help and exit. -+--version display version info and exit. -+ -+Environment variables override the default commands: -+ CHGRPPROG CHMODPROG CHOWNPROG CPPROG MKDIRPROG MVPROG RMPROG STRIPPROG -+" -+ -+while test -n "$1"; do -+ case $1 in -+ -c) shift -+ continue;; -+ -+ -d) dir_arg=true -+ shift -+ continue;; -+ -+ -g) chgrpcmd="$chgrpprog $2" -+ shift -+ shift -+ continue;; -+ -+ --help) echo "$usage"; exit $?;; -+ -+ -m) chmodcmd="$chmodprog $2" -+ shift -+ shift -+ continue;; -+ -+ -o) chowncmd="$chownprog $2" -+ shift -+ shift -+ continue;; -+ -+ -s) stripcmd=$stripprog -+ shift -+ continue;; -+ -+ -t) dstarg=$2 -+ shift -+ shift -+ continue;; -+ -+ -T) no_target_directory=true -+ shift -+ continue;; -+ -+ --version) echo "$0 $scriptversion"; exit $?;; -+ -+ *) # When -d is used, all remaining arguments are directories to create. -+ # When -t is used, the destination is already specified. -+ test -n "$dir_arg$dstarg" && break -+ # Otherwise, the last argument is the destination. Remove it from $@. -+ for arg -+ do -+ if test -n "$dstarg"; then -+ # $@ is not empty: it contains at least $arg. -+ set fnord "$@" "$dstarg" -+ shift # fnord -+ fi -+ shift # arg -+ dstarg=$arg -+ done -+ break;; -+ esac -+done -+ -+if test -z "$1"; then -+ if test -z "$dir_arg"; then -+ echo "$0: no input file specified." >&2 -+ exit 1 -+ fi -+ # It's OK to call `install-sh -d' without argument. -+ # This can happen when creating conditional directories. -+ exit 0 -+fi -+ -+for src -+do -+ # Protect names starting with `-'. -+ case $src in -+ -*) src=./$src ;; -+ esac -+ -+ if test -n "$dir_arg"; then -+ dst=$src -+ src= -+ -+ if test -d "$dst"; then -+ mkdircmd=: -+ chmodcmd= -+ else -+ mkdircmd=$mkdirprog -+ fi -+ else -+ # Waiting for this to be detected by the "$cpprog $src $dsttmp" command -+ # might cause directories to be created, which would be especially bad -+ # if $src (and thus $dsttmp) contains '*'. -+ if test ! -f "$src" && test ! -d "$src"; then -+ echo "$0: $src does not exist." >&2 -+ exit 1 -+ fi -+ -+ if test -z "$dstarg"; then -+ echo "$0: no destination specified." >&2 -+ exit 1 -+ fi -+ -+ dst=$dstarg -+ # Protect names starting with `-'. -+ case $dst in -+ -*) dst=./$dst ;; -+ esac -+ -+ # If destination is a directory, append the input filename; won't work -+ # if double slashes aren't ignored. -+ if test -d "$dst"; then -+ if test -n "$no_target_directory"; then -+ echo "$0: $dstarg: Is a directory" >&2 -+ exit 1 -+ fi -+ dst=$dst/`basename "$src"` -+ fi -+ fi -+ -+ # This sed command emulates the dirname command. -+ dstdir=`echo "$dst" | sed -e 's,/*$,,;s,[^/]*$,,;s,/*$,,;s,^$,.,'` -+ -+ # Make sure that the destination directory exists. -+ -+ # Skip lots of stat calls in the usual case. -+ if test ! -d "$dstdir"; then -+ defaultIFS=' -+ ' -+ IFS="${IFS-$defaultIFS}" -+ -+ oIFS=$IFS -+ # Some sh's can't handle IFS=/ for some reason. -+ IFS='%' -+ set x `echo "$dstdir" | sed -e 's@/@%@g' -e 's@^%@/@'` -+ shift -+ IFS=$oIFS -+ -+ pathcomp= -+ -+ while test $# -ne 0 ; do -+ pathcomp=$pathcomp$1 -+ shift -+ if test ! -d "$pathcomp"; then -+ $mkdirprog "$pathcomp" -+ # mkdir can fail with a `File exist' error in case several -+ # install-sh are creating the directory concurrently. This -+ # is OK. -+ test -d "$pathcomp" || exit -+ fi -+ pathcomp=$pathcomp/ -+ done -+ fi -+ -+ if test -n "$dir_arg"; then -+ $doit $mkdircmd "$dst" \ -+ && { test -z "$chowncmd" || $doit $chowncmd "$dst"; } \ -+ && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } \ -+ && { test -z "$stripcmd" || $doit $stripcmd "$dst"; } \ -+ && { test -z "$chmodcmd" || $doit $chmodcmd "$dst"; } -+ -+ else -+ dstfile=`basename "$dst"` -+ -+ # Make a couple of temp file names in the proper directory. -+ dsttmp=$dstdir/_inst.$$_ -+ rmtmp=$dstdir/_rm.$$_ -+ -+ # Trap to clean up those temp files at exit. -+ trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0 -+ trap '(exit $?); exit' 1 2 13 15 -+ -+ # Copy the file name to the temp name. -+ $doit $cpprog "$src" "$dsttmp" && -+ -+ # and set any options; do chmod last to preserve setuid bits. -+ # -+ # If any of these fail, we abort the whole thing. If we want to -+ # ignore errors from any of these, just make sure not to ignore -+ # errors from the above "$doit $cpprog $src $dsttmp" command. -+ # -+ { test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } \ -+ && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } \ -+ && { test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } \ -+ && { test -z "$chmodcmd" || $doit $chmodcmd "$dsttmp"; } && -+ -+ # Now rename the file to the real destination. -+ { $doit $mvcmd -f "$dsttmp" "$dstdir/$dstfile" 2>/dev/null \ -+ || { -+ # The rename failed, perhaps because mv can't rename something else -+ # to itself, or perhaps because mv is so ancient that it does not -+ # support -f. -+ -+ # Now remove or move aside any old file at destination location. -+ # We try this two ways since rm can't unlink itself on some -+ # systems and the destination file might be busy for other -+ # reasons. In this case, the final cleanup might fail but the new -+ # file should still install successfully. -+ { -+ if test -f "$dstdir/$dstfile"; then -+ $doit $rmcmd -f "$dstdir/$dstfile" 2>/dev/null \ -+ || $doit $mvcmd -f "$dstdir/$dstfile" "$rmtmp" 2>/dev/null \ -+ || { -+ echo "$0: cannot unlink or rename $dstdir/$dstfile" >&2 -+ (exit 1); exit 1 -+ } -+ else -+ : -+ fi -+ } && -+ -+ # Now rename the file to the real destination. -+ $doit $mvcmd "$dsttmp" "$dstdir/$dstfile" -+ } -+ } -+ fi || { (exit 1); exit 1; } -+done -+ -+# The final little trick to "correctly" pass the exit status to the exit trap. -+{ -+ (exit 0); exit 0 -+} -+ -+# Local variables: -+# eval: (add-hook 'write-file-hooks 'time-stamp) -+# time-stamp-start: "scriptversion=" -+# time-stamp-format: "%:y-%02m-%02d.%02H" -+# time-stamp-end: "$" -+# End: -diff --git a/libevent/kqueue.c b/libevent/kqueue.c -new file mode 100644 -index 0000000..38a1819 ---- /dev/null -+++ b/libevent/kqueue.c -@@ -0,0 +1,450 @@ -+/* $OpenBSD: kqueue.c,v 1.5 2002/07/10 14:41:31 art Exp $ */ -+ -+/* -+ * Copyright 2000-2002 Niels Provos -+ * All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. The name of the author may not be used to endorse or promote products -+ * derived from this software without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR -+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES -+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. -+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, -+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT -+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF -+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+ */ -+#ifdef HAVE_CONFIG_H -+#include "config.h" -+#endif -+ -+#include -+#ifdef HAVE_SYS_TIME_H -+#include -+#else -+#include -+#endif -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#ifdef HAVE_INTTYPES_H -+#include -+#endif -+ -+/* Some platforms apparently define the udata field of struct kevent as -+ * intptr_t, whereas others define it as void*. There doesn't seem to be an -+ * easy way to tell them apart via autoconf, so we need to use OS macros. */ -+#if defined(HAVE_INTTYPES_H) && !defined(__OpenBSD__) && !defined(__FreeBSD__) && !defined(__darwin__) && !defined(__APPLE__) -+#define PTR_TO_UDATA(x) ((intptr_t)(x)) -+#else -+#define PTR_TO_UDATA(x) (x) -+#endif -+ -+#include "event.h" -+#include "event-internal.h" -+#include "log.h" -+#include "event-internal.h" -+ -+#define EVLIST_X_KQINKERNEL 0x1000 -+ -+#define NEVENT 64 -+ -+struct kqop { -+ struct kevent *changes; -+ int nchanges; -+ struct kevent *events; -+ struct event_list evsigevents[NSIG]; -+ int nevents; -+ int kq; -+ pid_t pid; -+}; -+ -+static void *kq_init (struct event_base *); -+static int kq_add (void *, struct event *); -+static int kq_del (void *, struct event *); -+static int kq_dispatch (struct event_base *, void *, struct timeval *); -+static int kq_insert (struct kqop *, struct kevent *); -+static void kq_dealloc (struct event_base *, void *); -+ -+const struct eventop kqops = { -+ "kqueue", -+ kq_init, -+ kq_add, -+ kq_del, -+ kq_dispatch, -+ kq_dealloc, -+ 1 /* need reinit */ -+}; -+ -+static void * -+kq_init(struct event_base *base) -+{ -+ int i, kq; -+ struct kqop *kqueueop; -+ -+ /* Disable kqueue when this environment variable is set */ -+ if (getenv("EVENT_NOKQUEUE")) -+ return (NULL); -+ -+ if (!(kqueueop = calloc(1, sizeof(struct kqop)))) -+ return (NULL); -+ -+ /* Initalize the kernel queue */ -+ -+ if ((kq = kqueue()) == -1) { -+ event_warn("kqueue"); -+ free (kqueueop); -+ return (NULL); -+ } -+ -+ kqueueop->kq = kq; -+ -+ kqueueop->pid = getpid(); -+ -+ /* Initalize fields */ -+ kqueueop->changes = malloc(NEVENT * sizeof(struct kevent)); -+ if (kqueueop->changes == NULL) { -+ free (kqueueop); -+ return (NULL); -+ } -+ kqueueop->events = malloc(NEVENT * sizeof(struct kevent)); -+ if (kqueueop->events == NULL) { -+ free (kqueueop->changes); -+ free (kqueueop); -+ return (NULL); -+ } -+ kqueueop->nevents = NEVENT; -+ -+ /* we need to keep track of multiple events per signal */ -+ for (i = 0; i < NSIG; ++i) { -+ TAILQ_INIT(&kqueueop->evsigevents[i]); -+ } -+ -+ /* Check for Mac OS X kqueue bug. */ -+ kqueueop->changes[0].ident = -1; -+ kqueueop->changes[0].filter = EVFILT_READ; -+ kqueueop->changes[0].flags = EV_ADD; -+ /* -+ * If kqueue works, then kevent will succeed, and it will -+ * stick an error in events[0]. If kqueue is broken, then -+ * kevent will fail. -+ */ -+ if (kevent(kq, -+ kqueueop->changes, 1, kqueueop->events, NEVENT, NULL) != 1 || -+ kqueueop->events[0].ident != -1 || -+ kqueueop->events[0].flags != EV_ERROR) { -+ event_warn("%s: detected broken kqueue; not using.", __func__); -+ free(kqueueop->changes); -+ free(kqueueop->events); -+ free(kqueueop); -+ close(kq); -+ return (NULL); -+ } -+ -+ return (kqueueop); -+} -+ -+static int -+kq_insert(struct kqop *kqop, struct kevent *kev) -+{ -+ int nevents = kqop->nevents; -+ -+ if (kqop->nchanges == nevents) { -+ struct kevent *newchange; -+ struct kevent *newresult; -+ -+ nevents *= 2; -+ -+ newchange = realloc(kqop->changes, -+ nevents * sizeof(struct kevent)); -+ if (newchange == NULL) { -+ event_warn("%s: malloc", __func__); -+ return (-1); -+ } -+ kqop->changes = newchange; -+ -+ newresult = realloc(kqop->events, -+ nevents * sizeof(struct kevent)); -+ -+ /* -+ * If we fail, we don't have to worry about freeing, -+ * the next realloc will pick it up. -+ */ -+ if (newresult == NULL) { -+ event_warn("%s: malloc", __func__); -+ return (-1); -+ } -+ kqop->events = newresult; -+ -+ kqop->nevents = nevents; -+ } -+ -+ memcpy(&kqop->changes[kqop->nchanges++], kev, sizeof(struct kevent)); -+ -+ event_debug(("%s: fd %d %s%s", -+ __func__, (int)kev->ident, -+ kev->filter == EVFILT_READ ? "EVFILT_READ" : "EVFILT_WRITE", -+ kev->flags == EV_DELETE ? " (del)" : "")); -+ -+ return (0); -+} -+ -+static void -+kq_sighandler(int sig) -+{ -+ /* Do nothing here */ -+} -+ -+static int -+kq_dispatch(struct event_base *base, void *arg, struct timeval *tv) -+{ -+ struct kqop *kqop = arg; -+ struct kevent *changes = kqop->changes; -+ struct kevent *events = kqop->events; -+ struct event *ev; -+ struct timespec ts, *ts_p = NULL; -+ int i, res; -+ -+ if (tv != NULL) { -+ TIMEVAL_TO_TIMESPEC(tv, &ts); -+ ts_p = &ts; -+ } -+ -+ res = kevent(kqop->kq, changes, kqop->nchanges, -+ events, kqop->nevents, ts_p); -+ kqop->nchanges = 0; -+ if (res == -1) { -+ if (errno != EINTR) { -+ event_warn("kevent"); -+ return (-1); -+ } -+ -+ return (0); -+ } -+ -+ event_debug(("%s: kevent reports %d", __func__, res)); -+ -+ for (i = 0; i < res; i++) { -+ int which = 0; -+ -+ if (events[i].flags & EV_ERROR) { -+ /* -+ * Error messages that can happen, when a delete fails. -+ * EBADF happens when the file discriptor has been -+ * closed, -+ * ENOENT when the file discriptor was closed and -+ * then reopened. -+ * EINVAL for some reasons not understood; EINVAL -+ * should not be returned ever; but FreeBSD does :-\ -+ * An error is also indicated when a callback deletes -+ * an event we are still processing. In that case -+ * the data field is set to ENOENT. -+ */ -+ if (events[i].data == EBADF || -+ events[i].data == EINVAL || -+ events[i].data == ENOENT) -+ continue; -+ errno = events[i].data; -+ return (-1); -+ } -+ -+ if (events[i].filter == EVFILT_READ) { -+ which |= EV_READ; -+ } else if (events[i].filter == EVFILT_WRITE) { -+ which |= EV_WRITE; -+ } else if (events[i].filter == EVFILT_SIGNAL) { -+ which |= EV_SIGNAL; -+ } -+ -+ if (!which) -+ continue; -+ -+ if (events[i].filter == EVFILT_SIGNAL) { -+ struct event_list *head = -+ (struct event_list *)events[i].udata; -+ TAILQ_FOREACH(ev, head, ev_signal_next) { -+ event_active(ev, which, events[i].data); -+ } -+ } else { -+ ev = (struct event *)events[i].udata; -+ -+ if (!(ev->ev_events & EV_PERSIST)) -+ ev->ev_flags &= ~EVLIST_X_KQINKERNEL; -+ -+ event_active(ev, which, 1); -+ } -+ } -+ -+ return (0); -+} -+ -+ -+static int -+kq_add(void *arg, struct event *ev) -+{ -+ struct kqop *kqop = arg; -+ struct kevent kev; -+ -+ if (ev->ev_events & EV_SIGNAL) { -+ int nsignal = EVENT_SIGNAL(ev); -+ -+ assert(nsignal >= 0 && nsignal < NSIG); -+ if (TAILQ_EMPTY(&kqop->evsigevents[nsignal])) { -+ struct timespec timeout = { 0, 0 }; -+ -+ memset(&kev, 0, sizeof(kev)); -+ kev.ident = nsignal; -+ kev.filter = EVFILT_SIGNAL; -+ kev.flags = EV_ADD; -+ kev.udata = PTR_TO_UDATA(&kqop->evsigevents[nsignal]); -+ -+ /* Be ready for the signal if it is sent any -+ * time between now and the next call to -+ * kq_dispatch. */ -+ if (kevent(kqop->kq, &kev, 1, NULL, 0, &timeout) == -1) -+ return (-1); -+ -+ if (_evsignal_set_handler(ev->ev_base, nsignal, -+ kq_sighandler) == -1) -+ return (-1); -+ } -+ -+ TAILQ_INSERT_TAIL(&kqop->evsigevents[nsignal], ev, -+ ev_signal_next); -+ ev->ev_flags |= EVLIST_X_KQINKERNEL; -+ return (0); -+ } -+ -+ if (ev->ev_events & EV_READ) { -+ memset(&kev, 0, sizeof(kev)); -+ kev.ident = ev->ev_fd; -+ kev.filter = EVFILT_READ; -+#ifdef NOTE_EOF -+ /* Make it behave like select() and poll() */ -+ kev.fflags = NOTE_EOF; -+#endif -+ kev.flags = EV_ADD; -+ if (!(ev->ev_events & EV_PERSIST)) -+ kev.flags |= EV_ONESHOT; -+ kev.udata = PTR_TO_UDATA(ev); -+ -+ if (kq_insert(kqop, &kev) == -1) -+ return (-1); -+ -+ ev->ev_flags |= EVLIST_X_KQINKERNEL; -+ } -+ -+ if (ev->ev_events & EV_WRITE) { -+ memset(&kev, 0, sizeof(kev)); -+ kev.ident = ev->ev_fd; -+ kev.filter = EVFILT_WRITE; -+ kev.flags = EV_ADD; -+ if (!(ev->ev_events & EV_PERSIST)) -+ kev.flags |= EV_ONESHOT; -+ kev.udata = PTR_TO_UDATA(ev); -+ -+ if (kq_insert(kqop, &kev) == -1) -+ return (-1); -+ -+ ev->ev_flags |= EVLIST_X_KQINKERNEL; -+ } -+ -+ return (0); -+} -+ -+static int -+kq_del(void *arg, struct event *ev) -+{ -+ struct kqop *kqop = arg; -+ struct kevent kev; -+ -+ if (!(ev->ev_flags & EVLIST_X_KQINKERNEL)) -+ return (0); -+ -+ if (ev->ev_events & EV_SIGNAL) { -+ int nsignal = EVENT_SIGNAL(ev); -+ struct timespec timeout = { 0, 0 }; -+ -+ assert(nsignal >= 0 && nsignal < NSIG); -+ TAILQ_REMOVE(&kqop->evsigevents[nsignal], ev, ev_signal_next); -+ if (TAILQ_EMPTY(&kqop->evsigevents[nsignal])) { -+ memset(&kev, 0, sizeof(kev)); -+ kev.ident = nsignal; -+ kev.filter = EVFILT_SIGNAL; -+ kev.flags = EV_DELETE; -+ -+ /* Because we insert signal events -+ * immediately, we need to delete them -+ * immediately, too */ -+ if (kevent(kqop->kq, &kev, 1, NULL, 0, &timeout) == -1) -+ return (-1); -+ -+ if (_evsignal_restore_handler(ev->ev_base, -+ nsignal) == -1) -+ return (-1); -+ } -+ -+ ev->ev_flags &= ~EVLIST_X_KQINKERNEL; -+ return (0); -+ } -+ -+ if (ev->ev_events & EV_READ) { -+ memset(&kev, 0, sizeof(kev)); -+ kev.ident = ev->ev_fd; -+ kev.filter = EVFILT_READ; -+ kev.flags = EV_DELETE; -+ -+ if (kq_insert(kqop, &kev) == -1) -+ return (-1); -+ -+ ev->ev_flags &= ~EVLIST_X_KQINKERNEL; -+ } -+ -+ if (ev->ev_events & EV_WRITE) { -+ memset(&kev, 0, sizeof(kev)); -+ kev.ident = ev->ev_fd; -+ kev.filter = EVFILT_WRITE; -+ kev.flags = EV_DELETE; -+ -+ if (kq_insert(kqop, &kev) == -1) -+ return (-1); -+ -+ ev->ev_flags &= ~EVLIST_X_KQINKERNEL; -+ } -+ -+ return (0); -+} -+ -+static void -+kq_dealloc(struct event_base *base, void *arg) -+{ -+ struct kqop *kqop = arg; -+ -+ if (kqop->changes) -+ free(kqop->changes); -+ if (kqop->events) -+ free(kqop->events); -+ -+ if (kqop->kq >= 0 && kqop->pid == getpid()) -+ close(kqop->kq); -+ memset(kqop, 0, sizeof(struct kqop)); -+ free(kqop); -+} -diff --git a/libevent/log.c b/libevent/log.c -new file mode 100644 -index 0000000..b62a619 ---- /dev/null -+++ b/libevent/log.c -@@ -0,0 +1,187 @@ -+/* $OpenBSD: err.c,v 1.2 2002/06/25 15:50:15 mickey Exp $ */ -+ -+/* -+ * log.c -+ * -+ * Based on err.c, which was adapted from OpenBSD libc *err* *warn* code. -+ * -+ * Copyright (c) 2005 Nick Mathewson -+ * -+ * Copyright (c) 2000 Dug Song -+ * -+ * Copyright (c) 1993 -+ * The Regents of the University of California. All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. Neither the name of the University nor the names of its contributors -+ * may be used to endorse or promote products derived from this software -+ * without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND -+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE -+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE -+ * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE -+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL -+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS -+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) -+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT -+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY -+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF -+ * SUCH DAMAGE. -+ */ -+ -+#ifdef HAVE_CONFIG_H -+#include "config.h" -+#endif -+ -+#ifdef WIN32 -+#define WIN32_LEAN_AND_MEAN -+#include -+#undef WIN32_LEAN_AND_MEAN -+#endif -+#include -+#ifdef HAVE_SYS_TIME_H -+#include -+#else -+#include -+#endif -+#include -+#include -+#include -+#include -+#include -+#include "event.h" -+ -+#include "log.h" -+#include "evutil.h" -+ -+static void _warn_helper(int severity, int log_errno, const char *fmt, -+ va_list ap); -+static void event_log(int severity, const char *msg); -+ -+void -+event_err(int eval, const char *fmt, ...) -+{ -+ va_list ap; -+ -+ va_start(ap, fmt); -+ _warn_helper(_EVENT_LOG_ERR, errno, fmt, ap); -+ va_end(ap); -+ exit(eval); -+} -+ -+void -+event_warn(const char *fmt, ...) -+{ -+ va_list ap; -+ -+ va_start(ap, fmt); -+ _warn_helper(_EVENT_LOG_WARN, errno, fmt, ap); -+ va_end(ap); -+} -+ -+void -+event_errx(int eval, const char *fmt, ...) -+{ -+ va_list ap; -+ -+ va_start(ap, fmt); -+ _warn_helper(_EVENT_LOG_ERR, -1, fmt, ap); -+ va_end(ap); -+ exit(eval); -+} -+ -+void -+event_warnx(const char *fmt, ...) -+{ -+ va_list ap; -+ -+ va_start(ap, fmt); -+ _warn_helper(_EVENT_LOG_WARN, -1, fmt, ap); -+ va_end(ap); -+} -+ -+void -+event_msgx(const char *fmt, ...) -+{ -+ va_list ap; -+ -+ va_start(ap, fmt); -+ _warn_helper(_EVENT_LOG_MSG, -1, fmt, ap); -+ va_end(ap); -+} -+ -+void -+_event_debugx(const char *fmt, ...) -+{ -+ va_list ap; -+ -+ va_start(ap, fmt); -+ _warn_helper(_EVENT_LOG_DEBUG, -1, fmt, ap); -+ va_end(ap); -+} -+ -+static void -+_warn_helper(int severity, int log_errno, const char *fmt, va_list ap) -+{ -+ char buf[1024]; -+ size_t len; -+ -+ if (fmt != NULL) -+ evutil_vsnprintf(buf, sizeof(buf), fmt, ap); -+ else -+ buf[0] = '\0'; -+ -+ if (log_errno >= 0) { -+ len = strlen(buf); -+ if (len < sizeof(buf) - 3) { -+ evutil_snprintf(buf + len, sizeof(buf) - len, ": %s", -+ strerror(log_errno)); -+ } -+ } -+ -+ event_log(severity, buf); -+} -+ -+static event_log_cb log_fn = NULL; -+ -+void -+event_set_log_callback(event_log_cb cb) -+{ -+ log_fn = cb; -+} -+ -+static void -+event_log(int severity, const char *msg) -+{ -+ if (log_fn) -+ log_fn(severity, msg); -+ else { -+ const char *severity_str; -+ switch (severity) { -+ case _EVENT_LOG_DEBUG: -+ severity_str = "debug"; -+ break; -+ case _EVENT_LOG_MSG: -+ severity_str = "msg"; -+ break; -+ case _EVENT_LOG_WARN: -+ severity_str = "warn"; -+ break; -+ case _EVENT_LOG_ERR: -+ severity_str = "err"; -+ break; -+ default: -+ severity_str = "???"; -+ break; -+ } -+ (void)fprintf(stderr, "[%s] %s\n", severity_str, msg); -+ } -+} -diff --git a/libevent/log.h b/libevent/log.h -new file mode 100644 -index 0000000..7bc6632 ---- /dev/null -+++ b/libevent/log.h -@@ -0,0 +1,51 @@ -+/* -+ * Copyright (c) 2000-2004 Niels Provos -+ * All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. The name of the author may not be used to endorse or promote products -+ * derived from this software without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR -+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES -+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. -+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, -+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT -+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF -+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+ */ -+#ifndef _LOG_H_ -+#define _LOG_H_ -+ -+#ifdef __GNUC__ -+#define EV_CHECK_FMT(a,b) __attribute__((format(printf, a, b))) -+#else -+#define EV_CHECK_FMT(a,b) -+#endif -+ -+void event_err(int eval, const char *fmt, ...) EV_CHECK_FMT(2,3); -+void event_warn(const char *fmt, ...) EV_CHECK_FMT(1,2); -+void event_errx(int eval, const char *fmt, ...) EV_CHECK_FMT(2,3); -+void event_warnx(const char *fmt, ...) EV_CHECK_FMT(1,2); -+void event_msgx(const char *fmt, ...) EV_CHECK_FMT(1,2); -+void _event_debugx(const char *fmt, ...) EV_CHECK_FMT(1,2); -+ -+#ifdef USE_DEBUG -+#define event_debug(x) _event_debugx x -+#else -+#define event_debug(x) do {;} while (0) -+#endif -+ -+#undef EV_CHECK_FMT -+ -+#endif -diff --git a/libevent/min_heap.h b/libevent/min_heap.h -new file mode 100644 -index 0000000..d47e563 ---- /dev/null -+++ b/libevent/min_heap.h -@@ -0,0 +1,139 @@ -+/* -+ * Copyright (c) 2006 Maxim Yegorushkin -+ * All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. The name of the author may not be used to endorse or promote products -+ * derived from this software without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR -+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES -+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. -+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, -+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT -+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF -+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+ */ -+#ifndef _MIN_HEAP_H_ -+#define _MIN_HEAP_H_ -+ -+#include "event.h" -+#include "evutil.h" -+ -+typedef struct min_heap -+{ -+ struct event** p; -+ unsigned n, a; -+} min_heap_t; -+ -+static inline void min_heap_ctor(min_heap_t* s); -+static inline void min_heap_dtor(min_heap_t* s); -+static inline void min_heap_elem_init(struct event* e); -+static inline int min_heap_elem_greater(struct event *a, struct event *b); -+static inline int min_heap_empty(min_heap_t* s); -+static inline unsigned min_heap_size(min_heap_t* s); -+static inline struct event* min_heap_top(min_heap_t* s); -+static inline int min_heap_reserve(min_heap_t* s, unsigned n); -+static inline int min_heap_push(min_heap_t* s, struct event* e); -+static inline struct event* min_heap_pop(min_heap_t* s); -+static inline int min_heap_erase(min_heap_t* s, struct event* e); -+static inline void min_heap_shift_up_(min_heap_t* s, unsigned hole_index, struct event* e); -+static inline void min_heap_shift_down_(min_heap_t* s, unsigned hole_index, struct event* e); -+ -+int min_heap_elem_greater(struct event *a, struct event *b) -+{ -+ return evutil_timercmp(&a->ev_timeout, &b->ev_timeout, >); -+} -+ -+void min_heap_ctor(min_heap_t* s) { s->p = 0; s->n = 0; s->a = 0; } -+void min_heap_dtor(min_heap_t* s) { free(s->p); } -+void min_heap_elem_init(struct event* e) { e->min_heap_idx = -1; } -+int min_heap_empty(min_heap_t* s) { return 0u == s->n; } -+unsigned min_heap_size(min_heap_t* s) { return s->n; } -+struct event* min_heap_top(min_heap_t* s) { return s->n ? *s->p : 0; } -+ -+int min_heap_push(min_heap_t* s, struct event* e) -+{ -+ if(min_heap_reserve(s, s->n + 1)) -+ return -1; -+ min_heap_shift_up_(s, s->n++, e); -+ return 0; -+} -+ -+struct event* min_heap_pop(min_heap_t* s) -+{ -+ if(s->n) -+ { -+ struct event* e = *s->p; -+ min_heap_shift_down_(s, 0u, s->p[--s->n]); -+ e->min_heap_idx = -1; -+ return e; -+ } -+ return 0; -+} -+ -+int min_heap_erase(min_heap_t* s, struct event* e) -+{ -+ if(((unsigned int)-1) != e->min_heap_idx) -+ { -+ min_heap_shift_down_(s, e->min_heap_idx, s->p[--s->n]); -+ e->min_heap_idx = -1; -+ return 0; -+ } -+ return -1; -+} -+ -+int min_heap_reserve(min_heap_t* s, unsigned n) -+{ -+ if(s->a < n) -+ { -+ struct event** p; -+ unsigned a = s->a ? s->a * 2 : 8; -+ if(a < n) -+ a = n; -+ if(!(p = (struct event**)realloc(s->p, a * sizeof *p))) -+ return -1; -+ s->p = p; -+ s->a = a; -+ } -+ return 0; -+} -+ -+void min_heap_shift_up_(min_heap_t* s, unsigned hole_index, struct event* e) -+{ -+ unsigned parent = (hole_index - 1) / 2; -+ while(hole_index && min_heap_elem_greater(s->p[parent], e)) -+ { -+ (s->p[hole_index] = s->p[parent])->min_heap_idx = hole_index; -+ hole_index = parent; -+ parent = (hole_index - 1) / 2; -+ } -+ (s->p[hole_index] = e)->min_heap_idx = hole_index; -+} -+ -+void min_heap_shift_down_(min_heap_t* s, unsigned hole_index, struct event* e) -+{ -+ unsigned min_child = 2 * (hole_index + 1); -+ while(min_child <= s->n) -+ { -+ min_child -= min_child == s->n || min_heap_elem_greater(s->p[min_child], s->p[min_child - 1]); -+ if(!(min_heap_elem_greater(e, s->p[min_child]))) -+ break; -+ (s->p[hole_index] = s->p[min_child])->min_heap_idx = hole_index; -+ hole_index = min_child; -+ min_child = 2 * (hole_index + 1); -+ } -+ min_heap_shift_up_(s, hole_index, e); -+} -+ -+#endif /* _MIN_HEAP_H_ */ -diff --git a/libevent/missing b/libevent/missing -new file mode 100644 -index 0000000..09edd88 ---- /dev/null -+++ b/libevent/missing -@@ -0,0 +1,357 @@ -+#! /bin/sh -+# Common stub for a few missing GNU programs while installing. -+ -+scriptversion=2005-02-08.22 -+ -+# Copyright (C) 1996, 1997, 1999, 2000, 2002, 2003, 2004, 2005 -+# Free Software Foundation, Inc. -+# Originally by Fran,cois Pinard , 1996. -+ -+# 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, 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. -+ -+# You should have received a copy of the GNU General Public License -+# along with this program; if not, write to the Free Software -+# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA -+# 02111-1307, USA. -+ -+# As a special exception to the GNU General Public License, if you -+# distribute this file as part of a program that contains a -+# configuration script generated by Autoconf, you may include it under -+# the same distribution terms that you use for the rest of that program. -+ -+if test $# -eq 0; then -+ echo 1>&2 "Try \`$0 --help' for more information" -+ exit 1 -+fi -+ -+run=: -+ -+# In the cases where this matters, `missing' is being run in the -+# srcdir already. -+if test -f configure.ac; then -+ configure_ac=configure.ac -+else -+ configure_ac=configure.in -+fi -+ -+msg="missing on your system" -+ -+case "$1" in -+--run) -+ # Try to run requested program, and just exit if it succeeds. -+ run= -+ shift -+ "$@" && exit 0 -+ # Exit code 63 means version mismatch. This often happens -+ # when the user try to use an ancient version of a tool on -+ # a file that requires a minimum version. In this case we -+ # we should proceed has if the program had been absent, or -+ # if --run hadn't been passed. -+ if test $? = 63; then -+ run=: -+ msg="probably too old" -+ fi -+ ;; -+ -+ -h|--h|--he|--hel|--help) -+ echo "\ -+$0 [OPTION]... PROGRAM [ARGUMENT]... -+ -+Handle \`PROGRAM [ARGUMENT]...' for when PROGRAM is missing, or return an -+error status if there is no known handling for PROGRAM. -+ -+Options: -+ -h, --help display this help and exit -+ -v, --version output version information and exit -+ --run try to run the given command, and emulate it if it fails -+ -+Supported PROGRAM values: -+ aclocal touch file \`aclocal.m4' -+ autoconf touch file \`configure' -+ autoheader touch file \`config.h.in' -+ automake touch all \`Makefile.in' files -+ bison create \`y.tab.[ch]', if possible, from existing .[ch] -+ flex create \`lex.yy.c', if possible, from existing .c -+ help2man touch the output file -+ lex create \`lex.yy.c', if possible, from existing .c -+ makeinfo touch the output file -+ tar try tar, gnutar, gtar, then tar without non-portable flags -+ yacc create \`y.tab.[ch]', if possible, from existing .[ch] -+ -+Send bug reports to ." -+ exit $? -+ ;; -+ -+ -v|--v|--ve|--ver|--vers|--versi|--versio|--version) -+ echo "missing $scriptversion (GNU Automake)" -+ exit $? -+ ;; -+ -+ -*) -+ echo 1>&2 "$0: Unknown \`$1' option" -+ echo 1>&2 "Try \`$0 --help' for more information" -+ exit 1 -+ ;; -+ -+esac -+ -+# Now exit if we have it, but it failed. Also exit now if we -+# don't have it and --version was passed (most likely to detect -+# the program). -+case "$1" in -+ lex|yacc) -+ # Not GNU programs, they don't have --version. -+ ;; -+ -+ tar) -+ if test -n "$run"; then -+ echo 1>&2 "ERROR: \`tar' requires --run" -+ exit 1 -+ elif test "x$2" = "x--version" || test "x$2" = "x--help"; then -+ exit 1 -+ fi -+ ;; -+ -+ *) -+ if test -z "$run" && ($1 --version) > /dev/null 2>&1; then -+ # We have it, but it failed. -+ exit 1 -+ elif test "x$2" = "x--version" || test "x$2" = "x--help"; then -+ # Could not run --version or --help. This is probably someone -+ # running `$TOOL --version' or `$TOOL --help' to check whether -+ # $TOOL exists and not knowing $TOOL uses missing. -+ exit 1 -+ fi -+ ;; -+esac -+ -+# If it does not exist, or fails to run (possibly an outdated version), -+# try to emulate it. -+case "$1" in -+ aclocal*) -+ echo 1>&2 "\ -+WARNING: \`$1' is $msg. You should only need it if -+ you modified \`acinclude.m4' or \`${configure_ac}'. You might want -+ to install the \`Automake' and \`Perl' packages. Grab them from -+ any GNU archive site." -+ touch aclocal.m4 -+ ;; -+ -+ autoconf) -+ echo 1>&2 "\ -+WARNING: \`$1' is $msg. You should only need it if -+ you modified \`${configure_ac}'. You might want to install the -+ \`Autoconf' and \`GNU m4' packages. Grab them from any GNU -+ archive site." -+ touch configure -+ ;; -+ -+ autoheader) -+ echo 1>&2 "\ -+WARNING: \`$1' is $msg. You should only need it if -+ you modified \`acconfig.h' or \`${configure_ac}'. You might want -+ to install the \`Autoconf' and \`GNU m4' packages. Grab them -+ from any GNU archive site." -+ files=`sed -n 's/^[ ]*A[CM]_CONFIG_HEADER(\([^)]*\)).*/\1/p' ${configure_ac}` -+ test -z "$files" && files="config.h" -+ touch_files= -+ for f in $files; do -+ case "$f" in -+ *:*) touch_files="$touch_files "`echo "$f" | -+ sed -e 's/^[^:]*://' -e 's/:.*//'`;; -+ *) touch_files="$touch_files $f.in";; -+ esac -+ done -+ touch $touch_files -+ ;; -+ -+ automake*) -+ echo 1>&2 "\ -+WARNING: \`$1' is $msg. You should only need it if -+ you modified \`Makefile.am', \`acinclude.m4' or \`${configure_ac}'. -+ You might want to install the \`Automake' and \`Perl' packages. -+ Grab them from any GNU archive site." -+ find . -type f -name Makefile.am -print | -+ sed 's/\.am$/.in/' | -+ while read f; do touch "$f"; done -+ ;; -+ -+ autom4te) -+ echo 1>&2 "\ -+WARNING: \`$1' is needed, but is $msg. -+ You might have modified some files without having the -+ proper tools for further handling them. -+ You can get \`$1' as part of \`Autoconf' from any GNU -+ archive site." -+ -+ file=`echo "$*" | sed -n 's/.*--output[ =]*\([^ ]*\).*/\1/p'` -+ test -z "$file" && file=`echo "$*" | sed -n 's/.*-o[ ]*\([^ ]*\).*/\1/p'` -+ if test -f "$file"; then -+ touch $file -+ else -+ test -z "$file" || exec >$file -+ echo "#! /bin/sh" -+ echo "# Created by GNU Automake missing as a replacement of" -+ echo "# $ $@" -+ echo "exit 0" -+ chmod +x $file -+ exit 1 -+ fi -+ ;; -+ -+ bison|yacc) -+ echo 1>&2 "\ -+WARNING: \`$1' $msg. You should only need it if -+ you modified a \`.y' file. You may need the \`Bison' package -+ in order for those modifications to take effect. You can get -+ \`Bison' from any GNU archive site." -+ rm -f y.tab.c y.tab.h -+ if [ $# -ne 1 ]; then -+ eval LASTARG="\${$#}" -+ case "$LASTARG" in -+ *.y) -+ SRCFILE=`echo "$LASTARG" | sed 's/y$/c/'` -+ if [ -f "$SRCFILE" ]; then -+ cp "$SRCFILE" y.tab.c -+ fi -+ SRCFILE=`echo "$LASTARG" | sed 's/y$/h/'` -+ if [ -f "$SRCFILE" ]; then -+ cp "$SRCFILE" y.tab.h -+ fi -+ ;; -+ esac -+ fi -+ if [ ! -f y.tab.h ]; then -+ echo >y.tab.h -+ fi -+ if [ ! -f y.tab.c ]; then -+ echo 'main() { return 0; }' >y.tab.c -+ fi -+ ;; -+ -+ lex|flex) -+ echo 1>&2 "\ -+WARNING: \`$1' is $msg. You should only need it if -+ you modified a \`.l' file. You may need the \`Flex' package -+ in order for those modifications to take effect. You can get -+ \`Flex' from any GNU archive site." -+ rm -f lex.yy.c -+ if [ $# -ne 1 ]; then -+ eval LASTARG="\${$#}" -+ case "$LASTARG" in -+ *.l) -+ SRCFILE=`echo "$LASTARG" | sed 's/l$/c/'` -+ if [ -f "$SRCFILE" ]; then -+ cp "$SRCFILE" lex.yy.c -+ fi -+ ;; -+ esac -+ fi -+ if [ ! -f lex.yy.c ]; then -+ echo 'main() { return 0; }' >lex.yy.c -+ fi -+ ;; -+ -+ help2man) -+ echo 1>&2 "\ -+WARNING: \`$1' is $msg. You should only need it if -+ you modified a dependency of a manual page. You may need the -+ \`Help2man' package in order for those modifications to take -+ effect. You can get \`Help2man' from any GNU archive site." -+ -+ file=`echo "$*" | sed -n 's/.*-o \([^ ]*\).*/\1/p'` -+ if test -z "$file"; then -+ file=`echo "$*" | sed -n 's/.*--output=\([^ ]*\).*/\1/p'` -+ fi -+ if [ -f "$file" ]; then -+ touch $file -+ else -+ test -z "$file" || exec >$file -+ echo ".ab help2man is required to generate this page" -+ exit 1 -+ fi -+ ;; -+ -+ makeinfo) -+ echo 1>&2 "\ -+WARNING: \`$1' is $msg. You should only need it if -+ you modified a \`.texi' or \`.texinfo' file, or any other file -+ indirectly affecting the aspect of the manual. The spurious -+ call might also be the consequence of using a buggy \`make' (AIX, -+ DU, IRIX). You might want to install the \`Texinfo' package or -+ the \`GNU make' package. Grab either from any GNU archive site." -+ # The file to touch is that specified with -o ... -+ file=`echo "$*" | sed -n 's/.*-o \([^ ]*\).*/\1/p'` -+ if test -z "$file"; then -+ # ... or it is the one specified with @setfilename ... -+ infile=`echo "$*" | sed 's/.* \([^ ]*\) *$/\1/'` -+ file=`sed -n '/^@setfilename/ { s/.* \([^ ]*\) *$/\1/; p; q; }' $infile` -+ # ... or it is derived from the source name (dir/f.texi becomes f.info) -+ test -z "$file" && file=`echo "$infile" | sed 's,.*/,,;s,.[^.]*$,,'`.info -+ fi -+ touch $file -+ ;; -+ -+ tar) -+ shift -+ -+ # We have already tried tar in the generic part. -+ # Look for gnutar/gtar before invocation to avoid ugly error -+ # messages. -+ if (gnutar --version > /dev/null 2>&1); then -+ gnutar "$@" && exit 0 -+ fi -+ if (gtar --version > /dev/null 2>&1); then -+ gtar "$@" && exit 0 -+ fi -+ firstarg="$1" -+ if shift; then -+ case "$firstarg" in -+ *o*) -+ firstarg=`echo "$firstarg" | sed s/o//` -+ tar "$firstarg" "$@" && exit 0 -+ ;; -+ esac -+ case "$firstarg" in -+ *h*) -+ firstarg=`echo "$firstarg" | sed s/h//` -+ tar "$firstarg" "$@" && exit 0 -+ ;; -+ esac -+ fi -+ -+ echo 1>&2 "\ -+WARNING: I can't seem to be able to run \`tar' with the given arguments. -+ You may want to install GNU tar or Free paxutils, or check the -+ command line arguments." -+ exit 1 -+ ;; -+ -+ *) -+ echo 1>&2 "\ -+WARNING: \`$1' is needed, and is $msg. -+ You might have modified some files without having the -+ proper tools for further handling them. Check the \`README' file, -+ it often tells you about the needed prerequisites for installing -+ this package. You may also peek at any GNU archive site, in case -+ some other package would contain this missing \`$1' program." -+ exit 1 -+ ;; -+esac -+ -+exit 0 -+ -+# Local variables: -+# eval: (add-hook 'write-file-hooks 'time-stamp) -+# time-stamp-start: "scriptversion=" -+# time-stamp-format: "%:y-%02m-%02d.%02H" -+# time-stamp-end: "$" -+# End: -diff --git a/libevent/poll.c b/libevent/poll.c -new file mode 100644 -index 0000000..b67c6ff ---- /dev/null -+++ b/libevent/poll.c -@@ -0,0 +1,374 @@ -+/* $OpenBSD: poll.c,v 1.2 2002/06/25 15:50:15 mickey Exp $ */ -+ -+/* -+ * Copyright 2000-2003 Niels Provos -+ * All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. The name of the author may not be used to endorse or promote products -+ * derived from this software without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR -+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES -+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. -+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, -+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT -+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF -+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+ */ -+#ifdef HAVE_CONFIG_H -+#include "config.h" -+#endif -+ -+#include -+#ifdef HAVE_SYS_TIME_H -+#include -+#else -+#include -+#endif -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#ifdef CHECK_INVARIANTS -+#include -+#endif -+ -+#include "event.h" -+#include "event-internal.h" -+#include "evsignal.h" -+#include "log.h" -+ -+struct pollop { -+ int event_count; /* Highest number alloc */ -+ int nfds; /* Size of event_* */ -+ int fd_count; /* Size of idxplus1_by_fd */ -+ struct pollfd *event_set; -+ struct event **event_r_back; -+ struct event **event_w_back; -+ int *idxplus1_by_fd; /* Index into event_set by fd; we add 1 so -+ * that 0 (which is easy to memset) can mean -+ * "no entry." */ -+}; -+ -+static void *poll_init (struct event_base *); -+static int poll_add (void *, struct event *); -+static int poll_del (void *, struct event *); -+static int poll_dispatch (struct event_base *, void *, struct timeval *); -+static void poll_dealloc (struct event_base *, void *); -+ -+const struct eventop pollops = { -+ "poll", -+ poll_init, -+ poll_add, -+ poll_del, -+ poll_dispatch, -+ poll_dealloc, -+ 0 -+}; -+ -+static void * -+poll_init(struct event_base *base) -+{ -+ struct pollop *pollop; -+ -+ /* Disable poll when this environment variable is set */ -+ if (getenv("EVENT_NOPOLL")) -+ return (NULL); -+ -+ if (!(pollop = calloc(1, sizeof(struct pollop)))) -+ return (NULL); -+ -+ evsignal_init(base); -+ -+ return (pollop); -+} -+ -+#ifdef CHECK_INVARIANTS -+static void -+poll_check_ok(struct pollop *pop) -+{ -+ int i, idx; -+ struct event *ev; -+ -+ for (i = 0; i < pop->fd_count; ++i) { -+ idx = pop->idxplus1_by_fd[i]-1; -+ if (idx < 0) -+ continue; -+ assert(pop->event_set[idx].fd == i); -+ if (pop->event_set[idx].events & POLLIN) { -+ ev = pop->event_r_back[idx]; -+ assert(ev); -+ assert(ev->ev_events & EV_READ); -+ assert(ev->ev_fd == i); -+ } -+ if (pop->event_set[idx].events & POLLOUT) { -+ ev = pop->event_w_back[idx]; -+ assert(ev); -+ assert(ev->ev_events & EV_WRITE); -+ assert(ev->ev_fd == i); -+ } -+ } -+ for (i = 0; i < pop->nfds; ++i) { -+ struct pollfd *pfd = &pop->event_set[i]; -+ assert(pop->idxplus1_by_fd[pfd->fd] == i+1); -+ } -+} -+#else -+#define poll_check_ok(pop) -+#endif -+ -+static int -+poll_dispatch(struct event_base *base, void *arg, struct timeval *tv) -+{ -+ int res, i, msec = -1, nfds; -+ struct pollop *pop = arg; -+ -+ poll_check_ok(pop); -+ -+ if (tv != NULL) -+ msec = tv->tv_sec * 1000 + (tv->tv_usec + 999) / 1000; -+ -+ nfds = pop->nfds; -+ res = poll(pop->event_set, nfds, msec); -+ -+ if (res == -1) { -+ if (errno != EINTR) { -+ event_warn("poll"); -+ return (-1); -+ } -+ -+ evsignal_process(base); -+ return (0); -+ } else if (base->sig.evsignal_caught) { -+ evsignal_process(base); -+ } -+ -+ event_debug(("%s: poll reports %d", __func__, res)); -+ -+ if (res == 0) -+ return (0); -+ -+ for (i = 0; i < nfds; i++) { -+ int what = pop->event_set[i].revents; -+ struct event *r_ev = NULL, *w_ev = NULL; -+ if (!what) -+ continue; -+ -+ res = 0; -+ -+ /* If the file gets closed notify */ -+ if (what & (POLLHUP|POLLERR)) -+ what |= POLLIN|POLLOUT; -+ if (what & POLLIN) { -+ res |= EV_READ; -+ r_ev = pop->event_r_back[i]; -+ } -+ if (what & POLLOUT) { -+ res |= EV_WRITE; -+ w_ev = pop->event_w_back[i]; -+ } -+ if (res == 0) -+ continue; -+ -+ if (r_ev && (res & r_ev->ev_events)) { -+ event_active(r_ev, res & r_ev->ev_events, 1); -+ } -+ if (w_ev && w_ev != r_ev && (res & w_ev->ev_events)) { -+ event_active(w_ev, res & w_ev->ev_events, 1); -+ } -+ } -+ -+ return (0); -+} -+ -+static int -+poll_add(void *arg, struct event *ev) -+{ -+ struct pollop *pop = arg; -+ struct pollfd *pfd = NULL; -+ int i; -+ -+ if (ev->ev_events & EV_SIGNAL) -+ return (evsignal_add(ev)); -+ if (!(ev->ev_events & (EV_READ|EV_WRITE))) -+ return (0); -+ -+ poll_check_ok(pop); -+ if (pop->nfds + 1 >= pop->event_count) { -+ struct pollfd *tmp_event_set; -+ struct event **tmp_event_r_back; -+ struct event **tmp_event_w_back; -+ int tmp_event_count; -+ -+ if (pop->event_count < 32) -+ tmp_event_count = 32; -+ else -+ tmp_event_count = pop->event_count * 2; -+ -+ /* We need more file descriptors */ -+ tmp_event_set = realloc(pop->event_set, -+ tmp_event_count * sizeof(struct pollfd)); -+ if (tmp_event_set == NULL) { -+ event_warn("realloc"); -+ return (-1); -+ } -+ pop->event_set = tmp_event_set; -+ -+ tmp_event_r_back = realloc(pop->event_r_back, -+ tmp_event_count * sizeof(struct event *)); -+ if (tmp_event_r_back == NULL) { -+ /* event_set overallocated; that's okay. */ -+ event_warn("realloc"); -+ return (-1); -+ } -+ pop->event_r_back = tmp_event_r_back; -+ -+ tmp_event_w_back = realloc(pop->event_w_back, -+ tmp_event_count * sizeof(struct event *)); -+ if (tmp_event_w_back == NULL) { -+ /* event_set and event_r_back overallocated; that's -+ * okay. */ -+ event_warn("realloc"); -+ return (-1); -+ } -+ pop->event_w_back = tmp_event_w_back; -+ -+ pop->event_count = tmp_event_count; -+ } -+ if (ev->ev_fd >= pop->fd_count) { -+ int *tmp_idxplus1_by_fd; -+ int new_count; -+ if (pop->fd_count < 32) -+ new_count = 32; -+ else -+ new_count = pop->fd_count * 2; -+ while (new_count <= ev->ev_fd) -+ new_count *= 2; -+ tmp_idxplus1_by_fd = -+ realloc(pop->idxplus1_by_fd, new_count * sizeof(int)); -+ if (tmp_idxplus1_by_fd == NULL) { -+ event_warn("realloc"); -+ return (-1); -+ } -+ pop->idxplus1_by_fd = tmp_idxplus1_by_fd; -+ memset(pop->idxplus1_by_fd + pop->fd_count, -+ 0, sizeof(int)*(new_count - pop->fd_count)); -+ pop->fd_count = new_count; -+ } -+ -+ i = pop->idxplus1_by_fd[ev->ev_fd] - 1; -+ if (i >= 0) { -+ pfd = &pop->event_set[i]; -+ } else { -+ i = pop->nfds++; -+ pfd = &pop->event_set[i]; -+ pfd->events = 0; -+ pfd->fd = ev->ev_fd; -+ pop->event_w_back[i] = pop->event_r_back[i] = NULL; -+ pop->idxplus1_by_fd[ev->ev_fd] = i + 1; -+ } -+ -+ pfd->revents = 0; -+ if (ev->ev_events & EV_WRITE) { -+ pfd->events |= POLLOUT; -+ pop->event_w_back[i] = ev; -+ } -+ if (ev->ev_events & EV_READ) { -+ pfd->events |= POLLIN; -+ pop->event_r_back[i] = ev; -+ } -+ poll_check_ok(pop); -+ -+ return (0); -+} -+ -+/* -+ * Nothing to be done here. -+ */ -+ -+static int -+poll_del(void *arg, struct event *ev) -+{ -+ struct pollop *pop = arg; -+ struct pollfd *pfd = NULL; -+ int i; -+ -+ if (ev->ev_events & EV_SIGNAL) -+ return (evsignal_del(ev)); -+ -+ if (!(ev->ev_events & (EV_READ|EV_WRITE))) -+ return (0); -+ -+ poll_check_ok(pop); -+ i = pop->idxplus1_by_fd[ev->ev_fd] - 1; -+ if (i < 0) -+ return (-1); -+ -+ /* Do we still want to read or write? */ -+ pfd = &pop->event_set[i]; -+ if (ev->ev_events & EV_READ) { -+ pfd->events &= ~POLLIN; -+ pop->event_r_back[i] = NULL; -+ } -+ if (ev->ev_events & EV_WRITE) { -+ pfd->events &= ~POLLOUT; -+ pop->event_w_back[i] = NULL; -+ } -+ poll_check_ok(pop); -+ if (pfd->events) -+ /* Another event cares about that fd. */ -+ return (0); -+ -+ /* Okay, so we aren't interested in that fd anymore. */ -+ pop->idxplus1_by_fd[ev->ev_fd] = 0; -+ -+ --pop->nfds; -+ if (i != pop->nfds) { -+ /* -+ * Shift the last pollfd down into the now-unoccupied -+ * position. -+ */ -+ memcpy(&pop->event_set[i], &pop->event_set[pop->nfds], -+ sizeof(struct pollfd)); -+ pop->event_r_back[i] = pop->event_r_back[pop->nfds]; -+ pop->event_w_back[i] = pop->event_w_back[pop->nfds]; -+ pop->idxplus1_by_fd[pop->event_set[i].fd] = i + 1; -+ } -+ -+ poll_check_ok(pop); -+ return (0); -+} -+ -+static void -+poll_dealloc(struct event_base *base, void *arg) -+{ -+ struct pollop *pop = arg; -+ -+ evsignal_dealloc(base); -+ if (pop->event_set) -+ free(pop->event_set); -+ if (pop->event_r_back) -+ free(pop->event_r_back); -+ if (pop->event_w_back) -+ free(pop->event_w_back); -+ if (pop->idxplus1_by_fd) -+ free(pop->idxplus1_by_fd); -+ -+ memset(pop, 0, sizeof(struct pollop)); -+ free(pop); -+} -diff --git a/libevent/select.c b/libevent/select.c -new file mode 100644 -index 0000000..7faafe4 ---- /dev/null -+++ b/libevent/select.c -@@ -0,0 +1,352 @@ -+/* $OpenBSD: select.c,v 1.2 2002/06/25 15:50:15 mickey Exp $ */ -+ -+/* -+ * Copyright 2000-2002 Niels Provos -+ * All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. The name of the author may not be used to endorse or promote products -+ * derived from this software without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR -+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES -+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. -+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, -+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT -+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF -+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+ */ -+#ifdef HAVE_CONFIG_H -+#include "config.h" -+#endif -+ -+#include -+#ifdef HAVE_SYS_TIME_H -+#include -+#else -+#include -+#endif -+#ifdef HAVE_SYS_SELECT_H -+#include -+#endif -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#ifdef CHECK_INVARIANTS -+#include -+#endif -+ -+#include "event.h" -+#include "event-internal.h" -+#include "evsignal.h" -+#include "log.h" -+ -+#ifndef howmany -+#define howmany(x, y) (((x)+((y)-1))/(y)) -+#endif -+ -+struct selectop { -+ int event_fds; /* Highest fd in fd set */ -+ int event_fdsz; -+ fd_set *event_readset_in; -+ fd_set *event_writeset_in; -+ fd_set *event_readset_out; -+ fd_set *event_writeset_out; -+ struct event **event_r_by_fd; -+ struct event **event_w_by_fd; -+}; -+ -+static void *select_init (struct event_base *); -+static int select_add (void *, struct event *); -+static int select_del (void *, struct event *); -+static int select_dispatch (struct event_base *, void *, struct timeval *); -+static void select_dealloc (struct event_base *, void *); -+ -+const struct eventop selectops = { -+ "select", -+ select_init, -+ select_add, -+ select_del, -+ select_dispatch, -+ select_dealloc, -+ 0 -+}; -+ -+static int select_resize(struct selectop *sop, int fdsz); -+ -+static void * -+select_init(struct event_base *base) -+{ -+ struct selectop *sop; -+ -+ /* Disable select when this environment variable is set */ -+ if (getenv("EVENT_NOSELECT")) -+ return (NULL); -+ -+ if (!(sop = calloc(1, sizeof(struct selectop)))) -+ return (NULL); -+ -+ select_resize(sop, howmany(32 + 1, NFDBITS)*sizeof(fd_mask)); -+ -+ evsignal_init(base); -+ -+ return (sop); -+} -+ -+#ifdef CHECK_INVARIANTS -+static void -+check_selectop(struct selectop *sop) -+{ -+ int i; -+ for (i = 0; i <= sop->event_fds; ++i) { -+ if (FD_ISSET(i, sop->event_readset_in)) { -+ assert(sop->event_r_by_fd[i]); -+ assert(sop->event_r_by_fd[i]->ev_events & EV_READ); -+ assert(sop->event_r_by_fd[i]->ev_fd == i); -+ } else { -+ assert(! sop->event_r_by_fd[i]); -+ } -+ if (FD_ISSET(i, sop->event_writeset_in)) { -+ assert(sop->event_w_by_fd[i]); -+ assert(sop->event_w_by_fd[i]->ev_events & EV_WRITE); -+ assert(sop->event_w_by_fd[i]->ev_fd == i); -+ } else { -+ assert(! sop->event_w_by_fd[i]); -+ } -+ } -+ -+} -+#else -+#define check_selectop(sop) do { (void) sop; } while (0) -+#endif -+ -+static int -+select_dispatch(struct event_base *base, void *arg, struct timeval *tv) -+{ -+ int res, i; -+ struct selectop *sop = arg; -+ -+ check_selectop(sop); -+ -+ memcpy(sop->event_readset_out, sop->event_readset_in, -+ sop->event_fdsz); -+ memcpy(sop->event_writeset_out, sop->event_writeset_in, -+ sop->event_fdsz); -+ -+ res = select(sop->event_fds + 1, sop->event_readset_out, -+ sop->event_writeset_out, NULL, tv); -+ -+ check_selectop(sop); -+ -+ if (res == -1) { -+ if (errno != EINTR) { -+ event_warn("select"); -+ return (-1); -+ } -+ -+ evsignal_process(base); -+ return (0); -+ } else if (base->sig.evsignal_caught) { -+ evsignal_process(base); -+ } -+ -+ event_debug(("%s: select reports %d", __func__, res)); -+ -+ check_selectop(sop); -+ for (i = 0; i <= sop->event_fds; ++i) { -+ struct event *r_ev = NULL, *w_ev = NULL; -+ res = 0; -+ if (FD_ISSET(i, sop->event_readset_out)) { -+ r_ev = sop->event_r_by_fd[i]; -+ res |= EV_READ; -+ } -+ if (FD_ISSET(i, sop->event_writeset_out)) { -+ w_ev = sop->event_w_by_fd[i]; -+ res |= EV_WRITE; -+ } -+ if (r_ev && (res & r_ev->ev_events)) { -+ event_active(r_ev, res & r_ev->ev_events, 1); -+ } -+ if (w_ev && w_ev != r_ev && (res & w_ev->ev_events)) { -+ event_active(w_ev, res & w_ev->ev_events, 1); -+ } -+ } -+ check_selectop(sop); -+ -+ return (0); -+} -+ -+ -+static int -+select_resize(struct selectop *sop, int fdsz) -+{ -+ int n_events, n_events_old; -+ -+ fd_set *readset_in = NULL; -+ fd_set *writeset_in = NULL; -+ fd_set *readset_out = NULL; -+ fd_set *writeset_out = NULL; -+ struct event **r_by_fd = NULL; -+ struct event **w_by_fd = NULL; -+ -+ n_events = (fdsz/sizeof(fd_mask)) * NFDBITS; -+ n_events_old = (sop->event_fdsz/sizeof(fd_mask)) * NFDBITS; -+ -+ if (sop->event_readset_in) -+ check_selectop(sop); -+ -+ if ((readset_in = realloc(sop->event_readset_in, fdsz)) == NULL) -+ goto error; -+ sop->event_readset_in = readset_in; -+ if ((readset_out = realloc(sop->event_readset_out, fdsz)) == NULL) -+ goto error; -+ sop->event_readset_out = readset_out; -+ if ((writeset_in = realloc(sop->event_writeset_in, fdsz)) == NULL) -+ goto error; -+ sop->event_writeset_in = writeset_in; -+ if ((writeset_out = realloc(sop->event_writeset_out, fdsz)) == NULL) -+ goto error; -+ sop->event_writeset_out = writeset_out; -+ if ((r_by_fd = realloc(sop->event_r_by_fd, -+ n_events*sizeof(struct event*))) == NULL) -+ goto error; -+ sop->event_r_by_fd = r_by_fd; -+ if ((w_by_fd = realloc(sop->event_w_by_fd, -+ n_events * sizeof(struct event*))) == NULL) -+ goto error; -+ sop->event_w_by_fd = w_by_fd; -+ -+ memset((char *)sop->event_readset_in + sop->event_fdsz, 0, -+ fdsz - sop->event_fdsz); -+ memset((char *)sop->event_writeset_in + sop->event_fdsz, 0, -+ fdsz - sop->event_fdsz); -+ memset(sop->event_r_by_fd + n_events_old, 0, -+ (n_events-n_events_old) * sizeof(struct event*)); -+ memset(sop->event_w_by_fd + n_events_old, 0, -+ (n_events-n_events_old) * sizeof(struct event*)); -+ -+ sop->event_fdsz = fdsz; -+ check_selectop(sop); -+ -+ return (0); -+ -+ error: -+ event_warn("malloc"); -+ return (-1); -+} -+ -+ -+static int -+select_add(void *arg, struct event *ev) -+{ -+ struct selectop *sop = arg; -+ -+ if (ev->ev_events & EV_SIGNAL) -+ return (evsignal_add(ev)); -+ -+ check_selectop(sop); -+ /* -+ * Keep track of the highest fd, so that we can calculate the size -+ * of the fd_sets for select(2) -+ */ -+ if (sop->event_fds < ev->ev_fd) { -+ int fdsz = sop->event_fdsz; -+ -+ if (fdsz < sizeof(fd_mask)) -+ fdsz = sizeof(fd_mask); -+ -+ while (fdsz < -+ (howmany(ev->ev_fd + 1, NFDBITS) * sizeof(fd_mask))) -+ fdsz *= 2; -+ -+ if (fdsz != sop->event_fdsz) { -+ if (select_resize(sop, fdsz)) { -+ check_selectop(sop); -+ return (-1); -+ } -+ } -+ -+ sop->event_fds = ev->ev_fd; -+ } -+ -+ if (ev->ev_events & EV_READ) { -+ FD_SET(ev->ev_fd, sop->event_readset_in); -+ sop->event_r_by_fd[ev->ev_fd] = ev; -+ } -+ if (ev->ev_events & EV_WRITE) { -+ FD_SET(ev->ev_fd, sop->event_writeset_in); -+ sop->event_w_by_fd[ev->ev_fd] = ev; -+ } -+ check_selectop(sop); -+ -+ return (0); -+} -+ -+/* -+ * Nothing to be done here. -+ */ -+ -+static int -+select_del(void *arg, struct event *ev) -+{ -+ struct selectop *sop = arg; -+ -+ check_selectop(sop); -+ if (ev->ev_events & EV_SIGNAL) -+ return (evsignal_del(ev)); -+ -+ if (sop->event_fds < ev->ev_fd) { -+ check_selectop(sop); -+ return (0); -+ } -+ -+ if (ev->ev_events & EV_READ) { -+ FD_CLR(ev->ev_fd, sop->event_readset_in); -+ sop->event_r_by_fd[ev->ev_fd] = NULL; -+ } -+ -+ if (ev->ev_events & EV_WRITE) { -+ FD_CLR(ev->ev_fd, sop->event_writeset_in); -+ sop->event_w_by_fd[ev->ev_fd] = NULL; -+ } -+ -+ check_selectop(sop); -+ return (0); -+} -+ -+static void -+select_dealloc(struct event_base *base, void *arg) -+{ -+ struct selectop *sop = arg; -+ -+ evsignal_dealloc(base); -+ if (sop->event_readset_in) -+ free(sop->event_readset_in); -+ if (sop->event_writeset_in) -+ free(sop->event_writeset_in); -+ if (sop->event_readset_out) -+ free(sop->event_readset_out); -+ if (sop->event_writeset_out) -+ free(sop->event_writeset_out); -+ if (sop->event_r_by_fd) -+ free(sop->event_r_by_fd); -+ if (sop->event_w_by_fd) -+ free(sop->event_w_by_fd); -+ -+ memset(sop, 0, sizeof(struct selectop)); -+ free(sop); -+} -diff --git a/libevent/signal.c b/libevent/signal.c -new file mode 100644 -index 0000000..bcaa3f9 ---- /dev/null -+++ b/libevent/signal.c -@@ -0,0 +1,347 @@ -+/* $OpenBSD: select.c,v 1.2 2002/06/25 15:50:15 mickey Exp $ */ -+ -+/* -+ * Copyright 2000-2002 Niels Provos -+ * All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. The name of the author may not be used to endorse or promote products -+ * derived from this software without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR -+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES -+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. -+ * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, -+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT -+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF -+ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+ */ -+#ifdef HAVE_CONFIG_H -+#include "config.h" -+#endif -+ -+#ifdef WIN32 -+#define WIN32_LEAN_AND_MEAN -+#include -+#include -+#undef WIN32_LEAN_AND_MEAN -+#endif -+#include -+#ifdef HAVE_SYS_TIME_H -+#include -+#endif -+#include -+#ifdef HAVE_SYS_SOCKET_H -+#include -+#endif -+#include -+#include -+#include -+#include -+#ifdef HAVE_UNISTD_H -+#include -+#endif -+#include -+#ifdef HAVE_FCNTL_H -+#include -+#endif -+#include -+ -+#include "event.h" -+#include "event-internal.h" -+#include "evsignal.h" -+#include "evutil.h" -+#include "log.h" -+ -+struct event_base *evsignal_base = NULL; -+ -+static void evsignal_handler(int sig); -+ -+/* Callback for when the signal handler write a byte to our signaling socket */ -+static void -+evsignal_cb(int fd, short what, void *arg) -+{ -+ static char signals[100]; -+#ifdef WIN32 -+ SSIZE_T n; -+#else -+ ssize_t n; -+#endif -+ -+ n = recv(fd, signals, sizeof(signals), 0); -+ if (n == -1) -+ event_err(1, "%s: read", __func__); -+} -+ -+#ifdef HAVE_SETFD -+#define FD_CLOSEONEXEC(x) do { \ -+ if (fcntl(x, F_SETFD, 1) == -1) \ -+ event_warn("fcntl(%d, F_SETFD)", x); \ -+} while (0) -+#else -+#define FD_CLOSEONEXEC(x) -+#endif -+ -+void -+evsignal_init(struct event_base *base) -+{ -+ int i; -+ -+ /* -+ * Our signal handler is going to write to one end of the socket -+ * pair to wake up our event loop. The event loop then scans for -+ * signals that got delivered. -+ */ -+ if (evutil_socketpair( -+ AF_UNIX, SOCK_STREAM, 0, base->sig.ev_signal_pair) == -1) -+ event_err(1, "%s: socketpair", __func__); -+ -+ FD_CLOSEONEXEC(base->sig.ev_signal_pair[0]); -+ FD_CLOSEONEXEC(base->sig.ev_signal_pair[1]); -+ base->sig.sh_old = NULL; -+ base->sig.sh_old_max = 0; -+ base->sig.evsignal_caught = 0; -+ memset(&base->sig.evsigcaught, 0, sizeof(sig_atomic_t)*NSIG); -+ /* initialize the queues for all events */ -+ for (i = 0; i < NSIG; ++i) -+ TAILQ_INIT(&base->sig.evsigevents[i]); -+ -+ evutil_make_socket_nonblocking(base->sig.ev_signal_pair[0]); -+ -+ event_set(&base->sig.ev_signal, base->sig.ev_signal_pair[1], -+ EV_READ | EV_PERSIST, evsignal_cb, &base->sig.ev_signal); -+ base->sig.ev_signal.ev_base = base; -+ base->sig.ev_signal.ev_flags |= EVLIST_INTERNAL; -+} -+ -+/* Helper: set the signal handler for evsignal to handler in base, so that -+ * we can restore the original handler when we clear the current one. */ -+int -+_evsignal_set_handler(struct event_base *base, -+ int evsignal, void (*handler)(int)) -+{ -+#ifdef HAVE_SIGACTION -+ struct sigaction sa; -+#else -+ ev_sighandler_t sh; -+#endif -+ struct evsignal_info *sig = &base->sig; -+ void *p; -+ -+ /* -+ * resize saved signal handler array up to the highest signal number. -+ * a dynamic array is used to keep footprint on the low side. -+ */ -+ if (evsignal >= sig->sh_old_max) { -+ int new_max = evsignal + 1; -+ event_debug(("%s: evsignal (%d) >= sh_old_max (%d), resizing", -+ __func__, evsignal, sig->sh_old_max)); -+ p = realloc(sig->sh_old, new_max * sizeof(*sig->sh_old)); -+ if (p == NULL) { -+ event_warn("realloc"); -+ return (-1); -+ } -+ -+ memset((char *)p + sig->sh_old_max * sizeof(*sig->sh_old), -+ 0, (new_max - sig->sh_old_max) * sizeof(*sig->sh_old)); -+ -+ sig->sh_old_max = new_max; -+ sig->sh_old = p; -+ } -+ -+ /* allocate space for previous handler out of dynamic array */ -+ sig->sh_old[evsignal] = malloc(sizeof *sig->sh_old[evsignal]); -+ if (sig->sh_old[evsignal] == NULL) { -+ event_warn("malloc"); -+ return (-1); -+ } -+ -+ /* save previous handler and setup new handler */ -+#ifdef HAVE_SIGACTION -+ memset(&sa, 0, sizeof(sa)); -+ sa.sa_handler = handler; -+ sa.sa_flags |= SA_RESTART; -+ sigfillset(&sa.sa_mask); -+ -+ if (sigaction(evsignal, &sa, sig->sh_old[evsignal]) == -1) { -+ event_warn("sigaction"); -+ free(sig->sh_old[evsignal]); -+ return (-1); -+ } -+#else -+ if ((sh = signal(evsignal, handler)) == SIG_ERR) { -+ event_warn("signal"); -+ free(sig->sh_old[evsignal]); -+ return (-1); -+ } -+ *sig->sh_old[evsignal] = sh; -+#endif -+ -+ return (0); -+} -+ -+int -+evsignal_add(struct event *ev) -+{ -+ int evsignal; -+ struct event_base *base = ev->ev_base; -+ struct evsignal_info *sig = &ev->ev_base->sig; -+ -+ if (ev->ev_events & (EV_READ|EV_WRITE)) -+ event_errx(1, "%s: EV_SIGNAL incompatible use", __func__); -+ evsignal = EVENT_SIGNAL(ev); -+ assert(evsignal >= 0 && evsignal < NSIG); -+ if (TAILQ_EMPTY(&sig->evsigevents[evsignal])) { -+ event_debug(("%s: %p: changing signal handler", __func__, ev)); -+ if (_evsignal_set_handler( -+ base, evsignal, evsignal_handler) == -1) -+ return (-1); -+ -+ /* catch signals if they happen quickly */ -+ evsignal_base = base; -+ -+ if (!sig->ev_signal_added) { -+ if (event_add(&sig->ev_signal, NULL)) -+ return (-1); -+ sig->ev_signal_added = 1; -+ } -+ } -+ -+ /* multiple events may listen to the same signal */ -+ TAILQ_INSERT_TAIL(&sig->evsigevents[evsignal], ev, ev_signal_next); -+ -+ return (0); -+} -+ -+int -+_evsignal_restore_handler(struct event_base *base, int evsignal) -+{ -+ int ret = 0; -+ struct evsignal_info *sig = &base->sig; -+#ifdef HAVE_SIGACTION -+ struct sigaction *sh; -+#else -+ ev_sighandler_t *sh; -+#endif -+ -+ /* restore previous handler */ -+ sh = sig->sh_old[evsignal]; -+ sig->sh_old[evsignal] = NULL; -+#ifdef HAVE_SIGACTION -+ if (sigaction(evsignal, sh, NULL) == -1) { -+ event_warn("sigaction"); -+ ret = -1; -+ } -+#else -+ if (signal(evsignal, *sh) == SIG_ERR) { -+ event_warn("signal"); -+ ret = -1; -+ } -+#endif -+ free(sh); -+ -+ return ret; -+} -+ -+int -+evsignal_del(struct event *ev) -+{ -+ struct event_base *base = ev->ev_base; -+ struct evsignal_info *sig = &base->sig; -+ int evsignal = EVENT_SIGNAL(ev); -+ -+ assert(evsignal >= 0 && evsignal < NSIG); -+ -+ /* multiple events may listen to the same signal */ -+ TAILQ_REMOVE(&sig->evsigevents[evsignal], ev, ev_signal_next); -+ -+ if (!TAILQ_EMPTY(&sig->evsigevents[evsignal])) -+ return (0); -+ -+ event_debug(("%s: %p: restoring signal handler", __func__, ev)); -+ -+ return (_evsignal_restore_handler(ev->ev_base, EVENT_SIGNAL(ev))); -+} -+ -+static void -+evsignal_handler(int sig) -+{ -+ int save_errno = errno; -+ -+ if (evsignal_base == NULL) { -+ event_warn( -+ "%s: received signal %d, but have no base configured", -+ __func__, sig); -+ return; -+ } -+ -+ evsignal_base->sig.evsigcaught[sig]++; -+ evsignal_base->sig.evsignal_caught = 1; -+ -+#ifndef HAVE_SIGACTION -+ signal(sig, evsignal_handler); -+#endif -+ -+ /* Wake up our notification mechanism */ -+ send(evsignal_base->sig.ev_signal_pair[0], "a", 1, 0); -+ errno = save_errno; -+} -+ -+void -+evsignal_process(struct event_base *base) -+{ -+ struct evsignal_info *sig = &base->sig; -+ struct event *ev, *next_ev; -+ sig_atomic_t ncalls; -+ int i; -+ -+ base->sig.evsignal_caught = 0; -+ for (i = 1; i < NSIG; ++i) { -+ ncalls = sig->evsigcaught[i]; -+ if (ncalls == 0) -+ continue; -+ -+ for (ev = TAILQ_FIRST(&sig->evsigevents[i]); -+ ev != NULL; ev = next_ev) { -+ next_ev = TAILQ_NEXT(ev, ev_signal_next); -+ if (!(ev->ev_events & EV_PERSIST)) -+ event_del(ev); -+ event_active(ev, EV_SIGNAL, ncalls); -+ } -+ -+ sig->evsigcaught[i] = 0; -+ } -+} -+ -+void -+evsignal_dealloc(struct event_base *base) -+{ -+ int i = 0; -+ if (base->sig.ev_signal_added) { -+ event_del(&base->sig.ev_signal); -+ base->sig.ev_signal_added = 0; -+ } -+ for (i = 0; i < NSIG; ++i) { -+ if (i < base->sig.sh_old_max && base->sig.sh_old[i] != NULL) -+ _evsignal_restore_handler(base, i); -+ } -+ -+ EVUTIL_CLOSESOCKET(base->sig.ev_signal_pair[0]); -+ base->sig.ev_signal_pair[0] = -1; -+ EVUTIL_CLOSESOCKET(base->sig.ev_signal_pair[1]); -+ base->sig.ev_signal_pair[1] = -1; -+ base->sig.sh_old_max = 0; -+ -+ /* per index frees are handled in evsignal_del() */ -+ free(base->sig.sh_old); -+} -diff --git a/libevent/strlcpy-internal.h b/libevent/strlcpy-internal.h -new file mode 100644 -index 0000000..22b5f61 ---- /dev/null -+++ b/libevent/strlcpy-internal.h -@@ -0,0 +1,23 @@ -+#ifndef _STRLCPY_INTERNAL_H_ -+#define _STRLCPY_INTERNAL_H_ -+ -+#ifdef __cplusplus -+extern "C" { -+#endif -+ -+#ifdef HAVE_CONFIG_H -+#include "config.h" -+#endif /* HAVE_CONFIG_H */ -+ -+#ifndef HAVE_STRLCPY -+#include -+size_t _event_strlcpy(char *dst, const char *src, size_t siz); -+#define strlcpy _event_strlcpy -+#endif -+ -+#ifdef __cplusplus -+} -+#endif -+ -+#endif -+ -diff --git a/libevent/strlcpy.c b/libevent/strlcpy.c -new file mode 100644 -index 0000000..a1a413d ---- /dev/null -+++ b/libevent/strlcpy.c -@@ -0,0 +1,78 @@ -+/* $OpenBSD: strlcpy.c,v 1.5 2001/05/13 15:40:16 deraadt Exp $ */ -+ -+/* -+ * Copyright (c) 1998 Todd C. Miller -+ * All rights reserved. -+ * -+ * Redistribution and use in source and binary forms, with or without -+ * modification, are permitted provided that the following conditions -+ * are met: -+ * 1. Redistributions of source code must retain the above copyright -+ * notice, this list of conditions and the following disclaimer. -+ * 2. Redistributions in binary form must reproduce the above copyright -+ * notice, this list of conditions and the following disclaimer in the -+ * documentation and/or other materials provided with the distribution. -+ * 3. The name of the author may not be used to endorse or promote products -+ * derived from this software without specific prior written permission. -+ * -+ * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, -+ * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY -+ * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL -+ * THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, -+ * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, -+ * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; -+ * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, -+ * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR -+ * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF -+ * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -+ */ -+ -+#if defined(LIBC_SCCS) && !defined(lint) -+static char *rcsid = "$OpenBSD: strlcpy.c,v 1.5 2001/05/13 15:40:16 deraadt Exp $"; -+#endif /* LIBC_SCCS and not lint */ -+ -+#include "event-fpm.h" -+ -+#include -+ -+#ifdef HAVE_CONFIG_H -+#include "config.h" -+#endif /* HAVE_CONFIG_H */ -+ -+#ifndef HAVE_STRLCPY -+#include "strlcpy-internal.h" -+ -+/* -+ * Copy src to string dst of size siz. At most siz-1 characters -+ * will be copied. Always NUL terminates (unless siz == 0). -+ * Returns strlen(src); if retval >= siz, truncation occurred. -+ */ -+size_t -+_event_strlcpy(dst, src, siz) -+ char *dst; -+ const char *src; -+ size_t siz; -+{ -+ register char *d = dst; -+ register const char *s = src; -+ register size_t n = siz; -+ -+ /* Copy as many bytes as will fit */ -+ if (n != 0 && --n != 0) { -+ do { -+ if ((*d++ = *s++) == 0) -+ break; -+ } while (--n != 0); -+ } -+ -+ /* Not enough room in dst, add NUL and traverse rest of src */ -+ if (n == 0) { -+ if (siz != 0) -+ *d = '\0'; /* NUL-terminate dst */ -+ while (*s++) -+ ; -+ } -+ -+ return(s - src - 1); /* count does not include NUL */ -+} -+#endif -diff --git a/main/php_config.h.in b/main/php_config.h.in -index 6df7d68..f155934 100644 ---- a/main/php_config.h.in -+++ b/main/php_config.h.in -@@ -170,6 +170,9 @@ - /* Define if you have the chroot function. */ - #undef HAVE_CHROOT - -+/* Define if you have the clearenv function. */ -+#undef HAVE_CLEARENV -+ - /* Define if you have the crypt function. */ - #undef HAVE_CRYPT - -@@ -935,6 +938,9 @@ - /* */ - #undef PHP_FASTCGI - -+/* Is experimental fastcgi process manager code activated */ -+#undef PHP_FASTCGI_PM -+ - /* */ - #undef FORCE_CGI_REDIRECT - -@@ -944,6 +950,27 @@ - /* */ - #undef ENABLE_PATHINFO_CHECK - -+/* do we have libxml? */ -+#undef HAVE_LIBXML -+ -+/* do we have prctl? */ -+#undef HAVE_PRCTL -+ -+/* do we have clock_gettime? */ -+#undef HAVE_CLOCK_GETTIME -+ -+/* do we have clock_get_time? */ -+#undef HAVE_CLOCK_GET_TIME -+ -+/* do we have ptrace? */ -+#undef HAVE_PTRACE -+ -+/* do we have mach_vm_read? */ -+#undef HAVE_MACH_VM_READ -+ -+/* /proc/pid/mem interface */ -+#undef PROC_MEM_FILE -+ - /* Define if system uses EBCDIC */ - #undef CHARSET_EBCDIC - -diff --git a/sapi/cgi/Makefile.frag b/sapi/cgi/Makefile.frag -index 57a3b29..6fa6c9f 100644 ---- a/sapi/cgi/Makefile.frag -+++ b/sapi/cgi/Makefile.frag -@@ -1,2 +1,2 @@ --$(SAPI_CGI_PATH): $(PHP_GLOBAL_OBJS) $(PHP_SAPI_OBJS) -+$(SAPI_CGI_PATH): $(PHP_GLOBAL_OBJS) $(PHP_SAPI_OBJS) $(SAPI_EXTRA_DEPS) - $(BUILD_CGI) -diff --git a/sapi/cgi/cgi_main.c b/sapi/cgi/cgi_main.c -index a4a19c2..2c19083 100644 ---- a/sapi/cgi/cgi_main.c -+++ b/sapi/cgi/cgi_main.c -@@ -55,6 +55,9 @@ - #if HAVE_SYS_WAIT_H - #include - #endif -+#if HAVE_FCNTL_H -+#include -+#endif - #include "zend.h" - #include "zend_extensions.h" - #include "php_ini.h" -@@ -83,6 +86,11 @@ int __riscosify_control = __RISCOSIFY_STRICT_UNIX_SPECS; - #if PHP_FASTCGI - #include "fastcgi.h" - -+#if PHP_FASTCGI_PM -+#include "fpm/fpm.h" -+#include "fpm/fpm_request.h" -+#endif -+ - #ifndef PHP_WIN32 - /* XXX this will need to change later when threaded fastcgi is - implemented. shane */ -@@ -115,8 +123,12 @@ static int parent_waiting = 0; - static pid_t pgroup; - #endif - -+static int request_body_fd; -+ - #endif - -+static char *sapi_cgibin_getenv(char *name, size_t name_len TSRMLS_DC); -+ - #define PHP_MODE_STANDARD 1 - #define PHP_MODE_HIGHLIGHT 2 - #define PHP_MODE_INDENT 3 -@@ -146,6 +158,10 @@ static const opt_struct OPTIONS[] = { - {'w', 0, "strip"}, - {'?', 0, "usage"},/* help alias (both '?' and 'usage') */ - {'v', 0, "version"}, -+#if PHP_FASTCGI_PM -+ {'x', 0, "fpm"}, -+ {'y', 1, "fpm-config"}, -+#endif - {'z', 1, "zend-extension"}, - #if PHP_FASTCGI - {'T', 1, "timing"}, -@@ -170,6 +186,7 @@ typedef struct _php_cgi_globals_struct { - zend_bool impersonate; - # endif - #endif -+ char *error_header; - } php_cgi_globals_struct; - - #ifdef ZTS -@@ -474,7 +491,28 @@ static int sapi_cgi_read_post(char *buffer, uint count_bytes TSRMLS_DC) - #if PHP_FASTCGI - if (fcgi_is_fastcgi()) { - fcgi_request *request = (fcgi_request*) SG(server_context); -- tmp_read_bytes = fcgi_read(request, buffer + read_bytes, count_bytes - read_bytes); -+ -+ if (request_body_fd == -1) { -+ char *request_body_filename = sapi_cgibin_getenv((char *) "REQUEST_BODY_FILE", -+ sizeof("REQUEST_BODY_FILE")-1 TSRMLS_CC); -+ -+ if (request_body_filename && *request_body_filename) { -+ request_body_fd = open(request_body_filename, O_RDONLY); -+ -+ if (0 > request_body_fd) { -+ php_error(E_WARNING, "REQUEST_BODY_FILE: open('%s') failed: %s (%d)", -+ request_body_filename, strerror(errno), errno); -+ return 0; -+ } -+ } -+ } -+ -+ /* If REQUEST_BODY_FILE variable not available - read post body from fastcgi stream */ -+ if (request_body_fd < 0) { -+ tmp_read_bytes = fcgi_read(request, buffer + read_bytes, count_bytes - read_bytes); -+ } else { -+ tmp_read_bytes = read(request_body_fd, buffer + read_bytes, count_bytes - read_bytes); -+ } - } else { - tmp_read_bytes = read(STDIN_FILENO, buffer + read_bytes, count_bytes - read_bytes); - } -@@ -786,7 +824,12 @@ static void php_cgi_usage(char *argv0) - " -s Display colour syntax highlighted source.\n" - " -v Version number\n" - " -w Display source with stripped comments and whitespace.\n" -- " -z Load Zend extension .\n" -+#if PHP_FASTCGI_PM -+ " -x, --fpm Run in FastCGI process manager mode.\n" -+ " -y, --fpm-config \n" -+ " Specify alternative path to FastCGI process manager config file.\n" -+#endif -+ " -z Load Zend extension .\n" - #if PHP_FASTCGI - " -T Measure execution time of script repeated times.\n" - #endif -@@ -1236,6 +1279,7 @@ PHP_INI_BEGIN() - # ifdef PHP_WIN32 - STD_PHP_INI_ENTRY("fastcgi.impersonate", "0", PHP_INI_SYSTEM, OnUpdateBool, impersonate, php_cgi_globals_struct, php_cgi_globals) - # endif -+ STD_PHP_INI_ENTRY("fastcgi.error_header", NULL, PHP_INI_SYSTEM, OnUpdateString, error_header, php_cgi_globals_struct, php_cgi_globals) - #endif - PHP_INI_END() - -@@ -1258,6 +1302,7 @@ static void php_cgi_globals_ctor(php_cgi_globals_struct *php_cgi_globals TSRMLS_ - # ifdef PHP_WIN32 - php_cgi_globals->impersonate = 0; - # endif -+ php_cgi_globals->error_header = NULL; - #endif - } - /* }}} */ -@@ -1290,9 +1335,47 @@ static PHP_MSHUTDOWN_FUNCTION(cgi) - static PHP_MINFO_FUNCTION(cgi) - { - DISPLAY_INI_ENTRIES(); -+ -+#if PHP_FASTCGI_PM -+ -+#include "fpm/fpm_autoconf.h" -+ -+ php_info_print_table_start(); -+ php_info_print_table_row(2, "php-fpm", fpm ? "active" : "inactive"); -+ php_info_print_table_row(2, "php-fpm version", PHP_FPM_VERSION); -+ php_info_print_table_end(); -+#endif -+ - } - /* }}} */ - -+#if PHP_FASTCGI -+PHP_FUNCTION(fastcgi_finish_request) -+{ -+ fcgi_request *request = (fcgi_request*) SG(server_context); -+ -+ if (fcgi_is_fastcgi() && request->fd >= 0) { -+ -+ php_end_ob_buffers(1 TSRMLS_CC); -+ php_header(TSRMLS_C); -+ -+ fcgi_flush(request, 1); -+ fcgi_close(request, 0, 0); -+ RETURN_TRUE; -+ } -+ -+ RETURN_FALSE; -+ -+} -+#endif -+ -+function_entry cgi_fcgi_sapi_functions[] = { -+#if PHP_FASTCGI -+ PHP_FE(fastcgi_finish_request, NULL) -+#endif -+ {NULL, NULL, NULL} -+}; -+ - static zend_module_entry cgi_module_entry = { - STANDARD_MODULE_HEADER, - #if PHP_FASTCGI -@@ -1300,7 +1383,7 @@ static zend_module_entry cgi_module_entry = { - #else - "cgi", - #endif -- NULL, -+ cgi_fcgi_sapi_functions, - PHP_MINIT(cgi), - PHP_MSHUTDOWN(cgi), - NULL, -@@ -1340,6 +1423,7 @@ int main(int argc, char *argv[]) - char *bindpath = NULL; - int fcgi_fd = 0; - fcgi_request request; -+ char *fpm_config = NULL; - int repeats = 1; - int benchmark = 0; - #if HAVE_GETTIMEOFDAY -@@ -1460,6 +1544,14 @@ int main(int argc, char *argv[]) - case 's': /* generate highlighted HTML from source */ - behavior = PHP_MODE_HIGHLIGHT; - break; -+#if PHP_FASTCGI_PM -+ case 'y': -+ fpm_config = php_optarg; -+ break; -+ case 'x': -+ fpm = 1; -+ break; -+#endif - - } - -@@ -1524,6 +1616,19 @@ consult the installation file that came with this distribution, or visit \n\ - #endif /* FORCE_CGI_REDIRECT */ - - #if PHP_FASTCGI -+#if PHP_FASTCGI_PM -+ if (fpm) { -+ if (0 > fpm_init(argc, argv, fpm_config)) { -+ return FAILURE; -+ } -+ -+ fcgi_fd = fpm_run(&max_requests); -+ -+ fcgi_set_is_fastcgi(fastcgi = 1); -+ } -+ else -+#endif -+ - if (bindpath) { - fcgi_fd = fcgi_listen(bindpath, 128); - if (fcgi_fd < 0) { -@@ -1538,6 +1643,9 @@ consult the installation file that came with this distribution, or visit \n\ - - if (fastcgi) { - /* How many times to run PHP scripts before dying */ -+#if PHP_FASTCGI_PM -+ if (!fpm) -+#endif - if (getenv("PHP_FCGI_MAX_REQUESTS")) { - max_requests = atoi(getenv("PHP_FCGI_MAX_REQUESTS")); - if (max_requests < 0) { -@@ -1555,6 +1663,9 @@ consult the installation file that came with this distribution, or visit \n\ - - #ifndef PHP_WIN32 - /* Pre-fork, if required */ -+#if PHP_FASTCGI_PM -+ if (!fpm) -+#endif - if (getenv("PHP_FCGI_CHILDREN")) { - char * children_str = getenv("PHP_FCGI_CHILDREN"); - children = atoi(children_str); -@@ -1704,6 +1815,8 @@ consult the installation file that came with this distribution, or visit \n\ - #endif - - #if PHP_FASTCGI -+ request_body_fd = -1; -+ - SG(server_context) = (void *) &request; - #else - SG(server_context) = (void *) 1; /* avoid server_context==NULL checks */ -@@ -1711,6 +1824,10 @@ consult the installation file that came with this distribution, or visit \n\ - init_request_info(TSRMLS_C); - CG(interactive) = 0; - -+#if PHP_FASTCGI_PM -+ if (fpm) fpm_request_info(); -+#endif -+ - if (!cgi - #if PHP_FASTCGI - && !fastcgi -@@ -1994,6 +2111,10 @@ consult the installation file that came with this distribution, or visit \n\ - } - } - -+#if PHP_FASTCGI_PM -+ if (fpm) fpm_request_executing(); -+#endif -+ - switch (behavior) { - case PHP_MODE_STANDARD: - php_execute_script(&file_handle TSRMLS_CC); -@@ -2046,6 +2167,10 @@ consult the installation file that came with this distribution, or visit \n\ - - #if PHP_FASTCGI - fastcgi_request_done: -+ -+ if (request_body_fd != -1) close(request_body_fd); -+ -+ request_body_fd = -2; - #endif - { - char *path_translated; -@@ -2059,6 +2184,16 @@ fastcgi_request_done: - SG(request_info).path_translated = path_translated; - } - -+ if (EG(exit_status) == 255) { -+ if (CGIG(error_header) && *CGIG(error_header)) { -+ sapi_header_line ctr = {0}; -+ -+ ctr.line = CGIG(error_header); -+ ctr.line_len = strlen(CGIG(error_header)); -+ sapi_header_op(SAPI_HEADER_REPLACE, &ctr TSRMLS_CC); -+ } -+ } -+ - php_request_shutdown((void *) 0); - if (exit_status == 0) { - exit_status = EG(exit_status); -@@ -2096,15 +2231,20 @@ fastcgi_request_done: - if (bindpath) { - free(bindpath); - } -- if (max_requests != 1) { -- /* no need to return exit_status of the last request */ -- exit_status = 0; -- } - break; - } - /* end of fastcgi loop */ - } - fcgi_shutdown(); -+ -+ if (fcgi_in_shutdown() || /* graceful shutdown by a signal */ -+ (max_requests && (requests == max_requests)) /* we were told to process max_requests and we are done */ -+ ) { -+ exit_status = 0; -+ } -+ else { -+ exit_status = 255; -+ } - #endif - - if (cgi_sapi_module.php_ini_path_override) { -diff --git a/sapi/cgi/config9.m4 b/sapi/cgi/config9.m4 -index 4ff90fd..fdf409b 100644 ---- a/sapi/cgi/config9.m4 -+++ b/sapi/cgi/config9.m4 -@@ -22,6 +22,10 @@ PHP_ARG_ENABLE(path-info-check,, - [ --disable-path-info-check CGI: If this is disabled, paths such as - /info.php/test?a=b will fail to work], yes, no) - -+PHP_ARG_ENABLE(fpm,, -+[ --enable-fpm FastCGI: If this is enabled, the fastcgi support -+ will include experimental process manager code], no, no) -+ - dnl - dnl CGI setup - dnl -@@ -54,6 +58,20 @@ if test "$PHP_SAPI" = "default"; then - AC_DEFINE_UNQUOTED(PHP_FASTCGI, $PHP_ENABLE_FASTCGI, [ ]) - AC_MSG_RESULT($PHP_FASTCGI) - -+ dnl --enable-fpm -+ if test "$PHP_FASTCGI" = "yes"; then -+ AC_MSG_CHECKING(whether to enable FastCGI Process Manager) -+ if test "$PHP_FPM" = "yes"; then -+ PHP_FASTCGI_PM=1 -+ else -+ PHP_FASTCGI_PM=0 -+ fi -+ AC_MSG_RESULT($PHP_FPM) -+ else -+ PHP_FASTCGI_PM=0 -+ fi -+ AC_DEFINE_UNQUOTED(PHP_FASTCGI_PM, $PHP_FASTCGI_PM, [Is experimental fastcgi process manager code activated]) -+ - dnl --enable-force-cgi-redirect - AC_MSG_CHECKING(whether to force Apache CGI redirect) - if test "$PHP_FORCE_CGI_REDIRECT" = "yes"; then -@@ -93,10 +111,10 @@ if test "$PHP_SAPI" = "default"; then - BUILD_CGI="echo '\#! .' > php.sym && echo >>php.sym && nm -BCpg \`echo \$(PHP_GLOBAL_OBJS) \$(PHP_SAPI_OBJS) | sed 's/\([A-Za-z0-9_]*\)\.lo/\1.o/g'\` | \$(AWK) '{ if (((\$\$2 == \"T\") || (\$\$2 == \"D\") || (\$\$2 == \"B\")) && (substr(\$\$3,1,1) != \".\")) { print \$\$3 } }' | sort -u >> php.sym && \$(LIBTOOL) --mode=link \$(CC) -export-dynamic \$(CFLAGS_CLEAN) \$(EXTRA_CFLAGS) \$(EXTRA_LDFLAGS_PROGRAM) \$(LDFLAGS) -Wl,-brtl -Wl,-bE:php.sym \$(PHP_RPATHS) \$(PHP_GLOBAL_OBJS) \$(PHP_SAPI_OBJS) \$(EXTRA_LIBS) \$(ZEND_EXTRA_LIBS) -o \$(SAPI_CGI_PATH)" - ;; - *darwin*) -- BUILD_CGI="\$(CC) \$(CFLAGS_CLEAN) \$(EXTRA_CFLAGS) \$(EXTRA_LDFLAGS_PROGRAM) \$(LDFLAGS) \$(NATIVE_RPATHS) \$(PHP_GLOBAL_OBJS:.lo=.o) \$(PHP_SAPI_OBJS:.lo=.o) \$(PHP_FRAMEWORKS) \$(EXTRA_LIBS) \$(ZEND_EXTRA_LIBS) -o \$(SAPI_CGI_PATH)" -+ BUILD_CGI="\$(CC) \$(CFLAGS_CLEAN) \$(EXTRA_CFLAGS) \$(EXTRA_LDFLAGS_PROGRAM) \$(LDFLAGS) \$(NATIVE_RPATHS) \$(PHP_GLOBAL_OBJS:.lo=.o) \$(PHP_SAPI_OBJS:.lo=.o) \$(PHP_FRAMEWORKS) \$(EXTRA_LIBS) \$(SAPI_EXTRA_LIBS) \$(ZEND_EXTRA_LIBS) -o \$(SAPI_CGI_PATH)" - ;; - *) -- BUILD_CGI="\$(LIBTOOL) --mode=link \$(CC) -export-dynamic \$(CFLAGS_CLEAN) \$(EXTRA_CFLAGS) \$(EXTRA_LDFLAGS_PROGRAM) \$(LDFLAGS) \$(PHP_RPATHS) \$(PHP_GLOBAL_OBJS) \$(PHP_SAPI_OBJS) \$(EXTRA_LIBS) \$(ZEND_EXTRA_LIBS) -o \$(SAPI_CGI_PATH)" -+ BUILD_CGI="\$(LIBTOOL) --mode=link \$(CC) -export-dynamic \$(CFLAGS_CLEAN) \$(EXTRA_CFLAGS) \$(EXTRA_LDFLAGS_PROGRAM) \$(LDFLAGS) \$(PHP_RPATHS) \$(PHP_GLOBAL_OBJS) \$(PHP_SAPI_OBJS) \$(EXTRA_LIBS) \$(SAPI_EXTRA_LIBS) \$(ZEND_EXTRA_LIBS) -o \$(SAPI_CGI_PATH)" - ;; - esac - -diff --git a/sapi/cgi/fastcgi.c b/sapi/cgi/fastcgi.c -index 68b7e21..bcc0e7e 100644 ---- a/sapi/cgi/fastcgi.c -+++ b/sapi/cgi/fastcgi.c -@@ -27,6 +27,11 @@ - #include - #include - -+#if PHP_FASTCGI_PM -+#include "fpm/fpm.h" -+#include "fpm/fpm_request.h" -+#endif -+ - #ifdef _WIN32 - - #include -@@ -234,6 +239,8 @@ int fcgi_init(void) - } else { - return is_fastcgi = 0; - } -+ -+ fcgi_set_allowed_clients(getenv("FCGI_WEB_SERVER_ADDRS")); - #endif - } - return is_fastcgi; -@@ -249,14 +256,26 @@ int fcgi_is_fastcgi(void) - } - } - -+void fcgi_set_is_fastcgi(int new_value) -+{ -+ is_fastcgi = new_value; -+} -+ -+void fcgi_set_in_shutdown(int new_value) -+{ -+ in_shutdown = new_value; -+} -+ - void fcgi_shutdown(void) - { - if (is_initialized) { - zend_hash_destroy(&fcgi_mgmt_vars); - } - is_fastcgi = 0; -+ - if (allowed_clients) { - free(allowed_clients); -+ allowed_clients = 0; - } - } - -@@ -330,6 +349,41 @@ out_fail: - } - #endif - -+void fcgi_set_allowed_clients(char *ip) -+{ -+ char *cur, *end; -+ int n; -+ -+ if (ip) { -+ ip = strdup(ip); -+ cur = ip; -+ n = 0; -+ while (*cur) { -+ if (*cur == ',') n++; -+ cur++; -+ } -+ if (allowed_clients) free(allowed_clients); -+ allowed_clients = malloc(sizeof(in_addr_t) * (n+2)); -+ n = 0; -+ cur = ip; -+ while (cur) { -+ end = strchr(cur, ','); -+ if (end) { -+ *end = 0; -+ end++; -+ } -+ allowed_clients[n] = inet_addr(cur); -+ if (allowed_clients[n] == INADDR_NONE) { -+ fprintf(stderr, "Wrong IP address '%s' in FCGI_WEB_SERVER_ADDRS\n", cur); -+ } -+ n++; -+ cur = end; -+ } -+ allowed_clients[n] = INADDR_NONE; -+ free(ip); -+ } -+} -+ - static int is_port_number(const char *bindpath) - { - while (*bindpath) { -@@ -458,38 +512,6 @@ int fcgi_listen(const char *path, int backlog) - - if (!tcp) { - chmod(path, 0777); -- } else { -- char *ip = getenv("FCGI_WEB_SERVER_ADDRS"); -- char *cur, *end; -- int n; -- -- if (ip) { -- ip = strdup(ip); -- cur = ip; -- n = 0; -- while (*cur) { -- if (*cur == ',') n++; -- cur++; -- } -- allowed_clients = malloc(sizeof(in_addr_t) * (n+2)); -- n = 0; -- cur = ip; -- while (cur) { -- end = strchr(cur, ','); -- if (end) { -- *end = 0; -- end++; -- } -- allowed_clients[n] = inet_addr(cur); -- if (allowed_clients[n] == INADDR_NONE) { -- fprintf(stderr, "Wrong IP address '%s' in FCGI_WEB_SERVER_ADDRS\n", cur); -- } -- n++; -- cur = end; -- } -- allowed_clients[n] = INADDR_NONE; -- free(ip); -- } - } - - if (!is_initialized) { -@@ -866,7 +888,7 @@ int fcgi_read(fcgi_request *req, char *str, int len) - return n; - } - --static inline void fcgi_close(fcgi_request *req, int force, int destroy) -+void fcgi_close(fcgi_request *req, int force, int destroy) - { - if (destroy) { - zend_hash_destroy(&req->env); -@@ -906,6 +928,10 @@ static inline void fcgi_close(fcgi_request *req, int force, int destroy) - close(req->fd); - #endif - req->fd = -1; -+ -+#if PHP_FASTCGI_PM -+ if (fpm) fpm_request_finished(); -+#endif - } - } - -@@ -953,6 +979,10 @@ int fcgi_accept_request(fcgi_request *req) - sa_t sa; - socklen_t len = sizeof(sa); - -+#if PHP_FASTCGI_PM -+ if (fpm) fpm_request_accepting(); -+#endif -+ - FCGI_LOCK(req->listen_socket); - req->fd = accept(listen_socket, (struct sockaddr *)&sa, &len); - FCGI_UNLOCK(req->listen_socket); -@@ -988,6 +1018,11 @@ int fcgi_accept_request(fcgi_request *req) - break; - #else - if (req->fd >= 0) { -+ -+#if PHP_FASTCGI_PM -+ if (fpm) fpm_request_reading_headers(); -+#endif -+ - #if defined(HAVE_SYS_POLL_H) && defined(HAVE_POLL) - struct pollfd fds; - int ret; -diff --git a/sapi/cgi/fastcgi.h b/sapi/cgi/fastcgi.h -index c095c49..a3b3832 100644 ---- a/sapi/cgi/fastcgi.h -+++ b/sapi/cgi/fastcgi.h -@@ -114,6 +114,9 @@ typedef struct _fcgi_request { - int fcgi_init(void); - void fcgi_shutdown(void); - int fcgi_is_fastcgi(void); -+void fcgi_set_is_fastcgi(int); -+void fcgi_set_in_shutdown(int); -+void fcgi_set_allowed_clients(char *); - int fcgi_in_shutdown(void); - int fcgi_listen(const char *path, int backlog); - void fcgi_init_request(fcgi_request *req, int listen_socket); -@@ -128,6 +131,8 @@ int fcgi_read(fcgi_request *req, char *str, int len); - int fcgi_write(fcgi_request *req, fcgi_request_type type, const char *str, int len); - int fcgi_flush(fcgi_request *req, int close); - -+void fcgi_close(fcgi_request *req, int force, int destroy); -+ - #ifdef PHP_WIN32 - void fcgi_impersonate(void); - #endif -diff --git a/sapi/cgi/fpm/Makefile.frag b/sapi/cgi/fpm/Makefile.frag -new file mode 100644 -index 0000000..15e6637 ---- /dev/null -+++ b/sapi/cgi/fpm/Makefile.frag -@@ -0,0 +1,21 @@ -+ -+install-fpm: sapi/cgi/fpm/php-fpm.conf sapi/cgi/fpm/php-fpm -+ @echo "Installing FPM config: $(INSTALL_ROOT)$(php_fpm_conf_path)" -+ -@$(mkinstalldirs) \ -+ $(INSTALL_ROOT)$(prefix)/sbin \ -+ `dirname "$(INSTALL_ROOT)$(php_fpm_conf_path)"` \ -+ `dirname "$(INSTALL_ROOT)$(php_fpm_log_path)"` \ -+ `dirname "$(INSTALL_ROOT)$(php_fpm_pid_path)"` -+ -@if test -r "$(INSTALL_ROOT)$(php_fpm_conf_path)" ; then \ -+ dest=`basename "$(php_fpm_conf_path)"`.default ; \ -+ echo " (installing as $$dest)" ; \ -+ else \ -+ dest=`basename "$(php_fpm_conf_path)"` ; \ -+ fi ; \ -+ $(INSTALL_DATA) $(top_builddir)/sapi/cgi/fpm/php-fpm.conf $(INSTALL_ROOT)`dirname "$(php_fpm_conf_path)"`/$$dest -+ @echo "Installing init.d script: $(INSTALL_ROOT)$(prefix)/sbin/php-fpm" -+ -@$(INSTALL) -m 0755 $(top_builddir)/sapi/cgi/fpm/php-fpm $(INSTALL_ROOT)$(prefix)/sbin/php-fpm -+ -+$(top_builddir)/libevent/libevent.a: $(top_builddir)/libevent/Makefile -+ cd $(top_builddir)/libevent && $(MAKE) libevent.a -+ -diff --git a/sapi/cgi/fpm/acinclude.m4 b/sapi/cgi/fpm/acinclude.m4 -new file mode 100644 -index 0000000..e4d1f3e ---- /dev/null -+++ b/sapi/cgi/fpm/acinclude.m4 -@@ -0,0 +1,377 @@ -+ -+AC_DEFUN([AC_FPM_CHECK_FUNC], -+[ -+ SAVED_CFLAGS="$CFLAGS" -+ CFLAGS="$CFLAGS $2" -+ SAVED_LIBS="$LIBS" -+ LIBS="$LIBS $3" -+ -+ AC_CHECK_FUNC([$1],[$4],[$5]) -+ -+ CFLAGS="$SAVED_CFLAGS" -+ LIBS="$SAVED_LIBS" -+]) -+ -+AC_DEFUN([AC_FPM_LIBEVENT], -+[ -+ AC_ARG_WITH([libevent], -+ [ --with-libevent=DIR FPM: libevent install directory]) -+ -+ LIBEVENT_CFLAGS="" -+ LIBEVENT_LIBS="-levent" -+ LIBEVENT_INCLUDE_PATH="" -+ -+ if test "$with_libevent" != "no" -a -n "$with_libevent"; then -+ LIBEVENT_CFLAGS="-I$with_libevent/include" -+ LIBEVENT_LIBS="-L$with_libevent/lib $LIBEVENT_LIBS" -+ LIBEVENT_INCLUDE_PATH="$with_libevent/include" -+ fi -+ -+ AC_MSG_CHECKING([for event.h]) -+ -+ found=no -+ -+ for dir in "$LIBEVENT_INCLUDE_PATH" /usr/include ; do -+ if test -r "$dir/event.h" ; then -+ found=yes -+ break -+ fi -+ done -+ -+ AC_MSG_RESULT([$found]) -+ -+ AC_FPM_CHECK_FUNC([event_set], [$LIBEVENT_CFLAGS], [$LIBEVENT_LIBS], , -+ [AC_MSG_ERROR([Failed to link with libevent. Perhaps --with-libevent=DIR option could help.])]) -+ -+ AC_FPM_CHECK_FUNC([event_base_free], [$LIBEVENT_CFLAGS], [$LIBEVENT_LIBS], , -+ [AC_MSG_ERROR([You have too old version. libevent version >= 1.2 is required.])]) -+ -+]) -+ -+AC_DEFUN([AC_FPM_LIBXML], -+[ -+ AC_MSG_RESULT([checking for XML configuration]) -+ -+ AC_ARG_WITH(xml-config, -+ [ --with-xml-config=PATH FPM: use xml-config in PATH to find libxml], -+ [XMLCONFIG="$withval"], -+ [AC_PATH_PROGS(XMLCONFIG, [xml2-config xml-config], "")] -+ ) -+ -+ if test "x$XMLCONFIG" = "x"; then -+ AC_MSG_ERROR([XML configuration could not be found]) -+ else -+ AC_MSG_CHECKING([for libxml library]) -+ -+ if test ! -x "$XMLCONFIG"; then -+ AC_MSG_ERROR([$XMLCONFIG cannot be executed]) -+ fi -+ -+ LIBXML_LIBS="`$XMLCONFIG --libs`" -+ LIBXML_CFLAGS="`$XMLCONFIG --cflags`" -+ LIBXML_VERSION="`$XMLCONFIG --version`" -+ -+ AC_MSG_RESULT([yes, $LIBXML_VERSION]) -+ -+ AC_FPM_CHECK_FUNC([xmlParseFile], [$LIBXML_CFLAGS], [$LIBXML_LIBS], , -+ [AC_MSG_ERROR([Failed to link with libxml])]) -+ -+ AC_DEFINE(HAVE_LIBXML, 1, [do we have libxml?]) -+ fi -+]) -+ -+AC_DEFUN([AC_FPM_JUDY], -+[ -+ AC_ARG_WITH([Judy], -+ [ --with-Judy=DIR FPM: Judy install directory]) -+ -+ JUDY_CFLAGS="" -+ JUDY_LIBS="-lJudy" -+ JUDY_INCLUDE_PATH="" -+ -+ if test "$with_Judy" != "no" -a -n "$with_Judy"; then -+ JUDY_INCLUDE_PATH="$with_Judy/include" -+ JUDY_CFLAGS="-I$with_Judy/include $JUDY_CFLAGS" -+ JUDY_LIBS="-L$with_Judy/lib $JUDY_LIBS" -+ fi -+ -+ AC_MSG_CHECKING([for Judy.h]) -+ -+ found=no -+ -+ for dir in "$JUDY_INCLUDE_PATH" /usr/include ; do -+ if test -r "$dir/Judy.h" ; then -+ found=yes -+ break -+ fi -+ done -+ -+ AC_MSG_RESULT([$found]) -+ -+ AC_FPM_CHECK_FUNC([JudyLCount], [$JUDY_CFLAGS], [$JUDY_LIBS], , -+ [AC_MSG_ERROR([Failed to link with Judy])]) -+ -+]) -+ -+AC_DEFUN([AC_FPM_CLOCK], -+[ -+ have_clock_gettime=no -+ -+ AC_MSG_CHECKING([for clock_gettime]) -+ -+ AC_TRY_LINK([ #include ], [struct timespec ts; clock_gettime(CLOCK_MONOTONIC, &ts);], [ -+ have_clock_gettime=yes -+ AC_MSG_RESULT([yes]) -+ ], [ -+ AC_MSG_RESULT([no]) -+ ]) -+ -+ if test "$have_clock_gettime" = "no"; then -+ AC_MSG_CHECKING([for clock_gettime in -lrt]) -+ -+ SAVED_LIBS="$LIBS" -+ LIBS="$LIBS -lrt" -+ -+ AC_TRY_LINK([ #include ], [struct timespec ts; clock_gettime(CLOCK_MONOTONIC, &ts);], [ -+ have_clock_gettime=yes -+ AC_MSG_RESULT([yes]) -+ ], [ -+ LIBS="$SAVED_LIBS" -+ AC_MSG_RESULT([no]) -+ ]) -+ fi -+ -+ if test "$have_clock_gettime" = "yes"; then -+ AC_DEFINE([HAVE_CLOCK_GETTIME], 1, [do we have clock_gettime?]) -+ fi -+ -+ have_clock_get_time=no -+ -+ if test "$have_clock_gettime" = "no"; then -+ AC_MSG_CHECKING([for clock_get_time]) -+ -+ AC_TRY_RUN([ #include -+ #include -+ #include -+ -+ int main() -+ { -+ kern_return_t ret; clock_serv_t aClock; mach_timespec_t aTime; -+ ret = host_get_clock_service(mach_host_self(), REALTIME_CLOCK, &aClock); -+ -+ if (ret != KERN_SUCCESS) { -+ return 1; -+ } -+ -+ ret = clock_get_time(aClock, &aTime); -+ if (ret != KERN_SUCCESS) { -+ return 2; -+ } -+ -+ return 0; -+ } -+ ], [ -+ have_clock_get_time=yes -+ AC_MSG_RESULT([yes]) -+ ], [ -+ AC_MSG_RESULT([no]) -+ ]) -+ fi -+ -+ if test "$have_clock_get_time" = "yes"; then -+ AC_DEFINE([HAVE_CLOCK_GET_TIME], 1, [do we have clock_get_time?]) -+ fi -+]) -+ -+AC_DEFUN([AC_FPM_TRACE], -+[ -+ have_ptrace=no -+ have_broken_ptrace=no -+ -+ AC_MSG_CHECKING([for ptrace]) -+ -+ AC_TRY_COMPILE([ -+ #include -+ #include ], [ptrace(0, 0, (void *) 0, 0);], [ -+ have_ptrace=yes -+ AC_MSG_RESULT([yes]) -+ ], [ -+ AC_MSG_RESULT([no]) -+ ]) -+ -+ if test "$have_ptrace" = "yes"; then -+ AC_MSG_CHECKING([whether ptrace works]) -+ -+ AC_TRY_RUN([ -+ #include -+ #include -+ #include -+ #include -+ #include -+ #include -+ -+ #if !defined(PTRACE_ATTACH) && defined(PT_ATTACH) -+ #define PTRACE_ATTACH PT_ATTACH -+ #endif -+ -+ #if !defined(PTRACE_DETACH) && defined(PT_DETACH) -+ #define PTRACE_DETACH PT_DETACH -+ #endif -+ -+ #if !defined(PTRACE_PEEKDATA) && defined(PT_READ_D) -+ #define PTRACE_PEEKDATA PT_READ_D -+ #endif -+ -+ int main() -+ { -+ long v1 = (unsigned int) -1; /* copy will fail if sizeof(long) == 8 and we've got "int ptrace()" */ -+ long v2; -+ pid_t child; -+ int status; -+ -+ if ( (child = fork()) ) { /* parent */ -+ int ret = 0; -+ -+ if (0 > ptrace(PTRACE_ATTACH, child, 0, 0)) { -+ return 1; -+ } -+ -+ waitpid(child, &status, 0); -+ -+ #ifdef PT_IO -+ struct ptrace_io_desc ptio = { -+ .piod_op = PIOD_READ_D, -+ .piod_offs = &v1, -+ .piod_addr = &v2, -+ .piod_len = sizeof(v1) -+ }; -+ -+ if (0 > ptrace(PT_IO, child, (void *) &ptio, 0)) { -+ ret = 1; -+ } -+ #else -+ errno = 0; -+ -+ v2 = ptrace(PTRACE_PEEKDATA, child, (void *) &v1, 0); -+ -+ if (errno) { -+ ret = 1; -+ } -+ #endif -+ ptrace(PTRACE_DETACH, child, (void *) 1, 0); -+ -+ kill(child, SIGKILL); -+ -+ return ret ? ret : (v1 != v2); -+ } -+ else { /* child */ -+ sleep(10); -+ return 0; -+ } -+ } -+ ], [ -+ AC_MSG_RESULT([yes]) -+ ], [ -+ have_ptrace=no -+ have_broken_ptrace=yes -+ AC_MSG_RESULT([no]) -+ ]) -+ fi -+ -+ if test "$have_ptrace" = "yes"; then -+ AC_DEFINE([HAVE_PTRACE], 1, [do we have ptrace?]) -+ fi -+ -+ have_mach_vm_read=no -+ -+ if test "$have_broken_ptrace" = "yes"; then -+ AC_MSG_CHECKING([for mach_vm_read]) -+ -+ AC_TRY_COMPILE([ #include -+ #include -+ ], [ -+ mach_vm_read((vm_map_t)0, (mach_vm_address_t)0, (mach_vm_size_t)0, (vm_offset_t *)0, (mach_msg_type_number_t*)0); -+ ], [ -+ have_mach_vm_read=yes -+ AC_MSG_RESULT([yes]) -+ ], [ -+ AC_MSG_RESULT([no]) -+ ]) -+ fi -+ -+ if test "$have_mach_vm_read" = "yes"; then -+ AC_DEFINE([HAVE_MACH_VM_READ], 1, [do we have mach_vm_read?]) -+ fi -+ -+ proc_mem_file="" -+ -+ if test -r /proc/$$/mem ; then -+ proc_mem_file="mem" -+ else -+ if test -r /proc/$$/as ; then -+ proc_mem_file="as" -+ fi -+ fi -+ -+ if test -n "$proc_mem_file" ; then -+ AC_MSG_CHECKING([for proc mem file]) -+ -+ AC_TRY_RUN([ -+ #define _GNU_SOURCE -+ #define _FILE_OFFSET_BITS 64 -+ #include -+ #include -+ #include -+ #include -+ #include -+ #include -+ int main() -+ { -+ long v1 = (unsigned int) -1, v2 = 0; -+ char buf[128]; -+ int fd; -+ sprintf(buf, "/proc/%d/$proc_mem_file", getpid()); -+ fd = open(buf, O_RDONLY); -+ if (0 > fd) { -+ return 1; -+ } -+ if (sizeof(long) != pread(fd, &v2, sizeof(long), (uintptr_t) &v1)) { -+ close(fd); -+ return 1; -+ } -+ close(fd); -+ return v1 != v2; -+ } -+ ], [ -+ AC_MSG_RESULT([$proc_mem_file]) -+ ], [ -+ proc_mem_file="" -+ AC_MSG_RESULT([no]) -+ ]) -+ fi -+ -+ if test -n "$proc_mem_file"; then -+ AC_DEFINE_UNQUOTED([PROC_MEM_FILE], "$proc_mem_file", [/proc/pid/mem interface]) -+ fi -+ -+ if test "$have_ptrace" = "yes"; then -+ FPM_SOURCES="$FPM_SOURCES fpm_trace.c fpm_trace_ptrace.c" -+ elif test -n "$proc_mem_file"; then -+ FPM_SOURCES="$FPM_SOURCES fpm_trace.c fpm_trace_pread.c" -+ elif test "$have_mach_vm_read" = "yes" ; then -+ FPM_SOURCES="$FPM_SOURCES fpm_trace.c fpm_trace_mach.c" -+ fi -+ -+]) -+ -+AC_DEFUN([AC_FPM_PRCTL], -+[ -+ AC_MSG_CHECKING([for prctl]) -+ -+ AC_TRY_COMPILE([ #include ], [prctl(0, 0, 0, 0, 0);], [ -+ AC_DEFINE([HAVE_PRCTL], 1, [do we have prctl?]) -+ AC_MSG_RESULT([yes]) -+ ], [ -+ AC_MSG_RESULT([no]) -+ ]) -+]) -diff --git a/sapi/cgi/fpm/conf/php-fpm.conf.in b/sapi/cgi/fpm/conf/php-fpm.conf.in -new file mode 100644 -index 0000000..a54b0c2 ---- /dev/null -+++ b/sapi/cgi/fpm/conf/php-fpm.conf.in -@@ -0,0 +1,156 @@ -+ -+ -+ -+ All relative paths in this config are relative to php's install prefix -+ -+
-+ -+ Pid file -+ @php_fpm_pid_path@ -+ -+ Error log file -+ @php_fpm_log_path@ -+ -+ Log level -+ notice -+ -+ When this amount of php processes exited with SIGSEGV or SIGBUS ... -+ 10 -+ -+ ... in a less than this interval of time, a graceful restart will be initiated. -+ Useful to work around accidental curruptions in accelerator's shared memory. -+ 1m -+ -+ Time limit on waiting child's reaction on signals from master -+ 5s -+ -+ Set to 'no' to debug fpm -+ yes -+ -+
-+ -+ -+ -+
-+ -+ Name of pool. Used in logs and stats. -+ default -+ -+ Address to accept fastcgi requests on. -+ Valid syntax is 'ip.ad.re.ss:port' or just 'port' or '/path/to/unix/socket' -+ 127.0.0.1:9000 -+ -+ -+ -+ Set listen(2) backlog -+ -1 -+ -+ Set permissions for unix socket, if one used. -+ In Linux read/write permissions must be set in order to allow connections from web server. -+ Many BSD-derrived systems allow connections regardless of permissions. -+ -+ -+ 0666 -+ -+ -+ Additional php.ini defines, specific to this pool of workers. -+ -+ -+ -+ -+ -+ Unix user of processes -+ -+ -+ Unix group of processes -+ -+ -+ Process manager settings -+ -+ -+ Sets style of controling worker process count. -+ Valid values are 'static' and 'apache-like' -+ static -+ -+ Sets the limit on the number of simultaneous requests that will be served. -+ Equivalent to Apache MaxClients directive. -+ Equivalent to PHP_FCGI_CHILDREN environment in original php.fcgi -+ Used with any pm_style. -+ 5 -+ -+ Settings group for 'apache-like' pm style -+ -+ -+ Sets the number of server processes created on startup. -+ Used only when 'apache-like' pm_style is selected -+ 20 -+ -+ Sets the desired minimum number of idle server processes. -+ Used only when 'apache-like' pm_style is selected -+ 5 -+ -+ Sets the desired maximum number of idle server processes. -+ Used only when 'apache-like' pm_style is selected -+ 35 -+ -+ -+ -+ -+ -+ The timeout (in seconds) for serving a single request after which the worker process will be terminated -+ Should be used when 'max_execution_time' ini option does not stop script execution for some reason -+ '0s' means 'off' -+ 0s -+ -+ The timeout (in seconds) for serving of single request after which a php backtrace will be dumped to slow.log file -+ '0s' means 'off' -+ 0s -+ -+ The log file for slow requests -+ logs/slow.log -+ -+ Set open file desc rlimit -+ 1024 -+ -+ Set max core size rlimit -+ 0 -+ -+ Chroot to this directory at the start, absolute path -+ -+ -+ Chdir to this directory at the start, absolute path -+ -+ -+ Redirect workers' stdout and stderr into main error log. -+ If not set, they will be redirected to /dev/null, according to FastCGI specs -+ yes -+ -+ How much requests each process should execute before respawn. -+ Useful to work around memory leaks in 3rd party libraries. -+ For endless request processing please specify 0 -+ Equivalent to PHP_FCGI_MAX_REQUESTS -+ 500 -+ -+ Comma separated list of ipv4 addresses of FastCGI clients that allowed to connect. -+ Equivalent to FCGI_WEB_SERVER_ADDRS environment in original php.fcgi (5.2.2+) -+ Makes sense only with AF_INET listening socket. -+ 127.0.0.1 -+ -+ Pass environment variables like LD_LIBRARY_PATH -+ All $VARIABLEs are taken from current environment -+ -+ $HOSTNAME -+ /usr/local/bin:/usr/bin:/bin -+ /tmp -+ /tmp -+ /tmp -+ $OSTYPE -+ $MACHTYPE -+ 2 -+ -+ -+
-+ -+
-+ -+
-diff --git a/sapi/cgi/fpm/config.m4 b/sapi/cgi/fpm/config.m4 -new file mode 100644 -index 0000000..65ea5e2 ---- /dev/null -+++ b/sapi/cgi/fpm/config.m4 -@@ -0,0 +1,141 @@ -+ -+FPM_VERSION="0.5.14" -+ -+PHP_ARG_WITH(fpm-conf, for php-fpm config file path, -+[ --with-fpm-conf=PATH Set the path for php-fpm configuration file [PREFIX/etc/php-fpm.conf]], \$prefix/etc/php-fpm.conf, no) -+ -+PHP_ARG_WITH(fpm-log, for php-fpm log file path, -+[ --with-fpm-log=PATH Set the path for php-fpm log file [PREFIX/logs/php-fpm.log]], \$prefix/logs/php-fpm.log, no) -+ -+PHP_ARG_WITH(fpm-pid, for php-fpm pid file path, -+[ --with-fpm-pid=PATH Set the path for php-fpm pid file [PREFIX/logs/php-fpm.pid]], \$prefix/logs/php-fpm.pid, no) -+ -+FPM_SOURCES="fpm.c \ -+ fpm_conf.c \ -+ fpm_signals.c \ -+ fpm_children.c \ -+ fpm_worker_pool.c \ -+ fpm_unix.c \ -+ fpm_cleanup.c \ -+ fpm_sockets.c \ -+ fpm_stdio.c \ -+ fpm_env.c \ -+ fpm_events.c \ -+ fpm_php.c \ -+ fpm_php_trace.c \ -+ fpm_process_ctl.c \ -+ fpm_request.c \ -+ fpm_clock.c \ -+ fpm_shm.c \ -+ fpm_shm_slots.c \ -+ xml_config.c \ -+ zlog.c" -+ -+dnl AC_FPM_LIBEVENT -+AC_FPM_LIBXML -+AC_FPM_PRCTL -+AC_FPM_CLOCK -+AC_FPM_TRACE -+dnl AC_FPM_JUDY -+ -+LIBEVENT_CFLAGS="-I$abs_srcdir/libevent" -+LIBEVENT_LIBS="$abs_builddir/libevent/libevent.a" -+ -+SAPI_EXTRA_DEPS="$LIBEVENT_LIBS" -+ -+FPM_CFLAGS="$LIBEVENT_CFLAGS $LIBXML_CFLAGS $JUDY_CFLAGS" -+ -+dnl FPM_CFLAGS="$FPM_CFLAGS -DJUDYERROR_NOTEST" # for Judy -+FPM_CFLAGS="$FPM_CFLAGS -I$abs_srcdir/sapi/cgi" # for fastcgi.h -+ -+if test "$ICC" = "yes" ; then -+ FPM_ADD_CFLAGS="-Wall -wd279,310,869,810,981" -+elif test "$GCC" = "yes" ; then -+ FPM_ADD_CFLAGS="-Wall -Wpointer-arith -Wno-unused-parameter -Wunused-variable -Wunused-value -fno-strict-aliasing" -+fi -+ -+if test -n "$FPM_WERROR" ; then -+ FPM_ADD_CFLAGS="$FPM_ADD_CFLAGS -Werror" -+fi -+ -+FPM_CFLAGS="$FPM_ADD_CFLAGS $FPM_CFLAGS" -+ -+PHP_ADD_MAKEFILE_FRAGMENT($abs_srcdir/sapi/cgi/fpm/Makefile.frag) -+ -+PHP_ADD_SOURCES(sapi/cgi/fpm, $FPM_SOURCES, $FPM_CFLAGS, sapi) -+ -+PHP_ADD_BUILD_DIR(sapi/cgi/fpm) -+ -+install_fpm="install-fpm" -+ -+PHP_CONFIGURE_PART(Configuring libevent) -+ -+test -d "$abs_builddir/libevent" || mkdir -p $abs_builddir/libevent -+ -+dnl this is a bad hack -+ -+chmod +x "$abs_srcdir/libevent/configure" \ -+ "$abs_srcdir/libevent/depcomp" \ -+ "$abs_srcdir/libevent/install-sh" \ -+ "$abs_srcdir/libevent/missing" -+ -+libevent_configure="cd $abs_builddir/libevent ; CFLAGS=\"$CFLAGS $GCC_CFLAGS\" $abs_srcdir/libevent/configure --disable-shared" -+ -+(eval $libevent_configure) -+ -+if test ! -f "$abs_builddir/libevent/Makefile" ; then -+ echo "Failed to configure libevent" >&2 -+ exit 1 -+fi -+ -+dnl another hack for stealing libevent dependant library list -+ -+LIBEVENT_LIBS="$LIBEVENT_LIBS `echo "@LIBS@" | $abs_builddir/libevent/config.status --file=-:-`" -+ -+SAPI_EXTRA_LIBS="$LIBEVENT_LIBS $LIBXML_LIBS $JUDY_LIBS" -+ -+ -+if test "$prefix" = "NONE" ; then -+ fpm_prefix=/usr/local -+else -+ fpm_prefix="$prefix" -+fi -+ -+if test "$PHP_FPM_CONF" = "\$prefix/etc/php-fpm.conf" ; then -+ php_fpm_conf_path="$fpm_prefix/etc/php-fpm.conf" -+else -+ php_fpm_conf_path="$PHP_FPM_CONF" -+fi -+ -+if test "$PHP_FPM_LOG" = "\$prefix/logs/php-fpm.log" ; then -+ php_fpm_log_path="$fpm_prefix/logs/php-fpm.log" -+else -+ php_fpm_log_path="$PHP_FPM_LOG" -+fi -+ -+if test "$PHP_FPM_PID" = "\$prefix/logs/php-fpm.pid" ; then -+ php_fpm_pid_path="$fpm_prefix/logs/php-fpm.pid" -+else -+ php_fpm_pid_path="$PHP_FPM_PID" -+fi -+ -+ -+if grep nobody /etc/group >/dev/null 2>&1; then -+ php_fpm_group=nobody -+else -+ if grep nogroup /etc/group >/dev/null 2>&1; then -+ php_fpm_group=nogroup -+ else -+ php_fpm_group=nobody -+ fi -+fi -+ -+PHP_SUBST_OLD(php_fpm_conf_path) -+PHP_SUBST_OLD(php_fpm_log_path) -+PHP_SUBST_OLD(php_fpm_pid_path) -+PHP_SUBST_OLD(php_fpm_group) -+PHP_SUBST_OLD(FPM_VERSION) -+ -+PHP_OUTPUT(sapi/cgi/fpm/fpm_autoconf.h) -+PHP_OUTPUT(sapi/cgi/fpm/php-fpm.conf:sapi/cgi/fpm/conf/php-fpm.conf.in) -+PHP_OUTPUT(sapi/cgi/fpm/php-fpm:sapi/cgi/fpm/init.d/php-fpm.in) -diff --git a/sapi/cgi/fpm/fpm.c b/sapi/cgi/fpm/fpm.c -new file mode 100644 -index 0000000..9db2c9b ---- /dev/null -+++ b/sapi/cgi/fpm/fpm.c -@@ -0,0 +1,84 @@ -+ -+ /* $Id: fpm.c,v 1.23 2008/07/20 16:38:31 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#include /* for exit */ -+ -+#include "fpm.h" -+#include "fpm_children.h" -+#include "fpm_signals.h" -+#include "fpm_env.h" -+#include "fpm_events.h" -+#include "fpm_cleanup.h" -+#include "fpm_php.h" -+#include "fpm_sockets.h" -+#include "fpm_unix.h" -+#include "fpm_process_ctl.h" -+#include "fpm_conf.h" -+#include "fpm_worker_pool.h" -+#include "fpm_stdio.h" -+#include "zlog.h" -+ -+int fpm; -+ -+struct fpm_globals_s fpm_globals; -+ -+int fpm_init(int argc, char **argv, char *config) -+{ -+ fpm_globals.argc = argc; -+ fpm_globals.argv = argv; -+ fpm_globals.config = config; -+ -+ if (0 > fpm_php_init_main() || -+ 0 > fpm_stdio_init_main() || -+ 0 > fpm_conf_init_main() || -+ 0 > fpm_unix_init_main() || -+ 0 > fpm_env_init_main() || -+ 0 > fpm_signals_init_main() || -+ 0 > fpm_pctl_init_main() || -+ 0 > fpm_children_init_main() || -+ 0 > fpm_sockets_init_main() || -+ 0 > fpm_worker_pool_init_main() || -+ 0 > fpm_event_init_main()) { -+ return -1; -+ } -+ -+ if (0 > fpm_conf_write_pid()) { -+ return -1; -+ } -+ -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "fpm is running, pid %d", (int) fpm_globals.parent_pid); -+ -+ return 0; -+} -+ -+/* children: return listening socket -+ parent: never return */ -+int fpm_run(int *max_requests) -+{ -+ struct fpm_worker_pool_s *wp; -+ -+ /* create initial children in all pools */ -+ for (wp = fpm_worker_all_pools; wp; wp = wp->next) { -+ int is_parent; -+ -+ is_parent = fpm_children_create_initial(wp); -+ -+ if (!is_parent) { -+ goto run_child; -+ } -+ } -+ -+ /* run event loop forever */ -+ fpm_event_loop(); -+ -+run_child: /* only workers reach this point */ -+ -+ fpm_cleanups_run(FPM_CLEANUP_CHILD); -+ -+ *max_requests = fpm_globals.max_requests; -+ return fpm_globals.listening_socket; -+} -+ -diff --git a/sapi/cgi/fpm/fpm.h b/sapi/cgi/fpm/fpm.h -new file mode 100644 -index 0000000..eebd2dc ---- /dev/null -+++ b/sapi/cgi/fpm/fpm.h -@@ -0,0 +1,30 @@ -+ -+ /* $Id: fpm.h,v 1.13 2008/05/24 17:38:47 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_H -+#define FPM_H 1 -+ -+#include -+ -+int fpm_run(int *max_requests); -+int fpm_init(int argc, char **argv, char *config); -+ -+struct fpm_globals_s { -+ pid_t parent_pid; -+ int argc; -+ char **argv; -+ char *config; -+ int running_children; -+ int error_log_fd; -+ int log_level; -+ int listening_socket; /* for this child */ -+ int max_requests; /* for this child */ -+ int is_child; -+}; -+ -+extern struct fpm_globals_s fpm_globals; -+ -+extern int fpm; -+ -+#endif -diff --git a/sapi/cgi/fpm/fpm_arrays.h b/sapi/cgi/fpm/fpm_arrays.h -new file mode 100644 -index 0000000..fee6661 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_arrays.h -@@ -0,0 +1,110 @@ -+ -+ /* $Id: fpm_arrays.h,v 1.2 2008/05/24 17:38:47 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_ARRAYS_H -+#define FPM_ARRAYS_H 1 -+ -+#include -+#include -+ -+struct fpm_array_s { -+ void *data; -+ size_t sz; -+ size_t used; -+ size_t allocated; -+}; -+ -+static inline struct fpm_array_s *fpm_array_init(struct fpm_array_s *a, unsigned int sz, unsigned int initial_num) -+{ -+ void *allocated = 0; -+ -+ if (!a) { -+ a = malloc(sizeof(struct fpm_array_s)); -+ -+ if (!a) { -+ return 0; -+ } -+ -+ allocated = a; -+ } -+ -+ a->sz = sz; -+ -+ a->data = calloc(sz, initial_num); -+ -+ if (!a->data) { -+ free(allocated); -+ return 0; -+ } -+ -+ a->allocated = initial_num; -+ a->used = 0; -+ -+ return a; -+} -+ -+static inline void *fpm_array_item(struct fpm_array_s *a, unsigned int n) -+{ -+ char *ret; -+ -+ ret = (char *) a->data + a->sz * n; -+ -+ return ret; -+} -+ -+static inline void *fpm_array_item_last(struct fpm_array_s *a) -+{ -+ return fpm_array_item(a, a->used - 1); -+} -+ -+static inline int fpm_array_item_remove(struct fpm_array_s *a, unsigned int n) -+{ -+ int ret = -1; -+ -+ if (n < a->used - 1) { -+ void *last = fpm_array_item(a, a->used - 1); -+ void *to_remove = fpm_array_item(a, n); -+ -+ memcpy(to_remove, last, a->sz); -+ -+ ret = n; -+ } -+ -+ --a->used; -+ -+ return ret; -+} -+ -+static inline void *fpm_array_push(struct fpm_array_s *a) -+{ -+ void *ret; -+ -+ if (a->used == a->allocated) { -+ size_t new_allocated = a->allocated ? a->allocated * 2 : 20; -+ void *new_ptr = realloc(a->data, a->sz * new_allocated); -+ -+ if (!new_ptr) { -+ return 0; -+ } -+ -+ a->data = new_ptr; -+ a->allocated = new_allocated; -+ } -+ -+ ret = fpm_array_item(a, a->used); -+ -+ ++a->used; -+ -+ return ret; -+} -+ -+static inline void fpm_array_free(struct fpm_array_s *a) -+{ -+ free(a->data); -+ a->data = 0; -+ a->sz = 0; -+ a->used = a->allocated = 0; -+} -+ -+#endif -diff --git a/sapi/cgi/fpm/fpm_atomic.h b/sapi/cgi/fpm/fpm_atomic.h -new file mode 100644 -index 0000000..3334ae0 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_atomic.h -@@ -0,0 +1,85 @@ -+ -+ /* $Id: fpm_atomic.h,v 1.3 2008/09/18 23:34:11 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_ATOMIC_H -+#define FPM_ATOMIC_H 1 -+ -+#include -+#include -+ -+#if ( __i386__ || __i386 ) -+ -+typedef int32_t atomic_int_t; -+typedef uint32_t atomic_uint_t; -+typedef volatile atomic_uint_t atomic_t; -+ -+ -+static inline atomic_int_t atomic_fetch_add(atomic_t *value, atomic_int_t add) -+{ -+ __asm__ volatile ( "lock;" "xaddl %0, %1;" : -+ "+r" (add) : "m" (*value) : "memory"); -+ -+ return add; -+} -+ -+static inline atomic_uint_t atomic_cmp_set(atomic_t *lock, atomic_uint_t old, atomic_uint_t set) -+{ -+ unsigned char res; -+ -+ __asm__ volatile ( "lock;" "cmpxchgl %3, %1;" "sete %0;" : -+ "=a" (res) : "m" (*lock), "a" (old), "r" (set) : "memory"); -+ -+ return res; -+} -+ -+#elif ( __amd64__ || __amd64 ) -+ -+typedef int64_t atomic_int_t; -+typedef uint64_t atomic_uint_t; -+typedef volatile atomic_uint_t atomic_t; -+ -+static inline atomic_int_t atomic_fetch_add(atomic_t *value, atomic_int_t add) -+{ -+ __asm__ volatile ( "lock;" "xaddq %0, %1;" : -+ "+r" (add) : "m" (*value) : "memory"); -+ -+ return add; -+} -+ -+static inline atomic_uint_t atomic_cmp_set(atomic_t *lock, atomic_uint_t old, atomic_uint_t set) -+{ -+ unsigned char res; -+ -+ __asm__ volatile ( "lock;" "cmpxchgq %3, %1;" "sete %0;" : -+ "=a" (res) : "m" (*lock), "a" (old), "r" (set) : "memory"); -+ -+ return res; -+} -+ -+#else -+ -+#error unsupported processor. please write a patch and send it to me -+ -+#endif -+ -+static inline int fpm_spinlock(atomic_t *lock, int try_once) -+{ -+ if (try_once) { -+ return atomic_cmp_set(lock, 0, 1) ? 0 : -1; -+ } -+ -+ for (;;) { -+ -+ if (atomic_cmp_set(lock, 0, 1)) { -+ break; -+ } -+ -+ sched_yield(); -+ } -+ -+ return 0; -+} -+ -+#endif -+ -diff --git a/sapi/cgi/fpm/fpm_autoconf.h.in b/sapi/cgi/fpm/fpm_autoconf.h.in -new file mode 100644 -index 0000000..d00c165 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_autoconf.h.in -@@ -0,0 +1,9 @@ -+ -+ /* $Id: fpm_autoconf.h.in,v 1.3 2008/05/24 17:38:47 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#define PHP_FPM_VERSION "@FPM_VERSION@" -+#define PHP_FPM_CONF_PATH "@php_fpm_conf_path@" -+#define PHP_FPM_LOG_PATH "@php_fpm_log_path@" -+#define PHP_FPM_PID_PATH "@php_fpm_pid_path@" -+ -diff --git a/sapi/cgi/fpm/fpm_children.c b/sapi/cgi/fpm/fpm_children.c -new file mode 100644 -index 0000000..f586405 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_children.c -@@ -0,0 +1,385 @@ -+ -+ /* $Id: fpm_children.c,v 1.32.2.2 2008/12/13 03:21:18 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#include -+#include -+#include -+#include -+#include -+#include -+ -+#include "fpm.h" -+#include "fpm_children.h" -+#include "fpm_signals.h" -+#include "fpm_worker_pool.h" -+#include "fpm_sockets.h" -+#include "fpm_process_ctl.h" -+#include "fpm_php.h" -+#include "fpm_conf.h" -+#include "fpm_cleanup.h" -+#include "fpm_events.h" -+#include "fpm_clock.h" -+#include "fpm_stdio.h" -+#include "fpm_unix.h" -+#include "fpm_env.h" -+#include "fpm_shm_slots.h" -+ -+#include "zlog.h" -+ -+static time_t *last_faults; -+static int fault; -+ -+static int fpm_children_make(struct fpm_worker_pool_s *wp, int in_event_loop); -+ -+static void fpm_children_cleanup(int which, void *arg) -+{ -+ free(last_faults); -+} -+ -+static struct fpm_child_s *fpm_child_alloc() -+{ -+ struct fpm_child_s *ret; -+ -+ ret = malloc(sizeof(struct fpm_child_s)); -+ -+ if (!ret) return 0; -+ -+ memset(ret, 0, sizeof(*ret)); -+ -+ return ret; -+} -+ -+static void fpm_child_free(struct fpm_child_s *child) -+{ -+ free(child); -+} -+ -+static void fpm_child_close(struct fpm_child_s *child, int in_event_loop) -+{ -+ if (child->fd_stdout != -1) { -+ if (in_event_loop) { -+ fpm_event_fire(&child->ev_stdout); -+ } -+ if (child->fd_stdout != -1) { -+ close(child->fd_stdout); -+ } -+ } -+ -+ if (child->fd_stderr != -1) { -+ if (in_event_loop) { -+ fpm_event_fire(&child->ev_stderr); -+ } -+ if (child->fd_stderr != -1) { -+ close(child->fd_stderr); -+ } -+ } -+ -+ fpm_child_free(child); -+} -+ -+static void fpm_child_link(struct fpm_child_s *child) -+{ -+ struct fpm_worker_pool_s *wp = child->wp; -+ -+ ++wp->running_children; -+ ++fpm_globals.running_children; -+ -+ child->next = wp->children; -+ if (child->next) child->next->prev = child; -+ child->prev = 0; -+ wp->children = child; -+} -+ -+static void fpm_child_unlink(struct fpm_child_s *child) -+{ -+ --child->wp->running_children; -+ --fpm_globals.running_children; -+ -+ if (child->prev) child->prev->next = child->next; -+ else child->wp->children = child->next; -+ if (child->next) child->next->prev = child->prev; -+ -+} -+ -+static struct fpm_child_s *fpm_child_find(pid_t pid) -+{ -+ struct fpm_worker_pool_s *wp; -+ struct fpm_child_s *child = 0; -+ -+ for (wp = fpm_worker_all_pools; wp; wp = wp->next) { -+ -+ for (child = wp->children; child; child = child->next) { -+ if (child->pid == pid) { -+ break; -+ } -+ } -+ -+ if (child) break; -+ } -+ -+ if (!child) { -+ return 0; -+ } -+ -+ return child; -+} -+ -+static void fpm_child_init(struct fpm_worker_pool_s *wp) -+{ -+ fpm_globals.max_requests = wp->config->max_requests; -+ -+ if (0 > fpm_stdio_init_child(wp) || -+ 0 > fpm_unix_init_child(wp) || -+ 0 > fpm_signals_init_child() || -+ 0 > fpm_env_init_child(wp) || -+ 0 > fpm_php_init_child(wp)) { -+ -+ zlog(ZLOG_STUFF, ZLOG_ERROR, "child failed to initialize (pool %s)", wp->config->name); -+ exit(255); -+ } -+} -+ -+int fpm_children_free(struct fpm_child_s *child) -+{ -+ struct fpm_child_s *next; -+ -+ for (; child; child = next) { -+ next = child->next; -+ fpm_child_close(child, 0 /* in_event_loop */); -+ } -+ -+ return 0; -+} -+ -+void fpm_children_bury() -+{ -+ int status; -+ pid_t pid; -+ struct fpm_child_s *child; -+ -+ while ( (pid = waitpid(-1, &status, WNOHANG | WUNTRACED)) > 0) { -+ char buf[128]; -+ int severity = ZLOG_NOTICE; -+ -+ child = fpm_child_find(pid); -+ -+ if (WIFEXITED(status)) { -+ -+ snprintf(buf, sizeof(buf), "with code %d", WEXITSTATUS(status)); -+ -+ if (WEXITSTATUS(status) != 0) { -+ severity = ZLOG_WARNING; -+ } -+ -+ } -+ else if (WIFSIGNALED(status)) { -+ const char *signame = fpm_signal_names[WTERMSIG(status)]; -+ const char *have_core = WCOREDUMP(status) ? " (core dumped)" : ""; -+ -+ if (signame == NULL) { -+ signame = ""; -+ } -+ -+ snprintf(buf, sizeof(buf), "on signal %d %s%s", WTERMSIG(status), signame, have_core); -+ -+ if (WTERMSIG(status) != SIGQUIT) { /* possible request loss */ -+ severity = ZLOG_WARNING; -+ } -+ } -+ else if (WIFSTOPPED(status)) { -+ -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "child %d stopped for tracing", (int) pid); -+ -+ if (child && child->tracer) { -+ child->tracer(child); -+ } -+ -+ continue; -+ } -+ -+ if (child) { -+ struct fpm_worker_pool_s *wp = child->wp; -+ struct timeval tv1, tv2; -+ -+ fpm_child_unlink(child); -+ -+ fpm_shm_slots_discard_slot(child); -+ -+ fpm_clock_get(&tv1); -+ -+ timersub(&tv1, &child->started, &tv2); -+ -+ zlog(ZLOG_STUFF, severity, "child %d (pool %s) exited %s after %ld.%06d seconds from start", (int) pid, -+ child->wp->config->name, buf, tv2.tv_sec, (int) tv2.tv_usec); -+ -+ fpm_child_close(child, 1 /* in event_loop */); -+ -+ fpm_pctl_child_exited(); -+ -+ if (last_faults && (WTERMSIG(status) == SIGSEGV || WTERMSIG(status) == SIGBUS)) { -+ time_t now = tv1.tv_sec; -+ int restart_condition = 1; -+ int i; -+ -+ last_faults[fault++] = now; -+ -+ if (fault == fpm_global_config.emergency_restart_threshold) { -+ fault = 0; -+ } -+ -+ for (i = 0; i < fpm_global_config.emergency_restart_threshold; i++) { -+ if (now - last_faults[i] > fpm_global_config.emergency_restart_interval) { -+ restart_condition = 0; -+ break; -+ } -+ } -+ -+ if (restart_condition) { -+ -+ zlog(ZLOG_STUFF, ZLOG_WARNING, "failed processes threshold (%d in %d sec) is reached, initiating reload", -+ fpm_global_config.emergency_restart_threshold, fpm_global_config.emergency_restart_interval); -+ -+ fpm_pctl(FPM_PCTL_STATE_RELOADING, FPM_PCTL_ACTION_SET); -+ } -+ } -+ -+ fpm_children_make(wp, 1 /* in event loop */); -+ -+ if (fpm_globals.is_child) { -+ break; -+ } -+ } -+ else { -+ zlog(ZLOG_STUFF, ZLOG_ALERT, "oops, unknown child exited %s", buf); -+ } -+ } -+ -+} -+ -+static struct fpm_child_s *fpm_resources_prepare(struct fpm_worker_pool_s *wp) -+{ -+ struct fpm_child_s *c; -+ -+ c = fpm_child_alloc(); -+ -+ if (!c) { -+ zlog(ZLOG_STUFF, ZLOG_ERROR, "malloc failed (pool %s)", wp->config->name); -+ return 0; -+ } -+ -+ c->wp = wp; -+ c->fd_stdout = -1; c->fd_stderr = -1; -+ -+ if (0 > fpm_stdio_prepare_pipes(c)) { -+ fpm_child_free(c); -+ return 0; -+ } -+ -+ if (0 > fpm_shm_slots_prepare_slot(c)) { -+ fpm_stdio_discard_pipes(c); -+ fpm_child_free(c); -+ return 0; -+ } -+ -+ return c; -+} -+ -+static void fpm_resources_discard(struct fpm_child_s *child) -+{ -+ fpm_shm_slots_discard_slot(child); -+ fpm_stdio_discard_pipes(child); -+ fpm_child_free(child); -+} -+ -+static void fpm_child_resources_use(struct fpm_child_s *child) -+{ -+ fpm_shm_slots_child_use_slot(child); -+ fpm_stdio_child_use_pipes(child); -+ fpm_child_free(child); -+} -+ -+static void fpm_parent_resources_use(struct fpm_child_s *child) -+{ -+ fpm_shm_slots_parent_use_slot(child); -+ fpm_stdio_parent_use_pipes(child); -+ fpm_child_link(child); -+} -+ -+static int fpm_children_make(struct fpm_worker_pool_s *wp, int in_event_loop) -+{ -+ int enough = 0; -+ pid_t pid; -+ struct fpm_child_s *child; -+ -+ while (!enough && fpm_pctl_can_spawn_children() && wp->running_children < wp->config->pm->max_children) { -+ -+ child = fpm_resources_prepare(wp); -+ -+ if (!child) { -+ enough = 1; -+ break; -+ } -+ -+ pid = fork(); -+ -+ switch (pid) { -+ -+ case 0 : -+ fpm_child_resources_use(child); -+ fpm_globals.is_child = 1; -+ if (in_event_loop) { -+ fpm_event_exit_loop(); -+ } -+ fpm_child_init(wp); -+ return 0; -+ -+ case -1 : -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "fork() failed"); -+ enough = 1; -+ -+ fpm_resources_discard(child); -+ -+ break; /* dont try any more on error */ -+ -+ default : -+ child->pid = pid; -+ fpm_clock_get(&child->started); -+ fpm_parent_resources_use(child); -+ -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "child %d (pool %s) started", (int) pid, wp->config->name); -+ } -+ -+ } -+ -+ return 1; /* we are done */ -+} -+ -+int fpm_children_create_initial(struct fpm_worker_pool_s *wp) -+{ -+ return fpm_children_make(wp, 0 /* not in event loop yet */); -+} -+ -+int fpm_children_init_main() -+{ -+ if (fpm_global_config.emergency_restart_threshold && -+ fpm_global_config.emergency_restart_interval) { -+ -+ last_faults = malloc(sizeof(time_t) * fpm_global_config.emergency_restart_threshold); -+ -+ if (!last_faults) { -+ return -1; -+ } -+ -+ memset(last_faults, 0, sizeof(time_t) * fpm_global_config.emergency_restart_threshold); -+ } -+ -+ if (0 > fpm_cleanup_add(FPM_CLEANUP_ALL, fpm_children_cleanup, 0)) { -+ return -1; -+ } -+ -+ return 0; -+} -+ -diff --git a/sapi/cgi/fpm/fpm_children.h b/sapi/cgi/fpm/fpm_children.h -new file mode 100644 -index 0000000..c85adf9 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_children.h -@@ -0,0 +1,33 @@ -+ -+ /* $Id: fpm_children.h,v 1.9 2008/05/24 17:38:47 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_CHILDREN_H -+#define FPM_CHILDREN_H 1 -+ -+#include -+#include -+#include -+ -+#include "fpm_worker_pool.h" -+ -+int fpm_children_create_initial(struct fpm_worker_pool_s *wp); -+int fpm_children_free(struct fpm_child_s *child); -+void fpm_children_bury(); -+int fpm_children_init_main(); -+ -+struct fpm_child_s; -+ -+struct fpm_child_s { -+ struct fpm_child_s *prev, *next; -+ struct timeval started; -+ struct fpm_worker_pool_s *wp; -+ struct event ev_stdout, ev_stderr; -+ int shm_slot_i; -+ int fd_stdout, fd_stderr; -+ void (*tracer)(struct fpm_child_s *); -+ struct timeval slow_logged; -+ pid_t pid; -+}; -+ -+#endif -diff --git a/sapi/cgi/fpm/fpm_cleanup.c b/sapi/cgi/fpm/fpm_cleanup.c -new file mode 100644 -index 0000000..b4ef7bb ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_cleanup.c -@@ -0,0 +1,51 @@ -+ -+ /* $Id: fpm_cleanup.c,v 1.8 2008/05/24 17:38:47 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#include -+ -+#include "fpm_arrays.h" -+#include "fpm_cleanup.h" -+#include "zlog.h" -+ -+struct cleanup_s { -+ int type; -+ void (*cleanup)(int, void *); -+ void *arg; -+}; -+ -+static struct fpm_array_s cleanups = { .sz = sizeof(struct cleanup_s) }; -+ -+int fpm_cleanup_add(int type, void (*cleanup)(int, void *), void *arg) -+{ -+ struct cleanup_s *c; -+ -+ c = fpm_array_push(&cleanups); -+ -+ if (!c) { -+ return -1; -+ } -+ -+ c->type = type; -+ c->cleanup = cleanup; -+ c->arg = arg; -+ -+ return 0; -+} -+ -+void fpm_cleanups_run(int type) -+{ -+ struct cleanup_s *c = fpm_array_item_last(&cleanups); -+ int cl = cleanups.used; -+ -+ for ( ; cl--; c--) { -+ if (c->type & type) { -+ c->cleanup(type, c->arg); -+ } -+ } -+ -+ fpm_array_free(&cleanups); -+} -+ -diff --git a/sapi/cgi/fpm/fpm_cleanup.h b/sapi/cgi/fpm/fpm_cleanup.h -new file mode 100644 -index 0000000..4d7cf39 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_cleanup.h -@@ -0,0 +1,21 @@ -+ -+ /* $Id: fpm_cleanup.h,v 1.5 2008/05/24 17:38:47 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_CLEANUP_H -+#define FPM_CLEANUP_H 1 -+ -+int fpm_cleanup_add(int type, void (*cleanup)(int, void *), void *); -+void fpm_cleanups_run(int type); -+ -+enum { -+ FPM_CLEANUP_CHILD = (1 << 0), -+ FPM_CLEANUP_PARENT_EXIT = (1 << 1), -+ FPM_CLEANUP_PARENT_EXIT_MAIN = (1 << 2), -+ FPM_CLEANUP_PARENT_EXEC = (1 << 3), -+ FPM_CLEANUP_PARENT = (1 << 1) | (1 << 2) | (1 << 3), -+ FPM_CLEANUP_ALL = ~0, -+}; -+ -+#endif -+ -diff --git a/sapi/cgi/fpm/fpm_clock.c b/sapi/cgi/fpm/fpm_clock.c -new file mode 100644 -index 0000000..2abbce8 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_clock.c -@@ -0,0 +1,115 @@ -+ -+ /* $Id: fpm_clock.c,v 1.4 2008/09/18 23:19:59 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#if defined(HAVE_CLOCK_GETTIME) -+#include /* for CLOCK_MONOTONIC */ -+#endif -+ -+#include "fpm_clock.h" -+#include "zlog.h" -+ -+ -+/* posix monotonic clock - preferred source of time */ -+#if defined(HAVE_CLOCK_GETTIME) && defined(CLOCK_MONOTONIC) -+ -+static int monotonic_works; -+ -+int fpm_clock_init() -+{ -+ struct timespec ts; -+ -+ monotonic_works = 0; -+ -+ if (0 == clock_gettime(CLOCK_MONOTONIC, &ts)) { -+ monotonic_works = 1; -+ } -+ -+ return 0; -+} -+ -+int fpm_clock_get(struct timeval *tv) -+{ -+ if (monotonic_works) { -+ struct timespec ts; -+ -+ if (0 > clock_gettime(CLOCK_MONOTONIC, &ts)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "clock_gettime() failed"); -+ return -1; -+ } -+ -+ tv->tv_sec = ts.tv_sec; -+ tv->tv_usec = ts.tv_nsec / 1000; -+ return 0; -+ } -+ -+ return gettimeofday(tv, 0); -+} -+ -+/* macosx clock */ -+#elif defined(HAVE_CLOCK_GET_TIME) -+ -+#include -+#include -+#include -+ -+static clock_serv_t mach_clock; -+ -+/* this code borrowed from here: http://lists.apple.com/archives/Darwin-development/2002/Mar/msg00746.html */ -+/* mach_clock also should be re-initialized in child process after fork */ -+int fpm_clock_init() -+{ -+ kern_return_t ret; -+ mach_timespec_t aTime; -+ -+ ret = host_get_clock_service(mach_host_self(), REALTIME_CLOCK, &mach_clock); -+ -+ if (ret != KERN_SUCCESS) { -+ zlog(ZLOG_STUFF, ZLOG_ERROR, "host_get_clock_service() failed: %s", mach_error_string(ret)); -+ return -1; -+ } -+ -+ /* test if it works */ -+ ret = clock_get_time(mach_clock, &aTime); -+ -+ if (ret != KERN_SUCCESS) { -+ zlog(ZLOG_STUFF, ZLOG_ERROR, "clock_get_time() failed: %s", mach_error_string(ret)); -+ return -1; -+ } -+ -+ return 0; -+} -+ -+int fpm_clock_get(struct timeval *tv) -+{ -+ kern_return_t ret; -+ mach_timespec_t aTime; -+ -+ ret = clock_get_time(mach_clock, &aTime); -+ -+ if (ret != KERN_SUCCESS) { -+ zlog(ZLOG_STUFF, ZLOG_ERROR, "clock_get_time() failed: %s", mach_error_string(ret)); -+ return -1; -+ } -+ -+ tv->tv_sec = aTime.tv_sec; -+ tv->tv_usec = aTime.tv_nsec / 1000; -+ -+ return 0; -+} -+ -+#else /* no clock */ -+ -+int fpm_clock_init() -+{ -+ return 0; -+} -+ -+int fpm_clock_get(struct timeval *tv) -+{ -+ return gettimeofday(tv, 0); -+} -+ -+#endif -diff --git a/sapi/cgi/fpm/fpm_clock.h b/sapi/cgi/fpm/fpm_clock.h -new file mode 100644 -index 0000000..6aab959 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_clock.h -@@ -0,0 +1,13 @@ -+ -+ /* $Id: fpm_clock.h,v 1.2 2008/05/24 17:38:47 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_CLOCK_H -+#define FPM_CLOCK_H 1 -+ -+#include -+ -+int fpm_clock_init(); -+int fpm_clock_get(struct timeval *tv); -+ -+#endif -diff --git a/sapi/cgi/fpm/fpm_conf.c b/sapi/cgi/fpm/fpm_conf.c -new file mode 100644 -index 0000000..adf4f1a ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_conf.c -@@ -0,0 +1,532 @@ -+ -+ /* $Id: fpm_conf.c,v 1.33.2.3 2008/12/13 03:50:29 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+ -+#include "fpm.h" -+#include "fpm_conf.h" -+#include "fpm_stdio.h" -+#include "fpm_worker_pool.h" -+#include "fpm_cleanup.h" -+#include "fpm_php.h" -+#include "fpm_sockets.h" -+#include "xml_config.h" -+#include "zlog.h" -+ -+ -+struct fpm_global_config_s fpm_global_config; -+ -+static void *fpm_global_config_ptr() -+{ -+ return &fpm_global_config; -+} -+ -+static char *fpm_conf_set_log_level(void **conf, char *name, void *vv, intptr_t offset) -+{ -+ char *value = vv; -+ -+ if (!strcmp(value, "debug")) { -+ fpm_globals.log_level = ZLOG_DEBUG; -+ } -+ else if (!strcmp(value, "notice")) { -+ fpm_globals.log_level = ZLOG_NOTICE; -+ } -+ else if (!strcmp(value, "warn")) { -+ fpm_globals.log_level = ZLOG_WARNING; -+ } -+ else if (!strcmp(value, "error")) { -+ fpm_globals.log_level = ZLOG_ERROR; -+ } -+ else if (!strcmp(value, "alert")) { -+ fpm_globals.log_level = ZLOG_ALERT; -+ } -+ else { -+ return "invalid value for 'log_level'"; -+ } -+ -+ return NULL; -+} -+ -+static struct xml_conf_section xml_section_fpm_global_options = { -+ .conf = &fpm_global_config_ptr, -+ .path = "/configuration/global_options", -+ .parsers = (struct xml_value_parser []) { -+ { XML_CONF_SCALAR, "emergency_restart_threshold", &xml_conf_set_slot_integer, offsetof(struct fpm_global_config_s, emergency_restart_threshold) }, -+ { XML_CONF_SCALAR, "emergency_restart_interval", &xml_conf_set_slot_time, offsetof(struct fpm_global_config_s, emergency_restart_interval) }, -+ { XML_CONF_SCALAR, "process_control_timeout", &xml_conf_set_slot_time, offsetof(struct fpm_global_config_s, process_control_timeout) }, -+ { XML_CONF_SCALAR, "daemonize", &xml_conf_set_slot_boolean, offsetof(struct fpm_global_config_s, daemonize) }, -+ { XML_CONF_SCALAR, "pid_file", &xml_conf_set_slot_string, offsetof(struct fpm_global_config_s, pid_file) }, -+ { XML_CONF_SCALAR, "error_log", &xml_conf_set_slot_string, offsetof(struct fpm_global_config_s, error_log) }, -+ { XML_CONF_SCALAR, "log_level", &fpm_conf_set_log_level, 0 }, -+ { 0, 0, 0, 0 } -+ } -+}; -+ -+static char *fpm_conf_set_pm_style(void **conf, char *name, void *vv, intptr_t offset) -+{ -+ char *value = vv; -+ struct fpm_pm_s *c = *conf; -+ -+ if (!strcmp(value, "static")) { -+ c->style = PM_STYLE_STATIC; -+ } -+ else if (!strcmp(value, "apache-like")) { -+ c->style = PM_STYLE_APACHE_LIKE; -+ } -+ else { -+ return "invalid value for 'style'"; -+ } -+ -+ return NULL; -+} -+ -+static char *fpm_conf_set_rlimit_core(void **conf, char *name, void *vv, intptr_t offset) -+{ -+ char *value = vv; -+ struct fpm_worker_pool_config_s *c = *conf; -+ -+ if (!strcmp(value, "unlimited")) { -+ c->rlimit_core = -1; -+ } -+ else { -+ int int_value; -+ void *subconf = &int_value; -+ char *error; -+ -+ error = xml_conf_set_slot_integer(&subconf, name, vv, 0); -+ -+ if (error) return error; -+ -+ if (int_value < 0) return "invalid value for 'rlimit_core'"; -+ -+ c->rlimit_core = int_value; -+ } -+ -+ return NULL; -+} -+ -+static char *fpm_conf_set_catch_workers_output(void **conf, char *name, void *vv, intptr_t offset) -+{ -+ struct fpm_worker_pool_config_s *c = *conf; -+ int int_value; -+ void *subconf = &int_value; -+ char *error; -+ -+ error = xml_conf_set_slot_boolean(&subconf, name, vv, 0); -+ -+ if (error) return error; -+ -+ c->catch_workers_output = int_value; -+ -+ return NULL; -+} -+ -+static struct xml_conf_section fpm_conf_set_apache_like_subsection_conf = { -+ .path = "apache_like somewhere", /* fixme */ -+ .parsers = (struct xml_value_parser []) { -+ { XML_CONF_SCALAR, "StartServers", &xml_conf_set_slot_integer, offsetof(struct fpm_pm_s, options_apache_like.StartServers) }, -+ { XML_CONF_SCALAR, "MinSpareServers", &xml_conf_set_slot_integer, offsetof(struct fpm_pm_s, options_apache_like.MinSpareServers) }, -+ { XML_CONF_SCALAR, "MaxSpareServers", &xml_conf_set_slot_integer, offsetof(struct fpm_pm_s, options_apache_like.MaxSpareServers) }, -+ { 0, 0, 0, 0 } -+ } -+}; -+ -+static char *fpm_conf_set_apache_like_subsection(void **conf, char *name, void *xml_node, intptr_t offset) -+{ -+ return xml_conf_parse_section(conf, &fpm_conf_set_apache_like_subsection_conf, xml_node); -+} -+ -+static struct xml_conf_section fpm_conf_set_listen_options_subsection_conf = { -+ .path = "listen options somewhere", /* fixme */ -+ .parsers = (struct xml_value_parser []) { -+ { XML_CONF_SCALAR, "backlog", &xml_conf_set_slot_integer, offsetof(struct fpm_listen_options_s, backlog) }, -+ { XML_CONF_SCALAR, "owner", &xml_conf_set_slot_string, offsetof(struct fpm_listen_options_s, owner) }, -+ { XML_CONF_SCALAR, "group", &xml_conf_set_slot_string, offsetof(struct fpm_listen_options_s, group) }, -+ { XML_CONF_SCALAR, "mode", &xml_conf_set_slot_string, offsetof(struct fpm_listen_options_s, mode) }, -+ { 0, 0, 0, 0 } -+ } -+}; -+ -+static char *fpm_conf_set_listen_options_subsection(void **conf, char *name, void *xml_node, intptr_t offset) -+{ -+ void *subconf = (char *) *conf + offset; -+ struct fpm_listen_options_s *lo; -+ -+ lo = malloc(sizeof(*lo)); -+ -+ if (!lo) { -+ return "malloc() failed"; -+ } -+ -+ memset(lo, 0, sizeof(*lo)); -+ -+ lo->backlog = -1; -+ -+ * (struct fpm_listen_options_s **) subconf = lo; -+ -+ subconf = lo; -+ -+ return xml_conf_parse_section(&subconf, &fpm_conf_set_listen_options_subsection_conf, xml_node); -+} -+ -+static struct xml_conf_section fpm_conf_set_pm_subsection_conf = { -+ .path = "pm settings somewhere", /* fixme */ -+ .parsers = (struct xml_value_parser []) { -+ { XML_CONF_SCALAR, "style", &fpm_conf_set_pm_style, 0 }, -+ { XML_CONF_SCALAR, "max_children", &xml_conf_set_slot_integer, offsetof(struct fpm_pm_s, max_children) }, -+ { XML_CONF_SUBSECTION, "apache_like", &fpm_conf_set_apache_like_subsection, offsetof(struct fpm_pm_s, options_apache_like) }, -+ { 0, 0, 0, 0 } -+ } -+}; -+ -+static char *fpm_conf_set_pm_subsection(void **conf, char *name, void *xml_node, intptr_t offset) -+{ -+ void *subconf = (char *) *conf + offset; -+ struct fpm_pm_s *pm; -+ -+ pm = malloc(sizeof(*pm)); -+ -+ if (!pm) { -+ return "fpm_conf_set_pm_subsection(): malloc failed"; -+ } -+ -+ memset(pm, 0, sizeof(*pm)); -+ -+ * (struct fpm_pm_s **) subconf = pm; -+ -+ subconf = pm; -+ -+ return xml_conf_parse_section(&subconf, &fpm_conf_set_pm_subsection_conf, xml_node); -+} -+ -+static char *xml_conf_set_slot_key_value_pair(void **conf, char *name, void *vv, intptr_t offset) -+{ -+ char *value = vv; -+ struct key_value_s *kv; -+ struct key_value_s ***parent = (struct key_value_s ***) conf; -+ -+ kv = malloc(sizeof(*kv)); -+ -+ if (!kv) { -+ return "malloc() failed"; -+ } -+ -+ memset(kv, 0, sizeof(*kv)); -+ -+ kv->key = strdup(name); -+ kv->value = strdup(value); -+ -+ if (!kv->key || !kv->value) { -+ return "xml_conf_set_slot_key_value_pair(): strdup() failed"; -+ } -+ -+ **parent = kv; -+ -+ *parent = &kv->next; -+ -+ return NULL; -+} -+ -+static struct xml_conf_section fpm_conf_set_key_value_pairs_subsection_conf = { -+ .path = "key_value_pairs somewhere", /* fixme */ -+ .parsers = (struct xml_value_parser []) { -+ { XML_CONF_SCALAR, 0, &xml_conf_set_slot_key_value_pair, 0 }, -+ { 0, 0, 0, 0 } -+ } -+}; -+ -+static char *fpm_conf_set_key_value_pairs_subsection(void **conf, char *name, void *xml_node, intptr_t offset) -+{ -+ void *next_kv = (char *) *conf + offset; -+ -+ return xml_conf_parse_section(&next_kv, &fpm_conf_set_key_value_pairs_subsection_conf, xml_node); -+} -+ -+static void *fpm_worker_pool_config_alloc() -+{ -+ static struct fpm_worker_pool_s *current_wp = 0; -+ struct fpm_worker_pool_s *wp; -+ -+ wp = fpm_worker_pool_alloc(); -+ -+ if (!wp) return 0; -+ -+ wp->config = malloc(sizeof(struct fpm_worker_pool_config_s)); -+ -+ if (!wp->config) return 0; -+ -+ memset(wp->config, 0, sizeof(struct fpm_worker_pool_config_s)); -+ -+ if (current_wp) current_wp->next = wp; -+ -+ current_wp = wp; -+ -+ return wp->config; -+} -+ -+int fpm_worker_pool_config_free(struct fpm_worker_pool_config_s *wpc) -+{ -+ struct key_value_s *kv, *kv_next; -+ -+ free(wpc->name); -+ free(wpc->listen_address); -+ if (wpc->listen_options) { -+ free(wpc->listen_options->owner); -+ free(wpc->listen_options->group); -+ free(wpc->listen_options->mode); -+ free(wpc->listen_options); -+ } -+ for (kv = wpc->php_defines; kv; kv = kv_next) { -+ kv_next = kv->next; -+ free(kv->key); -+ free(kv->value); -+ free(kv); -+ } -+ for (kv = wpc->environment; kv; kv = kv_next) { -+ kv_next = kv->next; -+ free(kv->key); -+ free(kv->value); -+ free(kv); -+ } -+ free(wpc->pm); -+ free(wpc->user); -+ free(wpc->group); -+ free(wpc->chroot); -+ free(wpc->chdir); -+ free(wpc->allowed_clients); -+ free(wpc->slowlog); -+ -+ return 0; -+} -+ -+static struct xml_conf_section xml_section_fpm_worker_pool_config = { -+ .conf = &fpm_worker_pool_config_alloc, -+ .path = "/configuration/workers/pool", -+ .parsers = (struct xml_value_parser []) { -+ { XML_CONF_SCALAR, "name", &xml_conf_set_slot_string, offsetof(struct fpm_worker_pool_config_s, name) }, -+ { XML_CONF_SCALAR, "listen_address", &xml_conf_set_slot_string, offsetof(struct fpm_worker_pool_config_s, listen_address) }, -+ { XML_CONF_SUBSECTION, "listen_options", &fpm_conf_set_listen_options_subsection, offsetof(struct fpm_worker_pool_config_s, listen_options) }, -+ { XML_CONF_SUBSECTION, "php_defines", &fpm_conf_set_key_value_pairs_subsection, offsetof(struct fpm_worker_pool_config_s, php_defines) }, -+ { XML_CONF_SCALAR, "user", &xml_conf_set_slot_string, offsetof(struct fpm_worker_pool_config_s, user) }, -+ { XML_CONF_SCALAR, "group", &xml_conf_set_slot_string, offsetof(struct fpm_worker_pool_config_s, group) }, -+ { XML_CONF_SCALAR, "chroot", &xml_conf_set_slot_string, offsetof(struct fpm_worker_pool_config_s, chroot) }, -+ { XML_CONF_SCALAR, "chdir", &xml_conf_set_slot_string, offsetof(struct fpm_worker_pool_config_s, chdir) }, -+ { XML_CONF_SCALAR, "allowed_clients", &xml_conf_set_slot_string, offsetof(struct fpm_worker_pool_config_s, allowed_clients) }, -+ { XML_CONF_SUBSECTION, "environment", &fpm_conf_set_key_value_pairs_subsection, offsetof(struct fpm_worker_pool_config_s, environment) }, -+ { XML_CONF_SCALAR, "request_terminate_timeout", &xml_conf_set_slot_time, offsetof(struct fpm_worker_pool_config_s, request_terminate_timeout) }, -+ { XML_CONF_SCALAR, "request_slowlog_timeout", &xml_conf_set_slot_time, offsetof(struct fpm_worker_pool_config_s, request_slowlog_timeout) }, -+ { XML_CONF_SCALAR, "slowlog", &xml_conf_set_slot_string, offsetof(struct fpm_worker_pool_config_s, slowlog) }, -+ { XML_CONF_SCALAR, "rlimit_files", &xml_conf_set_slot_integer, offsetof(struct fpm_worker_pool_config_s, rlimit_files) }, -+ { XML_CONF_SCALAR, "rlimit_core", &fpm_conf_set_rlimit_core, 0 }, -+ { XML_CONF_SCALAR, "max_requests", &xml_conf_set_slot_integer, offsetof(struct fpm_worker_pool_config_s, max_requests) }, -+ { XML_CONF_SCALAR, "catch_workers_output", &fpm_conf_set_catch_workers_output, 0 }, -+ { XML_CONF_SUBSECTION, "pm", &fpm_conf_set_pm_subsection, offsetof(struct fpm_worker_pool_config_s, pm) }, -+ { 0, 0, 0, 0 } -+ } -+}; -+ -+static struct xml_conf_section *fpm_conf_all_sections[] = { -+ &xml_section_fpm_global_options, -+ &xml_section_fpm_worker_pool_config, -+ 0 -+}; -+ -+static int fpm_evaluate_full_path(char **path) -+{ -+ if (**path != '/') { -+ char *full_path; -+ -+ full_path = malloc(sizeof(PHP_PREFIX) + strlen(*path) + 1); -+ -+ if (!full_path) return -1; -+ -+ sprintf(full_path, "%s/%s", PHP_PREFIX, *path); -+ -+ free(*path); -+ -+ *path = full_path; -+ } -+ -+ return 0; -+} -+ -+static int fpm_conf_process_all_pools() -+{ -+ struct fpm_worker_pool_s *wp; -+ -+ if (!fpm_worker_all_pools) { -+ zlog(ZLOG_STUFF, ZLOG_ERROR, "at least one pool section must be specified in config file"); -+ return -1; -+ } -+ -+ for (wp = fpm_worker_all_pools; wp; wp = wp->next) { -+ -+ if (wp->config->listen_address && *wp->config->listen_address) { -+ -+ wp->listen_address_domain = fpm_sockets_domain_from_address(wp->config->listen_address); -+ -+ if (wp->listen_address_domain == FPM_AF_UNIX && *wp->config->listen_address != '/') { -+ fpm_evaluate_full_path(&wp->config->listen_address); -+ } -+ -+ } -+ else { -+ -+ wp->is_template = 1; -+ -+ } -+ -+ if (wp->config->request_slowlog_timeout) { -+#if HAVE_FPM_TRACE -+ if (! (wp->config->slowlog && *wp->config->slowlog)) { -+ zlog(ZLOG_STUFF, ZLOG_ERROR, "pool %s: 'slowlog' must be specified for use with 'request_slowlog_timeout'", -+ wp->config->name); -+ return -1; -+ } -+#else -+ static int warned = 0; -+ -+ if (!warned) { -+ zlog(ZLOG_STUFF, ZLOG_WARNING, "pool %s: 'request_slowlog_timeout' is not supported on your system", -+ wp->config->name); -+ warned = 1; -+ } -+ -+ wp->config->request_slowlog_timeout = 0; -+#endif -+ } -+ -+ if (wp->config->request_slowlog_timeout && wp->config->slowlog && *wp->config->slowlog) { -+ int fd; -+ -+ fpm_evaluate_full_path(&wp->config->slowlog); -+ -+ if (wp->config->request_slowlog_timeout) { -+ fd = open(wp->config->slowlog, O_WRONLY | O_APPEND | O_CREAT, S_IRUSR | S_IWUSR); -+ -+ if (0 > fd) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "open(%s) failed", wp->config->slowlog); -+ return -1; -+ } -+ close(fd); -+ } -+ } -+ } -+ -+ return 0; -+} -+ -+int fpm_conf_unlink_pid() -+{ -+ if (fpm_global_config.pid_file) { -+ -+ if (0 > unlink(fpm_global_config.pid_file)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "unlink(\"%s\") failed", fpm_global_config.pid_file); -+ return -1; -+ } -+ -+ } -+ -+ return 0; -+} -+ -+int fpm_conf_write_pid() -+{ -+ int fd; -+ -+ if (fpm_global_config.pid_file) { -+ char buf[64]; -+ int len; -+ -+ unlink(fpm_global_config.pid_file); -+ -+ fd = creat(fpm_global_config.pid_file, S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH); -+ -+ if (fd < 0) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "creat(\"%s\") failed", fpm_global_config.pid_file); -+ return -1; -+ } -+ -+ len = sprintf(buf, "%d", (int) fpm_globals.parent_pid); -+ -+ if (len != write(fd, buf, len)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "write() failed"); -+ return -1; -+ } -+ -+ close(fd); -+ } -+ -+ return 0; -+} -+ -+static int fpm_conf_post_process() -+{ -+ if (fpm_global_config.pid_file) { -+ fpm_evaluate_full_path(&fpm_global_config.pid_file); -+ } -+ -+ if (!fpm_global_config.error_log) { -+ fpm_global_config.error_log = strdup(PHP_FPM_LOG_PATH); -+ } -+ -+ fpm_evaluate_full_path(&fpm_global_config.error_log); -+ -+ if (0 > fpm_stdio_open_error_log(0)) { -+ return -1; -+ } -+ -+ return fpm_conf_process_all_pools(); -+} -+ -+static void fpm_conf_cleanup(int which, void *arg) -+{ -+ free(fpm_global_config.pid_file); -+ free(fpm_global_config.error_log); -+ fpm_global_config.pid_file = 0; -+ fpm_global_config.error_log = 0; -+} -+ -+int fpm_conf_init_main() -+{ -+ char *filename = fpm_globals.config; -+ char *err; -+ -+ if (0 > xml_conf_sections_register(fpm_conf_all_sections)) { -+ return -1; -+ } -+ -+ if (filename == NULL) { -+ filename = PHP_FPM_CONF_PATH; -+ } -+ -+ err = xml_conf_load_file(filename); -+ -+ if (err) { -+ zlog(ZLOG_STUFF, ZLOG_ERROR, "failed to load configuration file: %s", err); -+ return -1; -+ } -+ -+ if (0 > fpm_conf_post_process()) { -+ return -1; -+ } -+ -+ xml_conf_clean(); -+ -+ if (0 > fpm_cleanup_add(FPM_CLEANUP_ALL, fpm_conf_cleanup, 0)) { -+ return -1; -+ } -+ -+ return 0; -+} -diff --git a/sapi/cgi/fpm/fpm_conf.h b/sapi/cgi/fpm/fpm_conf.h -new file mode 100644 -index 0000000..4dd011e ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_conf.h -@@ -0,0 +1,73 @@ -+ -+ /* $Id: fpm_conf.h,v 1.12.2.2 2008/12/13 03:46:49 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_CONF_H -+#define FPM_CONF_H 1 -+ -+struct key_value_s; -+ -+struct key_value_s { -+ struct key_value_s *next; -+ char *key; -+ char *value; -+}; -+ -+struct fpm_global_config_s { -+ int emergency_restart_threshold; -+ int emergency_restart_interval; -+ int process_control_timeout; -+ int daemonize; -+ char *pid_file; -+ char *error_log; -+}; -+ -+extern struct fpm_global_config_s fpm_global_config; -+ -+struct fpm_pm_s { -+ int style; -+ int max_children; -+ struct { -+ int StartServers; -+ int MinSpareServers; -+ int MaxSpareServers; -+ } options_apache_like; -+}; -+ -+struct fpm_listen_options_s { -+ int backlog; -+ char *owner; -+ char *group; -+ char *mode; -+}; -+ -+struct fpm_worker_pool_config_s { -+ char *name; -+ char *listen_address; -+ struct fpm_listen_options_s *listen_options; -+ struct key_value_s *php_defines; -+ char *user; -+ char *group; -+ char *chroot; -+ char *chdir; -+ char *allowed_clients; -+ struct key_value_s *environment; -+ struct fpm_pm_s *pm; -+ int request_terminate_timeout; -+ int request_slowlog_timeout; -+ char *slowlog; -+ int max_requests; -+ int rlimit_files; -+ int rlimit_core; -+ unsigned catch_workers_output:1; -+}; -+ -+enum { PM_STYLE_STATIC = 1, PM_STYLE_APACHE_LIKE = 2 }; -+ -+int fpm_conf_init_main(); -+int fpm_worker_pool_config_free(struct fpm_worker_pool_config_s *wpc); -+int fpm_conf_write_pid(); -+int fpm_conf_unlink_pid(); -+ -+#endif -+ -diff --git a/sapi/cgi/fpm/fpm_config.h b/sapi/cgi/fpm/fpm_config.h -new file mode 100644 -index 0000000..319b200 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_config.h -@@ -0,0 +1,39 @@ -+ -+ /* $Id: fpm_config.h,v 1.16 2008/05/25 00:30:43 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "php_config.h" -+#include "fpm_autoconf.h" -+ -+ -+/* Solaris does not have it */ -+#ifndef INADDR_NONE -+#define INADDR_NONE (-1) -+#endif -+ -+ -+/* If we're not using GNU C, elide __attribute__ */ -+#ifndef __GNUC__ -+# define __attribute__(x) /*NOTHING*/ -+#endif -+ -+ -+/* Solaris does not have it */ -+#ifndef timersub -+#define timersub(tvp, uvp, vvp) \ -+ do { \ -+ (vvp)->tv_sec = (tvp)->tv_sec - (uvp)->tv_sec; \ -+ (vvp)->tv_usec = (tvp)->tv_usec - (uvp)->tv_usec; \ -+ if ((vvp)->tv_usec < 0) { \ -+ (vvp)->tv_sec--; \ -+ (vvp)->tv_usec += 1000000; \ -+ } \ -+ } while (0) -+#endif -+ -+#if defined(HAVE_PTRACE) || defined(PROC_MEM_FILE) || defined(HAVE_MACH_VM_READ) -+#define HAVE_FPM_TRACE 1 -+#else -+#define HAVE_FPM_TRACE 0 -+#endif -+ -diff --git a/sapi/cgi/fpm/fpm_env.c b/sapi/cgi/fpm/fpm_env.c -new file mode 100644 -index 0000000..624a9fe ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_env.c -@@ -0,0 +1,125 @@ -+ -+ /* $Id: fpm_env.c,v 1.15 2008/09/18 23:19:59 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#ifdef HAVE_ALLOCA_H -+#include -+#endif -+#include -+#include -+#include -+ -+#include "fpm_env.h" -+#include "zlog.h" -+ -+#ifndef HAVE_SETENV -+int setenv(char *name, char *value, int overwrite) -+{ -+ int name_len = strlen(name); -+ int value_len = strlen(value); -+ char *var = alloca(name_len + 1 + value_len + 1); -+ -+ memcpy(var, name, name_len); -+ -+ var[name_len] = '='; -+ -+ memcpy(var + name_len + 1, value, value_len); -+ -+ var[name_len + 1 + value_len] = '\0'; -+ -+ return putenv(var); -+} -+#endif -+ -+#ifndef HAVE_CLEARENV -+void clearenv() -+{ -+ char **envp; -+ char *s; -+ -+ /* this algo is the only one known to me -+ that works well on all systems */ -+ while (*(envp = environ)) { -+ char *eq = strchr(*envp, '='); -+ -+ s = strdup(*envp); -+ -+ if (eq) s[eq - *envp] = '\0'; -+ -+ unsetenv(s); -+ free(s); -+ } -+ -+} -+#endif -+ -+ -+int fpm_env_init_child(struct fpm_worker_pool_s *wp) -+{ -+ struct key_value_s *kv; -+ -+ clearenv(); -+ -+ for (kv = wp->config->environment; kv; kv = kv->next) { -+ setenv(kv->key, kv->value, 1); -+ } -+ -+ if (wp->user) { -+ setenv("USER", wp->user, 1); -+ } -+ -+ if (wp->home) { -+ setenv("HOME", wp->home, 1); -+ } -+ -+ return 0; -+} -+ -+static int fpm_env_conf_wp(struct fpm_worker_pool_s *wp) -+{ -+ struct key_value_s *kv; -+ -+ kv = wp->config->environment; -+ -+ for (kv = wp->config->environment; kv; kv = kv->next) { -+ if (*kv->value == '$') { -+ char *value = getenv(kv->value + 1); -+ -+ if (!value) value = ""; -+ -+ free(kv->value); -+ kv->value = strdup(value); -+ } -+ -+ /* autodetected values should be removed -+ if these vars specified in config */ -+ if (!strcmp(kv->key, "USER")) { -+ free(wp->user); -+ wp->user = 0; -+ } -+ -+ if (!strcmp(kv->key, "HOME")) { -+ free(wp->home); -+ wp->home = 0; -+ } -+ } -+ -+ return 0; -+} -+ -+int fpm_env_init_main() -+{ -+ struct fpm_worker_pool_s *wp; -+ -+ for (wp = fpm_worker_all_pools; wp; wp = wp->next) { -+ -+ if (0 > fpm_env_conf_wp(wp)) { -+ return -1; -+ } -+ -+ } -+ -+ return 0; -+} -diff --git a/sapi/cgi/fpm/fpm_env.h b/sapi/cgi/fpm/fpm_env.h -new file mode 100644 -index 0000000..0f79ed7 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_env.h -@@ -0,0 +1,24 @@ -+ -+ /* $Id: fpm_env.h,v 1.9 2008/09/18 23:19:59 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_ENV_H -+#define FPM_ENV_H 1 -+ -+#include "fpm_worker_pool.h" -+ -+int fpm_env_init_child(struct fpm_worker_pool_s *wp); -+int fpm_env_init_main(); -+ -+extern char **environ; -+ -+#ifndef HAVE_SETENV -+int setenv(char *name, char *value, int overwrite); -+#endif -+ -+#ifndef HAVE_CLEARENV -+void clearenv(); -+#endif -+ -+#endif -+ -diff --git a/sapi/cgi/fpm/fpm_events.c b/sapi/cgi/fpm/fpm_events.c -new file mode 100644 -index 0000000..654e9c8 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_events.c -@@ -0,0 +1,135 @@ -+ -+ /* $Id: fpm_events.c,v 1.21.2.2 2008/12/13 03:21:18 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#include -+#include -+#include /* for putenv */ -+#include -+#include /* for event.h below */ -+#include -+ -+#include "fpm.h" -+#include "fpm_process_ctl.h" -+#include "fpm_events.h" -+#include "fpm_cleanup.h" -+#include "fpm_stdio.h" -+#include "fpm_signals.h" -+#include "fpm_children.h" -+#include "zlog.h" -+ -+static void fpm_event_cleanup(int which, void *arg) -+{ -+ event_base_free(0); -+} -+ -+static void fpm_got_signal(int fd, short ev, void *arg) -+{ -+ char c; -+ int res; -+ -+ do { -+ -+ do { -+ res = read(fd, &c, 1); -+ } while (res == -1 && errno == EINTR); -+ -+ if (res <= 0) { -+ if (res < 0 && errno != EAGAIN && errno != EWOULDBLOCK) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "read() failed"); -+ } -+ return; -+ } -+ -+ switch (c) { -+ case 'C' : /* SIGCHLD */ -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "received SIGCHLD"); -+ fpm_children_bury(); -+ break; -+ case 'I' : /* SIGINT */ -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "received SIGINT"); -+ fpm_pctl(FPM_PCTL_STATE_TERMINATING, FPM_PCTL_ACTION_SET); -+ break; -+ case 'T' : /* SIGTERM */ -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "received SIGTERM"); -+ fpm_pctl(FPM_PCTL_STATE_TERMINATING, FPM_PCTL_ACTION_SET); -+ break; -+ case 'Q' : /* SIGQUIT */ -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "received SIGQUIT"); -+ fpm_pctl(FPM_PCTL_STATE_FINISHING, FPM_PCTL_ACTION_SET); -+ break; -+ case '1' : /* SIGUSR1 */ -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "received SIGUSR1"); -+ if (0 == fpm_stdio_open_error_log(1)) { -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "log file re-opened"); -+ } -+ break; -+ case '2' : /* SIGUSR2 */ -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "received SIGUSR2"); -+ fpm_pctl(FPM_PCTL_STATE_RELOADING, FPM_PCTL_ACTION_SET); -+ break; -+ } -+ -+ if (fpm_globals.is_child) { -+ break; -+ } -+ -+ } while (1); -+ -+ return; -+} -+ -+int fpm_event_init_main() -+{ -+ event_init(); -+ -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "libevent: using %s", event_get_method()); -+ -+ if (0 > fpm_cleanup_add(FPM_CLEANUP_ALL, fpm_event_cleanup, 0)) { -+ return -1; -+ } -+ -+ return 0; -+} -+ -+int fpm_event_loop() -+{ -+ static struct event signal_fd_event; -+ -+ event_set(&signal_fd_event, fpm_signals_get_fd(), EV_PERSIST | EV_READ, &fpm_got_signal, 0); -+ -+ event_add(&signal_fd_event, 0); -+ -+ fpm_pctl_heartbeat(-1, 0, 0); -+ -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "libevent: entering main loop"); -+ -+ event_loop(0); -+ -+ return 0; -+} -+ -+int fpm_event_add(int fd, struct event *ev, void (*callback)(int, short, void *), void *arg) -+{ -+ event_set(ev, fd, EV_PERSIST | EV_READ, callback, arg); -+ -+ return event_add(ev, 0); -+} -+ -+int fpm_event_del(struct event *ev) -+{ -+ return event_del(ev); -+} -+ -+void fpm_event_exit_loop() -+{ -+ event_loopbreak(); -+} -+ -+void fpm_event_fire(struct event *ev) -+{ -+ (*ev->ev_callback)( (int) ev->ev_fd, (short) ev->ev_res, ev->ev_arg); -+} -+ -diff --git a/sapi/cgi/fpm/fpm_events.h b/sapi/cgi/fpm/fpm_events.h -new file mode 100644 -index 0000000..d5a45ce ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_events.h -@@ -0,0 +1,16 @@ -+ -+ /* $Id: fpm_events.h,v 1.9 2008/05/24 17:38:47 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_EVENTS_H -+#define FPM_EVENTS_H 1 -+ -+void fpm_event_exit_loop(); -+int fpm_event_loop(); -+int fpm_event_add(int fd, struct event *ev, void (*callback)(int, short, void *), void *arg); -+int fpm_event_del(struct event *ev); -+void fpm_event_fire(struct event *ev); -+int fpm_event_init_main(); -+ -+ -+#endif -diff --git a/sapi/cgi/fpm/fpm_php.c b/sapi/cgi/fpm/fpm_php.c -new file mode 100644 -index 0000000..fb46b9b ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_php.c -@@ -0,0 +1,190 @@ -+ -+ /* $Id: fpm_php.c,v 1.22.2.4 2008/12/13 03:21:18 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#include -+#include -+#include -+ -+#include "php.h" -+#include "php_main.h" -+#include "php_ini.h" -+#include "ext/standard/dl.h" -+ -+#include "fastcgi.h" -+ -+#include "fpm.h" -+#include "fpm_php.h" -+#include "fpm_cleanup.h" -+#include "fpm_worker_pool.h" -+ -+static int zend_ini_alter_master(char *name, int name_length, char *new_value, int new_value_length, int stage TSRMLS_DC) -+{ -+ zend_ini_entry *ini_entry; -+ char *duplicate; -+ -+ if (zend_hash_find(EG(ini_directives), name, name_length, (void **) &ini_entry) == FAILURE) { -+ return FAILURE; -+ } -+ -+ duplicate = strdup(new_value); -+ -+ if (!ini_entry->on_modify -+ || ini_entry->on_modify(ini_entry, duplicate, new_value_length, -+ ini_entry->mh_arg1, ini_entry->mh_arg2, ini_entry->mh_arg3, stage TSRMLS_CC) == SUCCESS) { -+ ini_entry->value = duplicate; -+ ini_entry->value_length = new_value_length; -+ } else { -+ free(duplicate); -+ } -+ -+ return SUCCESS; -+} -+ -+static void fpm_php_disable(char *value, int (*zend_disable)(char *, uint TSRMLS_DC) TSRMLS_DC) -+{ -+ char *s = 0, *e = value; -+ -+ while (*e) { -+ switch (*e) { -+ case ' ': -+ case ',': -+ if (s) { -+ *e = '\0'; -+ zend_disable(s, e - s TSRMLS_CC); -+ s = 0; -+ } -+ break; -+ default: -+ if (!s) { -+ s = e; -+ } -+ break; -+ } -+ e++; -+ } -+ -+ if (s) { -+ zend_disable(s, e - s TSRMLS_CC); -+ } -+} -+ -+static int fpm_php_apply_defines(struct fpm_worker_pool_s *wp) -+{ -+ TSRMLS_FETCH(); -+ struct key_value_s *kv; -+ -+ for (kv = wp->config->php_defines; kv; kv = kv->next) { -+ char *name = kv->key; -+ char *value = kv->value; -+ int name_len = strlen(name); -+ int value_len = strlen(value); -+ -+ if (!strcmp(name, "extension") && *value) { -+ zval zv; -+ -+#if defined(PHP_VERSION_ID) && (PHP_VERSION_ID >= 50300) -+ php_dl(value, MODULE_PERSISTENT, &zv, 1 TSRMLS_CC); -+#else -+ zval filename; -+ ZVAL_STRINGL(&filename, value, value_len, 0); -+#if (PHP_MAJOR_VERSION >= 5) -+ php_dl(&filename, MODULE_PERSISTENT, &zv, 1 TSRMLS_CC); -+#else -+ php_dl(&filename, MODULE_PERSISTENT, &zv TSRMLS_CC); -+#endif -+#endif -+ continue; -+ } -+ -+ zend_ini_alter_master(name, name_len + 1, value, value_len, PHP_INI_STAGE_ACTIVATE TSRMLS_CC); -+ -+ if (!strcmp(name, "disable_functions") && *value) { -+ char *v = strdup(value); -+#if (PHP_MAJOR_VERSION >= 5) -+ PG(disable_functions) = v; -+#endif -+ fpm_php_disable(v, zend_disable_function TSRMLS_CC); -+ } -+ else if (!strcmp(name, "disable_classes") && *value) { -+ char *v = strdup(value); -+#if (PHP_MAJOR_VERSION >= 5) -+ PG(disable_classes) = v; -+#endif -+ fpm_php_disable(v, zend_disable_class TSRMLS_CC); -+ } -+ } -+ -+ return 0; -+} -+ -+static int fpm_php_set_allowed_clients(struct fpm_worker_pool_s *wp) -+{ -+ if (wp->listen_address_domain == FPM_AF_INET) { -+ fcgi_set_allowed_clients(wp->config->allowed_clients); -+ } -+ -+ return 0; -+} -+ -+static int fpm_php_set_fcgi_mgmt_vars(struct fpm_worker_pool_s *wp) -+{ -+ char max_workers[10 + 1]; /* 4294967295 */ -+ int len; -+ -+ len = sprintf(max_workers, "%u", (unsigned int) wp->config->pm->max_children); -+ -+ fcgi_set_mgmt_var("FCGI_MAX_CONNS", sizeof("FCGI_MAX_CONNS")-1, max_workers, len); -+ fcgi_set_mgmt_var("FCGI_MAX_REQS", sizeof("FCGI_MAX_REQS")-1, max_workers, len); -+ -+ return 0; -+} -+ -+char *fpm_php_script_filename(TSRMLS_D) -+{ -+ return SG(request_info).path_translated; -+} -+ -+char *fpm_php_request_method(TSRMLS_D) -+{ -+ return (char *) SG(request_info).request_method; -+} -+ -+size_t fpm_php_content_length(TSRMLS_D) -+{ -+ return SG(request_info).content_length; -+} -+ -+static void fpm_php_cleanup(int which, void *arg) -+{ -+ TSRMLS_FETCH(); -+ php_module_shutdown(TSRMLS_C); -+ sapi_shutdown(); -+} -+ -+void fpm_php_soft_quit() -+{ -+ fcgi_set_in_shutdown(1); -+} -+ -+int fpm_php_init_main() -+{ -+ if (0 > fpm_cleanup_add(FPM_CLEANUP_PARENT, fpm_php_cleanup, 0)) { -+ return -1; -+ } -+ -+ return 0; -+} -+ -+int fpm_php_init_child(struct fpm_worker_pool_s *wp) -+{ -+ if (0 > fpm_php_apply_defines(wp) || -+ 0 > fpm_php_set_allowed_clients(wp) || -+ 0 > fpm_php_set_fcgi_mgmt_vars(wp)) { -+ return -1; -+ } -+ -+ return 0; -+} -diff --git a/sapi/cgi/fpm/fpm_php.h b/sapi/cgi/fpm/fpm_php.h -new file mode 100644 -index 0000000..a05464f ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_php.h -@@ -0,0 +1,22 @@ -+ -+ /* $Id: fpm_php.h,v 1.10.2.1 2008/11/15 00:57:24 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_PHP_H -+#define FPM_PHP_H 1 -+ -+#include -+ -+#include "build-defs.h" /* for PHP_ defines */ -+ -+struct fpm_worker_pool_s; -+ -+int fpm_php_init_child(struct fpm_worker_pool_s *wp); -+char *fpm_php_script_filename(TSRMLS_D); -+char *fpm_php_request_method(TSRMLS_D); -+size_t fpm_php_content_length(TSRMLS_D); -+void fpm_php_soft_quit(); -+int fpm_php_init_main(); -+ -+#endif -+ -diff --git a/sapi/cgi/fpm/fpm_php_trace.c b/sapi/cgi/fpm/fpm_php_trace.c -new file mode 100644 -index 0000000..25a0d71 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_php_trace.c -@@ -0,0 +1,171 @@ -+ -+ /* $Id: fpm_php_trace.c,v 1.27.2.1 2008/11/15 00:57:24 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#if HAVE_FPM_TRACE -+ -+#include "php.h" -+#include "php_main.h" -+ -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+ -+#include "fpm_trace.h" -+#include "fpm_php_trace.h" -+#include "fpm_children.h" -+#include "fpm_worker_pool.h" -+#include "fpm_process_ctl.h" -+ -+#include "zlog.h" -+ -+ -+#define valid_ptr(p) ((p) && 0 == ((p) & (sizeof(long) - 1))) -+ -+#if SIZEOF_LONG == 4 -+#define PTR_FMT "08" -+#elif SIZEOF_LONG == 8 -+#define PTR_FMT "016" -+#endif -+ -+ -+static int fpm_php_trace_dump(struct fpm_child_s *child, FILE *slowlog TSRMLS_DC) -+{ -+ int callers_limit = 20; -+ pid_t pid = child->pid; -+ struct timeval tv; -+ static const int buf_size = 1024; -+ char buf[buf_size]; -+ long execute_data; -+ long l; -+ -+ gettimeofday(&tv, 0); -+ -+ zlog_print_time(&tv, buf, buf_size); -+ -+ fprintf(slowlog, "\n%s pid %d (pool %s)\n", buf, (int) pid, child->wp->config->name); -+ -+ if (0 > fpm_trace_get_strz(buf, buf_size, (long) &SG(request_info).path_translated)) { -+ return -1; -+ } -+ -+ fprintf(slowlog, "script_filename = %s\n", buf); -+ -+ if (0 > fpm_trace_get_long((long) &EG(current_execute_data), &l)) { -+ return -1; -+ } -+ -+ execute_data = l; -+ -+ while (execute_data) { -+ long function; -+ uint lineno = 0; -+ -+ fprintf(slowlog, "[0x%" PTR_FMT "lx] ", execute_data); -+ -+ if (0 > fpm_trace_get_long(execute_data + offsetof(zend_execute_data, function_state.function), &l)) { -+ return -1; -+ } -+ -+ function = l; -+ -+ if (valid_ptr(function)) { -+ if (0 > fpm_trace_get_strz(buf, buf_size, function + offsetof(zend_function, common.function_name))) { -+ return -1; -+ } -+ -+ fprintf(slowlog, "%s()", buf); -+ } -+ else { -+ fprintf(slowlog, "???"); -+ } -+ -+ if (0 > fpm_trace_get_long(execute_data + offsetof(zend_execute_data, op_array), &l)) { -+ return -1; -+ } -+ -+ *buf = '\0'; -+ -+ if (valid_ptr(l)) { -+ long op_array = l; -+ -+ if (0 > fpm_trace_get_strz(buf, buf_size, op_array + offsetof(zend_op_array, filename))) { -+ return -1; -+ } -+ } -+ -+ if (0 > fpm_trace_get_long(execute_data + offsetof(zend_execute_data, opline), &l)) { -+ return -1; -+ } -+ -+ if (valid_ptr(l)) { -+ long opline = l; -+ uint *lu = (uint *) &l; -+ -+ if (0 > fpm_trace_get_long(opline + offsetof(struct _zend_op, lineno), &l)) { -+ return -1; -+ } -+ -+ lineno = *lu; -+ } -+ -+ fprintf(slowlog, " %s:%u\n", *buf ? buf : "unknown", lineno); -+ -+ if (0 > fpm_trace_get_long(execute_data + offsetof(zend_execute_data, prev_execute_data), &l)) { -+ return -1; -+ } -+ -+ execute_data = l; -+ -+ if (0 == --callers_limit) { -+ break; -+ } -+ } -+ -+ return 0; -+} -+ -+void fpm_php_trace(struct fpm_child_s *child) -+{ -+ TSRMLS_FETCH(); -+ FILE *slowlog; -+ -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "about to trace %d", (int) child->pid); -+ -+ slowlog = fopen(child->wp->config->slowlog, "a+"); -+ -+ if (!slowlog) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "fopen(%s) failed", child->wp->config->slowlog); -+ goto done0; -+ } -+ -+ if (0 > fpm_trace_ready(child->pid)) { -+ goto done1; -+ } -+ -+ if (0 > fpm_php_trace_dump(child, slowlog TSRMLS_CC)) { -+ fprintf(slowlog, "+++ dump failed\n"); -+ } -+ -+ if (0 > fpm_trace_close(child->pid)) { -+ goto done1; -+ } -+ -+done1: -+ fclose(slowlog); -+ -+done0: -+ fpm_pctl_kill(child->pid, FPM_PCTL_CONT); -+ child->tracer = 0; -+ -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "finished trace of %d", (int) child->pid); -+} -+ -+#endif -+ -diff --git a/sapi/cgi/fpm/fpm_php_trace.h b/sapi/cgi/fpm/fpm_php_trace.h -new file mode 100644 -index 0000000..af5e456 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_php_trace.h -@@ -0,0 +1,13 @@ -+ -+ /* $Id: fpm_php_trace.h,v 1.2 2008/05/24 17:38:47 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_PHP_TRACE_H -+#define FPM_PHP_TRACE_H 1 -+ -+struct fpm_child_s; -+ -+void fpm_php_trace(struct fpm_child_s *); -+ -+#endif -+ -diff --git a/sapi/cgi/fpm/fpm_process_ctl.c b/sapi/cgi/fpm/fpm_process_ctl.c -new file mode 100644 -index 0000000..c9b69eb ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_process_ctl.c -@@ -0,0 +1,354 @@ -+ -+ /* $Id: fpm_process_ctl.c,v 1.19.2.2 2008/12/13 03:21:18 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#include -+#include -+#include -+#include -+ -+#include "fpm.h" -+#include "fpm_clock.h" -+#include "fpm_children.h" -+#include "fpm_signals.h" -+#include "fpm_events.h" -+#include "fpm_process_ctl.h" -+#include "fpm_cleanup.h" -+#include "fpm_request.h" -+#include "fpm_worker_pool.h" -+#include "zlog.h" -+ -+ -+static int fpm_state = FPM_PCTL_STATE_NORMAL; -+static int fpm_signal_sent = 0; -+ -+ -+static const char *fpm_state_names[] = { -+ [FPM_PCTL_STATE_NORMAL] = "normal", -+ [FPM_PCTL_STATE_RELOADING] = "reloading", -+ [FPM_PCTL_STATE_TERMINATING] = "terminating", -+ [FPM_PCTL_STATE_FINISHING] = "finishing" -+}; -+ -+static int saved_argc; -+static char **saved_argv; -+ -+static void fpm_pctl_cleanup(int which, void *arg) -+{ -+ int i; -+ -+ if (which != FPM_CLEANUP_PARENT_EXEC) { -+ -+ for (i = 0; i < saved_argc; i++) { -+ free(saved_argv[i]); -+ } -+ -+ free(saved_argv); -+ -+ } -+} -+ -+static struct event pctl_event; -+ -+static void fpm_pctl_action(int fd, short which, void *arg) -+{ -+ evtimer_del(&pctl_event); -+ -+ memset(&pctl_event, 0, sizeof(pctl_event)); -+ -+ fpm_pctl(FPM_PCTL_STATE_UNSPECIFIED, FPM_PCTL_ACTION_TIMEOUT); -+} -+ -+static int fpm_pctl_timeout_set(int sec) -+{ -+ struct timeval tv = { .tv_sec = sec, .tv_usec = 0 }; -+ -+ if (evtimer_initialized(&pctl_event)) { -+ evtimer_del(&pctl_event); -+ } -+ -+ evtimer_set(&pctl_event, &fpm_pctl_action, 0); -+ -+ evtimer_add(&pctl_event, &tv); -+ -+ return 0; -+} -+ -+static void fpm_pctl_exit() -+{ -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "exiting, bye-bye!"); -+ -+ fpm_conf_unlink_pid(); -+ -+ fpm_cleanups_run(FPM_CLEANUP_PARENT_EXIT_MAIN); -+ -+ exit(0); -+} -+ -+#define optional_arg(c) (saved_argc > c ? ", \"" : ""), (saved_argc > c ? saved_argv[c] : ""), (saved_argc > c ? "\"" : "") -+ -+static void fpm_pctl_exec() -+{ -+ -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "reloading: execvp(\"%s\", {\"%s\"" -+ "%s%s%s" "%s%s%s" "%s%s%s" "%s%s%s" "%s%s%s" -+ "%s%s%s" "%s%s%s" "%s%s%s" "%s%s%s" "%s%s%s" -+ "})", -+ saved_argv[0], saved_argv[0], -+ optional_arg(1), -+ optional_arg(2), -+ optional_arg(3), -+ optional_arg(4), -+ optional_arg(5), -+ optional_arg(6), -+ optional_arg(7), -+ optional_arg(8), -+ optional_arg(9), -+ optional_arg(10) -+ ); -+ -+ fpm_cleanups_run(FPM_CLEANUP_PARENT_EXEC); -+ -+ execvp(saved_argv[0], saved_argv); -+ -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "execvp() failed"); -+ -+ exit(1); -+} -+ -+static void fpm_pctl_action_last() -+{ -+ switch (fpm_state) { -+ -+ case FPM_PCTL_STATE_RELOADING : -+ -+ fpm_pctl_exec(); -+ break; -+ -+ case FPM_PCTL_STATE_FINISHING : -+ -+ case FPM_PCTL_STATE_TERMINATING : -+ -+ fpm_pctl_exit(); -+ break; -+ } -+} -+ -+int fpm_pctl_kill(pid_t pid, int how) -+{ -+ int s = 0; -+ -+ switch (how) { -+ case FPM_PCTL_TERM : -+ s = SIGTERM; -+ break; -+ case FPM_PCTL_STOP : -+ s = SIGSTOP; -+ break; -+ case FPM_PCTL_CONT : -+ s = SIGCONT; -+ break; -+ default : -+ break; -+ } -+ -+ return kill(pid, s); -+} -+ -+static void fpm_pctl_kill_all(int signo) -+{ -+ struct fpm_worker_pool_s *wp; -+ int alive_children = 0; -+ -+ for (wp = fpm_worker_all_pools; wp; wp = wp->next) { -+ struct fpm_child_s *child; -+ -+ for (child = wp->children; child; child = child->next) { -+ -+ int res = kill(child->pid, signo); -+ -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "sending signal %d %s to child %d (pool %s)", signo, -+ fpm_signal_names[signo] ? fpm_signal_names[signo] : "", -+ (int) child->pid, child->wp->config->name); -+ -+ if (res == 0) ++alive_children; -+ } -+ } -+ -+ if (alive_children) { -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "%d %s still alive", alive_children, alive_children == 1 ? "child is" : "children are"); -+ } -+} -+ -+static void fpm_pctl_action_next() -+{ -+ int sig, timeout; -+ -+ if (!fpm_globals.running_children) fpm_pctl_action_last(); -+ -+ if (fpm_signal_sent == 0) { -+ if (fpm_state == FPM_PCTL_STATE_TERMINATING) { -+ sig = SIGTERM; -+ } -+ else { -+ sig = SIGQUIT; -+ } -+ timeout = fpm_global_config.process_control_timeout; -+ } -+ else { -+ if (fpm_signal_sent == SIGQUIT) { -+ sig = SIGTERM; -+ } -+ else { -+ sig = SIGKILL; -+ } -+ timeout = 1; -+ } -+ -+ fpm_pctl_kill_all(sig); -+ -+ fpm_signal_sent = sig; -+ -+ fpm_pctl_timeout_set(timeout); -+} -+ -+void fpm_pctl(int new_state, int action) -+{ -+ switch (action) { -+ -+ case FPM_PCTL_ACTION_SET : -+ -+ if (fpm_state == new_state) { /* already in progress - just ignore duplicate signal */ -+ return; -+ } -+ -+ switch (fpm_state) { /* check which states can be overridden */ -+ -+ case FPM_PCTL_STATE_NORMAL : -+ -+ /* 'normal' can be overridden by any other state */ -+ break; -+ -+ case FPM_PCTL_STATE_RELOADING : -+ -+ /* 'reloading' can be overridden by 'finishing' */ -+ if (new_state == FPM_PCTL_STATE_FINISHING) break; -+ -+ case FPM_PCTL_STATE_FINISHING : -+ -+ /* 'reloading' and 'finishing' can be overridden by 'terminating' */ -+ if (new_state == FPM_PCTL_STATE_TERMINATING) break; -+ -+ case FPM_PCTL_STATE_TERMINATING : -+ -+ /* nothing can override 'terminating' state */ -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "not switching to '%s' state, because already in '%s' state", -+ fpm_state_names[new_state], fpm_state_names[fpm_state]); -+ -+ return; -+ } -+ -+ fpm_signal_sent = 0; -+ fpm_state = new_state; -+ -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "switching to '%s' state", fpm_state_names[fpm_state]); -+ -+ /* fall down */ -+ -+ case FPM_PCTL_ACTION_TIMEOUT : -+ -+ fpm_pctl_action_next(); -+ -+ break; -+ -+ case FPM_PCTL_ACTION_LAST_CHILD_EXITED : -+ -+ fpm_pctl_action_last(); -+ -+ break; -+ -+ } -+} -+ -+int fpm_pctl_can_spawn_children() -+{ -+ return fpm_state == FPM_PCTL_STATE_NORMAL; -+} -+ -+int fpm_pctl_child_exited() -+{ -+ if (fpm_state == FPM_PCTL_STATE_NORMAL) return 0; -+ -+ if (!fpm_globals.running_children) { -+ fpm_pctl(FPM_PCTL_STATE_UNSPECIFIED, FPM_PCTL_ACTION_LAST_CHILD_EXITED); -+ } -+ -+ return 0; -+} -+ -+int fpm_pctl_init_main() -+{ -+ int i; -+ -+ saved_argc = fpm_globals.argc; -+ -+ saved_argv = malloc(sizeof(char *) * (saved_argc + 1)); -+ -+ if (!saved_argv) { -+ return -1; -+ } -+ -+ for (i = 0; i < saved_argc; i++) { -+ saved_argv[i] = strdup(fpm_globals.argv[i]); -+ -+ if (!saved_argv[i]) { -+ return -1; -+ } -+ } -+ -+ saved_argv[i] = 0; -+ -+ if (0 > fpm_cleanup_add(FPM_CLEANUP_ALL, fpm_pctl_cleanup, 0)) { -+ return -1; -+ } -+ -+ return 0; -+} -+ -+static void fpm_pctl_check_request_timeout(struct timeval *now) -+{ -+ struct fpm_worker_pool_s *wp; -+ -+ for (wp = fpm_worker_all_pools; wp; wp = wp->next) { -+ int terminate_timeout = wp->config->request_terminate_timeout; -+ int slowlog_timeout = wp->config->request_slowlog_timeout; -+ struct fpm_child_s *child; -+ -+ if (terminate_timeout || slowlog_timeout) { -+ for (child = wp->children; child; child = child->next) { -+ fpm_request_check_timed_out(child, now, terminate_timeout, slowlog_timeout); -+ } -+ } -+ } -+ -+} -+ -+void fpm_pctl_heartbeat(int fd, short which, void *arg) -+{ -+ static struct event heartbeat; -+ struct timeval tv = { .tv_sec = 0, .tv_usec = 130000 }; -+ struct timeval now; -+ -+ if (which == EV_TIMEOUT) { -+ evtimer_del(&heartbeat); -+ fpm_clock_get(&now); -+ fpm_pctl_check_request_timeout(&now); -+ } -+ -+ evtimer_set(&heartbeat, &fpm_pctl_heartbeat, 0); -+ -+ evtimer_add(&heartbeat, &tv); -+} -+ -diff --git a/sapi/cgi/fpm/fpm_process_ctl.h b/sapi/cgi/fpm/fpm_process_ctl.h -new file mode 100644 -index 0000000..8424f10 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_process_ctl.h -@@ -0,0 +1,39 @@ -+ -+ /* $Id: fpm_process_ctl.h,v 1.6 2008/07/20 21:33:10 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_PROCESS_CTL_H -+#define FPM_PROCESS_CTL_H 1 -+ -+struct fpm_child_s; -+ -+void fpm_pctl(int new_state, int action); -+int fpm_pctl_can_spawn_children(); -+int fpm_pctl_kill(pid_t pid, int how); -+void fpm_pctl_heartbeat(int fd, short which, void *arg); -+int fpm_pctl_child_exited(); -+int fpm_pctl_init_main(); -+ -+ -+enum { -+ FPM_PCTL_STATE_UNSPECIFIED, -+ FPM_PCTL_STATE_NORMAL, -+ FPM_PCTL_STATE_RELOADING, -+ FPM_PCTL_STATE_TERMINATING, -+ FPM_PCTL_STATE_FINISHING -+}; -+ -+enum { -+ FPM_PCTL_ACTION_SET, -+ FPM_PCTL_ACTION_TIMEOUT, -+ FPM_PCTL_ACTION_LAST_CHILD_EXITED -+}; -+ -+enum { -+ FPM_PCTL_TERM, -+ FPM_PCTL_STOP, -+ FPM_PCTL_CONT -+}; -+ -+#endif -+ -diff --git a/sapi/cgi/fpm/fpm_request.c b/sapi/cgi/fpm/fpm_request.c -new file mode 100644 -index 0000000..3faf77d ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_request.c -@@ -0,0 +1,164 @@ -+ -+ /* $Id: fpm_request.c,v 1.9.2.1 2008/11/15 00:57:24 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#include "fpm_php.h" -+#include "fpm_str.h" -+#include "fpm_clock.h" -+#include "fpm_conf.h" -+#include "fpm_trace.h" -+#include "fpm_php_trace.h" -+#include "fpm_process_ctl.h" -+#include "fpm_children.h" -+#include "fpm_shm_slots.h" -+#include "fpm_request.h" -+ -+#include "zlog.h" -+ -+void fpm_request_accepting() -+{ -+ struct fpm_shm_slot_s *slot; -+ -+ slot = fpm_shm_slots_acquire(0, 0); -+ -+ slot->request_stage = FPM_REQUEST_ACCEPTING; -+ -+ fpm_clock_get(&slot->tv); -+ memset(slot->request_method, 0, sizeof(slot->request_method)); -+ slot->content_length = 0; -+ memset(slot->script_filename, 0, sizeof(slot->script_filename)); -+ -+ fpm_shm_slots_release(slot); -+} -+ -+void fpm_request_reading_headers() -+{ -+ struct fpm_shm_slot_s *slot; -+ -+ slot = fpm_shm_slots_acquire(0, 0); -+ -+ slot->request_stage = FPM_REQUEST_READING_HEADERS; -+ -+ fpm_clock_get(&slot->tv); -+ slot->accepted = slot->tv; -+ -+ fpm_shm_slots_release(slot); -+} -+ -+void fpm_request_info() -+{ -+ TSRMLS_FETCH(); -+ struct fpm_shm_slot_s *slot; -+ char *request_method = fpm_php_request_method(TSRMLS_C); -+ char *script_filename = fpm_php_script_filename(TSRMLS_C); -+ -+ slot = fpm_shm_slots_acquire(0, 0); -+ -+ slot->request_stage = FPM_REQUEST_INFO; -+ -+ fpm_clock_get(&slot->tv); -+ -+ if (request_method) { -+ cpystrn(slot->request_method, request_method, sizeof(slot->request_method)); -+ } -+ -+ slot->content_length = fpm_php_content_length(TSRMLS_C); -+ -+ /* if cgi.fix_pathinfo is set to "1" and script cannot be found (404) -+ the sapi_globals.request_info.path_translated is set to NULL */ -+ if (script_filename) { -+ cpystrn(slot->script_filename, script_filename, sizeof(slot->script_filename)); -+ } -+ -+ fpm_shm_slots_release(slot); -+} -+ -+void fpm_request_executing() -+{ -+ struct fpm_shm_slot_s *slot; -+ -+ slot = fpm_shm_slots_acquire(0, 0); -+ -+ slot->request_stage = FPM_REQUEST_EXECUTING; -+ -+ fpm_clock_get(&slot->tv); -+ -+ fpm_shm_slots_release(slot); -+} -+ -+void fpm_request_finished() -+{ -+ struct fpm_shm_slot_s *slot; -+ -+ slot = fpm_shm_slots_acquire(0, 0); -+ -+ slot->request_stage = FPM_REQUEST_FINISHED; -+ -+ fpm_clock_get(&slot->tv); -+ memset(&slot->accepted, 0, sizeof(slot->accepted)); -+ -+ fpm_shm_slots_release(slot); -+} -+ -+void fpm_request_check_timed_out(struct fpm_child_s *child, struct timeval *now, int terminate_timeout, int slowlog_timeout) -+{ -+ struct fpm_shm_slot_s *slot; -+ struct fpm_shm_slot_s slot_c; -+ -+ slot = fpm_shm_slot(child); -+ -+ if (!fpm_shm_slots_acquire(slot, 1)) { -+ return; -+ } -+ -+ slot_c = *slot; -+ -+ fpm_shm_slots_release(slot); -+ -+#if HAVE_FPM_TRACE -+ if (child->slow_logged.tv_sec) { -+ if (child->slow_logged.tv_sec != slot_c.accepted.tv_sec || child->slow_logged.tv_usec != slot_c.accepted.tv_usec) { -+ child->slow_logged.tv_sec = 0; -+ child->slow_logged.tv_usec = 0; -+ } -+ } -+#endif -+ -+ if (slot_c.request_stage > FPM_REQUEST_ACCEPTING && slot_c.request_stage < FPM_REQUEST_FINISHED) { -+ char purified_script_filename[sizeof(slot_c.script_filename)]; -+ struct timeval tv; -+ -+ timersub(now, &slot_c.accepted, &tv); -+ -+#if HAVE_FPM_TRACE -+ if (child->slow_logged.tv_sec == 0 && slowlog_timeout && -+ slot_c.request_stage == FPM_REQUEST_EXECUTING && tv.tv_sec >= slowlog_timeout) { -+ -+ str_purify_filename(purified_script_filename, slot_c.script_filename, sizeof(slot_c.script_filename)); -+ -+ child->slow_logged = slot_c.accepted; -+ child->tracer = fpm_php_trace; -+ -+ fpm_trace_signal(child->pid); -+ -+ zlog(ZLOG_STUFF, ZLOG_WARNING, "child %d, script '%s' (pool %s) executing too slow (%d.%06d sec), logging", -+ (int) child->pid, purified_script_filename, child->wp->config->name, (int) tv.tv_sec, (int) tv.tv_usec); -+ } -+ -+ else -+#endif -+ if (terminate_timeout && tv.tv_sec >= terminate_timeout) { -+ -+ str_purify_filename(purified_script_filename, slot_c.script_filename, sizeof(slot_c.script_filename)); -+ -+ fpm_pctl_kill(child->pid, FPM_PCTL_TERM); -+ -+ zlog(ZLOG_STUFF, ZLOG_WARNING, "child %d, script '%s' (pool %s) execution timed out (%d.%06d sec), terminating", -+ (int) child->pid, purified_script_filename, child->wp->config->name, (int) tv.tv_sec, (int) tv.tv_usec); -+ } -+ } -+ -+} -+ -diff --git a/sapi/cgi/fpm/fpm_request.h b/sapi/cgi/fpm/fpm_request.h -new file mode 100644 -index 0000000..d768db6 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_request.h -@@ -0,0 +1,27 @@ -+ -+ /* $Id: fpm_request.h,v 1.4 2008/07/20 01:47:16 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_REQUEST_H -+#define FPM_REQUEST_H 1 -+ -+void fpm_request_accepting(); /* hanging in accept() */ -+void fpm_request_reading_headers(); /* start reading fastcgi request from very first byte */ -+void fpm_request_info(); /* not a stage really but a point in the php code, where all request params have become known to sapi */ -+void fpm_request_executing(); /* the script is executing */ -+void fpm_request_finished(); /* request processed: script response have been sent to web server */ -+ -+struct fpm_child_s; -+struct timeval; -+ -+void fpm_request_check_timed_out(struct fpm_child_s *child, struct timeval *tv, int terminate_timeout, int slowlog_timeout); -+ -+enum fpm_request_stage_e { -+ FPM_REQUEST_ACCEPTING = 1, -+ FPM_REQUEST_READING_HEADERS, -+ FPM_REQUEST_INFO, -+ FPM_REQUEST_EXECUTING, -+ FPM_REQUEST_FINISHED -+}; -+ -+#endif -diff --git a/sapi/cgi/fpm/fpm_shm.c b/sapi/cgi/fpm/fpm_shm.c -new file mode 100644 -index 0000000..21c3d75 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_shm.c -@@ -0,0 +1,100 @@ -+ -+ /* $Id: fpm_shm.c,v 1.3 2008/05/24 17:38:47 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#include -+#include -+#include -+ -+#include "fpm_shm.h" -+#include "zlog.h" -+ -+ -+/* MAP_ANON is depricated, but not in macosx */ -+#if defined(MAP_ANON) && !defined(MAP_ANONYMOUS) -+#define MAP_ANONYMOUS MAP_ANON -+#endif -+ -+ -+struct fpm_shm_s *fpm_shm_alloc(size_t sz) -+{ -+ struct fpm_shm_s *shm; -+ -+ shm = malloc(sizeof(*shm)); -+ -+ if (!shm) { -+ return 0; -+ } -+ -+ shm->mem = mmap(0, sz, PROT_READ | PROT_WRITE, MAP_ANONYMOUS | MAP_SHARED, -1, 0); -+ -+ if (!shm->mem) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "mmap(MAP_ANONYMOUS | MAP_SHARED) failed"); -+ free(shm); -+ return 0; -+ } -+ -+ shm->used = 0; -+ shm->sz = sz; -+ -+ return shm; -+} -+ -+static void fpm_shm_free(struct fpm_shm_s *shm, int do_unmap) -+{ -+ if (do_unmap) { -+ munmap(shm->mem, shm->sz); -+ } -+ -+ free(shm); -+} -+ -+void fpm_shm_free_list(struct fpm_shm_s *shm, void *mem) -+{ -+ struct fpm_shm_s *next; -+ -+ for (; shm; shm = next) { -+ next = shm->next; -+ -+ fpm_shm_free(shm, mem != shm->mem); -+ } -+} -+ -+void *fpm_shm_alloc_chunk(struct fpm_shm_s **head, size_t sz, void **mem) -+{ -+ size_t pagesize = getpagesize(); -+ static const size_t cache_line_size = 16; -+ size_t aligned_sz; -+ struct fpm_shm_s *shm; -+ void *ret; -+ -+ sz = (sz + cache_line_size - 1) & -cache_line_size; -+ -+ shm = *head; -+ -+ if (0 == shm || shm->sz - shm->used < sz) { -+ /* allocate one more shm segment */ -+ -+ aligned_sz = (sz + pagesize - 1) & -pagesize; -+ -+ shm = fpm_shm_alloc(aligned_sz); -+ -+ if (!shm) { -+ return 0; -+ } -+ -+ shm->next = *head; -+ if (shm->next) shm->next->prev = shm; -+ shm->prev = 0; -+ *head = shm; -+ } -+ -+ *mem = shm->mem; -+ ret = (char *) shm->mem + shm->used; -+ shm->used += sz; -+ -+ return ret; -+} -+ -diff --git a/sapi/cgi/fpm/fpm_shm.h b/sapi/cgi/fpm/fpm_shm.h -new file mode 100644 -index 0000000..f3f0be0 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_shm.h -@@ -0,0 +1,22 @@ -+ -+ /* $Id: fpm_shm.h,v 1.3 2008/05/24 17:38:47 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_SHM_H -+#define FPM_SHM_H 1 -+ -+struct fpm_shm_s; -+ -+struct fpm_shm_s { -+ struct fpm_shm_s *prev, *next; -+ void *mem; -+ size_t sz; -+ size_t used; -+}; -+ -+struct fpm_shm_s *fpm_shm_alloc(size_t sz); -+void fpm_shm_free_list(struct fpm_shm_s *, void *); -+void *fpm_shm_alloc_chunk(struct fpm_shm_s **head, size_t sz, void **mem); -+ -+#endif -+ -diff --git a/sapi/cgi/fpm/fpm_shm_slots.c b/sapi/cgi/fpm/fpm_shm_slots.c -new file mode 100644 -index 0000000..efa3707 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_shm_slots.c -@@ -0,0 +1,127 @@ -+ -+ /* $Id: fpm_shm_slots.c,v 1.2 2008/05/24 17:38:47 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#include "fpm_atomic.h" -+#include "fpm_worker_pool.h" -+#include "fpm_children.h" -+#include "fpm_shm.h" -+#include "fpm_shm_slots.h" -+#include "zlog.h" -+ -+static void *shm_mem; -+static struct fpm_shm_slot_s *shm_slot; -+ -+int fpm_shm_slots_prepare_slot(struct fpm_child_s *child) -+{ -+ struct fpm_worker_pool_s *wp = child->wp; -+ struct fpm_shm_slot_ptr_s *shm_slot_ptr; -+ -+ child->shm_slot_i = wp->slots_used.used; -+ -+ shm_slot_ptr = fpm_array_push(&wp->slots_used); -+ -+ if (0 == shm_slot_ptr) { -+ return -1; -+ } -+ -+ if (0 == wp->slots_free.used) { -+ shm_slot_ptr->shm_slot = fpm_shm_alloc_chunk(&wp->shm_list, sizeof(struct fpm_shm_slot_s), &shm_slot_ptr->mem); -+ -+ if (!shm_slot_ptr->shm_slot) { -+ return -1; -+ } -+ } -+ else { -+ *shm_slot_ptr = *(struct fpm_shm_slot_ptr_s *) fpm_array_item_last(&wp->slots_free); -+ -+ --wp->slots_free.used; -+ } -+ -+ memset(shm_slot_ptr->shm_slot, 0, sizeof(struct fpm_shm_slot_s)); -+ -+ shm_slot_ptr->child = child; -+ -+ return 0; -+} -+ -+void fpm_shm_slots_discard_slot(struct fpm_child_s *child) -+{ -+ struct fpm_shm_slot_ptr_s *shm_slot_ptr; -+ struct fpm_worker_pool_s *wp = child->wp; -+ int n; -+ -+ shm_slot_ptr = fpm_array_push(&wp->slots_free); -+ -+ if (shm_slot_ptr) { -+ -+ struct fpm_shm_slot_ptr_s *shm_slot_ptr_used; -+ -+ shm_slot_ptr_used = fpm_array_item(&wp->slots_used, child->shm_slot_i); -+ -+ *shm_slot_ptr = *shm_slot_ptr_used; -+ -+ shm_slot_ptr->child = 0; -+ -+ } -+ -+ n = fpm_array_item_remove(&wp->slots_used, child->shm_slot_i); -+ -+ if (n > -1) { -+ shm_slot_ptr = fpm_array_item(&wp->slots_used, n); -+ -+ shm_slot_ptr->child->shm_slot_i = n; -+ } -+} -+ -+void fpm_shm_slots_child_use_slot(struct fpm_child_s *child) -+{ -+ struct fpm_shm_slot_ptr_s *shm_slot_ptr; -+ struct fpm_worker_pool_s *wp = child->wp; -+ -+ shm_slot_ptr = fpm_array_item(&wp->slots_used, child->shm_slot_i); -+ -+ shm_slot = shm_slot_ptr->shm_slot; -+ shm_mem = shm_slot_ptr->mem; -+} -+ -+void fpm_shm_slots_parent_use_slot(struct fpm_child_s *child) -+{ -+ /* nothing to do */ -+} -+ -+void *fpm_shm_slots_mem() -+{ -+ return shm_mem; -+} -+ -+struct fpm_shm_slot_s *fpm_shm_slot(struct fpm_child_s *child) -+{ -+ struct fpm_shm_slot_ptr_s *shm_slot_ptr; -+ struct fpm_worker_pool_s *wp = child->wp; -+ -+ shm_slot_ptr = fpm_array_item(&wp->slots_used, child->shm_slot_i); -+ -+ return shm_slot_ptr->shm_slot; -+} -+ -+struct fpm_shm_slot_s *fpm_shm_slots_acquire(struct fpm_shm_slot_s *s, int nohang) -+{ -+ if (s == 0) { -+ s = shm_slot; -+ } -+ -+ if (0 > fpm_spinlock(&s->lock, nohang)) { -+ return 0; -+ } -+ -+ return s; -+} -+ -+void fpm_shm_slots_release(struct fpm_shm_slot_s *s) -+{ -+ s->lock = 0; -+} -+ -diff --git a/sapi/cgi/fpm/fpm_shm_slots.h b/sapi/cgi/fpm/fpm_shm_slots.h -new file mode 100644 -index 0000000..4596c6f ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_shm_slots.h -@@ -0,0 +1,43 @@ -+ -+ /* $Id: fpm_shm_slots.h,v 1.2 2008/05/24 17:38:47 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_SHM_SLOTS_H -+#define FPM_SHM_SLOTS_H 1 -+ -+#include "fpm_atomic.h" -+#include "fpm_worker_pool.h" -+#include "fpm_request.h" -+ -+struct fpm_child_s; -+ -+struct fpm_shm_slot_s { -+ union { -+ atomic_t lock; -+ char dummy[16]; -+ }; -+ enum fpm_request_stage_e request_stage; -+ struct timeval accepted; -+ struct timeval tv; -+ char request_method[16]; -+ size_t content_length; /* used with POST only */ -+ char script_filename[256]; -+}; -+ -+struct fpm_shm_slot_ptr_s { -+ void *mem; -+ struct fpm_shm_slot_s *shm_slot; -+ struct fpm_child_s *child; -+}; -+ -+int fpm_shm_slots_prepare_slot(struct fpm_child_s *child); -+void fpm_shm_slots_discard_slot(struct fpm_child_s *child); -+void fpm_shm_slots_child_use_slot(struct fpm_child_s *child); -+void fpm_shm_slots_parent_use_slot(struct fpm_child_s *child); -+void *fpm_shm_slots_mem(); -+struct fpm_shm_slot_s *fpm_shm_slot(struct fpm_child_s *child); -+struct fpm_shm_slot_s *fpm_shm_slots_acquire(struct fpm_shm_slot_s *, int nohang); -+void fpm_shm_slots_release(struct fpm_shm_slot_s *); -+ -+#endif -+ -diff --git a/sapi/cgi/fpm/fpm_signals.c b/sapi/cgi/fpm/fpm_signals.c -new file mode 100644 -index 0000000..2cf878d ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_signals.c -@@ -0,0 +1,252 @@ -+ -+ /* $Id: fpm_signals.c,v 1.24 2008/08/26 15:09:15 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+ -+#include "fpm.h" -+#include "fpm_signals.h" -+#include "fpm_sockets.h" -+#include "fpm_php.h" -+#include "zlog.h" -+ -+static int sp[2]; -+ -+const char *fpm_signal_names[NSIG + 1] = { -+#ifdef SIGHUP -+ [SIGHUP] = "SIGHUP", -+#endif -+#ifdef SIGINT -+ [SIGINT] = "SIGINT", -+#endif -+#ifdef SIGQUIT -+ [SIGQUIT] = "SIGQUIT", -+#endif -+#ifdef SIGILL -+ [SIGILL] = "SIGILL", -+#endif -+#ifdef SIGTRAP -+ [SIGTRAP] = "SIGTRAP", -+#endif -+#ifdef SIGABRT -+ [SIGABRT] = "SIGABRT", -+#endif -+#ifdef SIGEMT -+ [SIGEMT] = "SIGEMT", -+#endif -+#ifdef SIGBUS -+ [SIGBUS] = "SIGBUS", -+#endif -+#ifdef SIGFPE -+ [SIGFPE] = "SIGFPE", -+#endif -+#ifdef SIGKILL -+ [SIGKILL] = "SIGKILL", -+#endif -+#ifdef SIGUSR1 -+ [SIGUSR1] = "SIGUSR1", -+#endif -+#ifdef SIGSEGV -+ [SIGSEGV] = "SIGSEGV", -+#endif -+#ifdef SIGUSR2 -+ [SIGUSR2] = "SIGUSR2", -+#endif -+#ifdef SIGPIPE -+ [SIGPIPE] = "SIGPIPE", -+#endif -+#ifdef SIGALRM -+ [SIGALRM] = "SIGALRM", -+#endif -+#ifdef SIGTERM -+ [SIGTERM] = "SIGTERM", -+#endif -+#ifdef SIGCHLD -+ [SIGCHLD] = "SIGCHLD", -+#endif -+#ifdef SIGCONT -+ [SIGCONT] = "SIGCONT", -+#endif -+#ifdef SIGSTOP -+ [SIGSTOP] = "SIGSTOP", -+#endif -+#ifdef SIGTSTP -+ [SIGTSTP] = "SIGTSTP", -+#endif -+#ifdef SIGTTIN -+ [SIGTTIN] = "SIGTTIN", -+#endif -+#ifdef SIGTTOU -+ [SIGTTOU] = "SIGTTOU", -+#endif -+#ifdef SIGURG -+ [SIGURG] = "SIGURG", -+#endif -+#ifdef SIGXCPU -+ [SIGXCPU] = "SIGXCPU", -+#endif -+#ifdef SIGXFSZ -+ [SIGXFSZ] = "SIGXFSZ", -+#endif -+#ifdef SIGVTALRM -+ [SIGVTALRM] = "SIGVTALRM", -+#endif -+#ifdef SIGPROF -+ [SIGPROF] = "SIGPROF", -+#endif -+#ifdef SIGWINCH -+ [SIGWINCH] = "SIGWINCH", -+#endif -+#ifdef SIGINFO -+ [SIGINFO] = "SIGINFO", -+#endif -+#ifdef SIGIO -+ [SIGIO] = "SIGIO", -+#endif -+#ifdef SIGPWR -+ [SIGPWR] = "SIGPWR", -+#endif -+#ifdef SIGSYS -+ [SIGSYS] = "SIGSYS", -+#endif -+#ifdef SIGWAITING -+ [SIGWAITING] = "SIGWAITING", -+#endif -+#ifdef SIGLWP -+ [SIGLWP] = "SIGLWP", -+#endif -+#ifdef SIGFREEZE -+ [SIGFREEZE] = "SIGFREEZE", -+#endif -+#ifdef SIGTHAW -+ [SIGTHAW] = "SIGTHAW", -+#endif -+#ifdef SIGCANCEL -+ [SIGCANCEL] = "SIGCANCEL", -+#endif -+#ifdef SIGLOST -+ [SIGLOST] = "SIGLOST", -+#endif -+}; -+ -+static void sig_soft_quit(int signo) -+{ -+ int saved_errno = errno; -+ -+ /* closing fastcgi listening socket will force fcgi_accept() exit immediately */ -+ close(0); -+ socket(AF_UNIX, SOCK_STREAM, 0); -+ -+ fpm_php_soft_quit(); -+ -+ errno = saved_errno; -+} -+ -+static void sig_handler(int signo) -+{ -+ static const char sig_chars[NSIG + 1] = { -+ [SIGTERM] = 'T', -+ [SIGINT] = 'I', -+ [SIGUSR1] = '1', -+ [SIGUSR2] = '2', -+ [SIGQUIT] = 'Q', -+ [SIGCHLD] = 'C' -+ }; -+ char s; -+ int saved_errno; -+ -+ if (fpm_globals.parent_pid != getpid()) { -+ /* prevent a signal race condition when child process -+ have not set up it's own signal handler yet */ -+ return; -+ } -+ -+ saved_errno = errno; -+ -+ s = sig_chars[signo]; -+ -+ write(sp[1], &s, sizeof(s)); -+ -+ errno = saved_errno; -+} -+ -+int fpm_signals_init_main() -+{ -+ struct sigaction act; -+ -+ if (0 > socketpair(AF_UNIX, SOCK_STREAM, 0, sp)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "socketpair() failed"); -+ return -1; -+ } -+ -+ if (0 > fd_set_blocked(sp[0], 0) || 0 > fd_set_blocked(sp[1], 0)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "fd_set_blocked() failed"); -+ return -1; -+ } -+ -+ if (0 > fcntl(sp[0], F_SETFD, FD_CLOEXEC) || 0 > fcntl(sp[1], F_SETFD, FD_CLOEXEC)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "fcntl(F_SETFD, FD_CLOEXEC) failed"); -+ return -1; -+ } -+ -+ memset(&act, 0, sizeof(act)); -+ act.sa_handler = sig_handler; -+ sigfillset(&act.sa_mask); -+ -+ if (0 > sigaction(SIGTERM, &act, 0) || -+ 0 > sigaction(SIGINT, &act, 0) || -+ 0 > sigaction(SIGUSR1, &act, 0) || -+ 0 > sigaction(SIGUSR2, &act, 0) || -+ 0 > sigaction(SIGCHLD, &act, 0) || -+ 0 > sigaction(SIGQUIT, &act, 0)) { -+ -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "sigaction() failed"); -+ return -1; -+ } -+ -+ return 0; -+} -+ -+int fpm_signals_init_child() -+{ -+ struct sigaction act, act_dfl; -+ -+ memset(&act, 0, sizeof(act)); -+ memset(&act_dfl, 0, sizeof(act_dfl)); -+ -+ act.sa_handler = &sig_soft_quit; -+ act.sa_flags |= SA_RESTART; -+ -+ act_dfl.sa_handler = SIG_DFL; -+ -+ close(sp[0]); -+ close(sp[1]); -+ -+ if (0 > sigaction(SIGTERM, &act_dfl, 0) || -+ 0 > sigaction(SIGINT, &act_dfl, 0) || -+ 0 > sigaction(SIGUSR1, &act_dfl, 0) || -+ 0 > sigaction(SIGUSR2, &act_dfl, 0) || -+ 0 > sigaction(SIGCHLD, &act_dfl, 0) || -+ 0 > sigaction(SIGQUIT, &act, 0)) { -+ -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "sigaction() failed"); -+ return -1; -+ } -+ -+ return 0; -+} -+ -+int fpm_signals_get_fd() -+{ -+ return sp[0]; -+} -diff --git a/sapi/cgi/fpm/fpm_signals.h b/sapi/cgi/fpm/fpm_signals.h -new file mode 100644 -index 0000000..eb80fae ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_signals.h -@@ -0,0 +1,16 @@ -+ -+ /* $Id: fpm_signals.h,v 1.5 2008/05/24 17:38:47 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_SIGNALS_H -+#define FPM_SIGNALS_H 1 -+ -+#include -+ -+int fpm_signals_init_main(); -+int fpm_signals_init_child(); -+int fpm_signals_get_fd(); -+ -+extern const char *fpm_signal_names[NSIG + 1]; -+ -+#endif -diff --git a/sapi/cgi/fpm/fpm_sockets.c b/sapi/cgi/fpm/fpm_sockets.c -new file mode 100644 -index 0000000..5acb559 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_sockets.c -@@ -0,0 +1,427 @@ -+ -+ /* $Id: fpm_sockets.c,v 1.20.2.1 2008/12/13 03:21:18 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#ifdef HAVE_ALLOCA_H -+#include -+#endif -+#include -+#include /* for chmod(2) */ -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+ -+#include "zlog.h" -+#include "fpm_arrays.h" -+#include "fpm_sockets.h" -+#include "fpm_worker_pool.h" -+#include "fpm_unix.h" -+#include "fpm_str.h" -+#include "fpm_env.h" -+#include "fpm_cleanup.h" -+ -+struct listening_socket_s { -+ int refcount; -+ int sock; -+ int type; -+ char *key; -+}; -+ -+static struct fpm_array_s sockets_list; -+ -+static int fpm_sockets_resolve_af_inet(char *node, char *service, struct sockaddr_in *addr) -+{ -+ struct addrinfo *res; -+ struct addrinfo hints; -+ int ret; -+ -+ memset(&hints, 0, sizeof(hints)); -+ -+ hints.ai_family = AF_INET; -+ -+ ret = getaddrinfo(node, service, &hints, &res); -+ -+ if (ret != 0) { -+ zlog(ZLOG_STUFF, ZLOG_ERROR, "can't resolve hostname '%s%s%s': getaddrinfo said: %s%s%s\n", -+ node, service ? ":" : "", service ? service : "", -+ gai_strerror(ret), ret == EAI_SYSTEM ? ", system error: " : "", ret == EAI_SYSTEM ? strerror(errno) : ""); -+ return -1; -+ } -+ -+ *addr = *(struct sockaddr_in *) res->ai_addr; -+ -+ freeaddrinfo(res); -+ -+ return 0; -+} -+ -+enum { FPM_GET_USE_SOCKET = 1, FPM_STORE_SOCKET = 2, FPM_STORE_USE_SOCKET = 3 }; -+ -+static void fpm_sockets_cleanup(int which, void *arg) -+{ -+ int i; -+ char *env_value = 0; -+ int p = 0; -+ struct listening_socket_s *ls = sockets_list.data; -+ -+ for (i = 0; i < sockets_list.used; i++, ls++) { -+ -+ if (which != FPM_CLEANUP_PARENT_EXEC) { -+ -+ close(ls->sock); -+ -+ } -+ else { /* on PARENT EXEC we want socket fds to be inherited through environment variable */ -+ char fd[32]; -+ sprintf(fd, "%d", ls->sock); -+ env_value = realloc(env_value, p + (p ? 1 : 0) + strlen(ls->key) + 1 + strlen(fd) + 1); -+ p += sprintf(env_value + p, "%s%s=%s", p ? "," : "", ls->key, fd); -+ } -+ -+ if (which == FPM_CLEANUP_PARENT_EXIT_MAIN) { -+ -+ if (ls->type == FPM_AF_UNIX) { -+ unlink(ls->key); -+ } -+ -+ } -+ -+ free(ls->key); -+ } -+ -+ if (env_value) { -+ setenv("FPM_SOCKETS", env_value, 1); -+ free(env_value); -+ } -+ -+ fpm_array_free(&sockets_list); -+} -+ -+static int fpm_sockets_hash_op(int sock, struct sockaddr *sa, char *key, int type, int op) -+{ -+ -+ if (key == NULL) { -+ -+ switch (type) { -+ -+ case FPM_AF_INET : { -+ struct sockaddr_in *sa_in = (struct sockaddr_in *) sa; -+ -+ key = alloca(sizeof("xxx.xxx.xxx.xxx:ppppp")); -+ -+ sprintf(key, "%u.%u.%u.%u:%u", IPQUAD(&sa_in->sin_addr), (unsigned int) ntohs(sa_in->sin_port)); -+ -+ break; -+ } -+ -+ case FPM_AF_UNIX : { -+ struct sockaddr_un *sa_un = (struct sockaddr_un *) sa; -+ -+ key = alloca(strlen(sa_un->sun_path) + 1); -+ -+ strcpy(key, sa_un->sun_path); -+ -+ break; -+ } -+ -+ default : -+ -+ return -1; -+ } -+ -+ } -+ -+ switch (op) { -+ -+ case FPM_GET_USE_SOCKET : -+ { -+ -+ int i; -+ struct listening_socket_s *ls = sockets_list.data; -+ -+ for (i = 0; i < sockets_list.used; i++, ls++) { -+ -+ if (!strcmp(ls->key, key)) { -+ ++ls->refcount; -+ return ls->sock; -+ } -+ } -+ -+ break; -+ } -+ -+ case FPM_STORE_SOCKET : /* inherited socket */ -+ case FPM_STORE_USE_SOCKET : /* just created */ -+ { -+ -+ struct listening_socket_s *ls; -+ -+ ls = fpm_array_push(&sockets_list); -+ -+ if (!ls) { -+ break; -+ } -+ -+ if (op == FPM_STORE_SOCKET) { -+ ls->refcount = 0; -+ } -+ else { -+ ls->refcount = 1; -+ } -+ ls->type = type; -+ ls->sock = sock; -+ ls->key = strdup(key); -+ -+ return 0; -+ -+ } -+ } -+ -+ return -1; -+ -+} -+ -+static int fpm_sockets_new_listening_socket(struct fpm_worker_pool_s *wp, struct sockaddr *sa, int socklen) -+{ -+ int backlog = -1; -+ int flags = 1; -+ int sock; -+ mode_t saved_umask; -+ -+ /* we have custom backlog value */ -+ if (wp->config->listen_options) { -+ backlog = wp->config->listen_options->backlog; -+ } -+ -+ sock = socket(sa->sa_family, SOCK_STREAM, 0); -+ -+ if (0 > sock) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "socket() failed"); -+ return -1; -+ } -+ -+ setsockopt(sock, SOL_SOCKET, SO_REUSEADDR, &flags, sizeof(flags)); -+ -+ if (wp->listen_address_domain == FPM_AF_UNIX) { -+ unlink( ((struct sockaddr_un *) sa)->sun_path); -+ } -+ -+ saved_umask = umask(0777 ^ wp->socket_mode); -+ -+ if (0 > bind(sock, sa, socklen)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "bind() for address '%s' failed", wp->config->listen_address); -+ return -1; -+ } -+ -+ if (wp->listen_address_domain == FPM_AF_UNIX) { -+ -+ char *path = ((struct sockaddr_un *) sa)->sun_path; -+ -+ if (wp->socket_uid != -1 || wp->socket_gid != -1) { -+ -+ if (0 > chown(path, wp->socket_uid, wp->socket_gid)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "chown() for address '%s' failed", wp->config->listen_address); -+ return -1; -+ } -+ -+ } -+ -+ } -+ -+ umask(saved_umask); -+ -+ if (0 > listen(sock, backlog)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "listen() for address '%s' failed", wp->config->listen_address); -+ return -1; -+ } -+ -+ return sock; -+} -+ -+static int fpm_sockets_get_listening_socket(struct fpm_worker_pool_s *wp, struct sockaddr *sa, int socklen) -+{ -+ int sock; -+ -+ sock = fpm_sockets_hash_op(0, sa, 0, wp->listen_address_domain, FPM_GET_USE_SOCKET); -+ -+ if (sock >= 0) return sock; -+ -+ sock = fpm_sockets_new_listening_socket(wp, sa, socklen); -+ -+ fpm_sockets_hash_op(sock, sa, 0, wp->listen_address_domain, FPM_STORE_USE_SOCKET); -+ -+ return sock; -+} -+ -+enum fpm_address_domain fpm_sockets_domain_from_address(char *address) -+{ -+ if (strchr(address, ':')) return FPM_AF_INET; -+ -+ if (strlen(address) == strspn(address, "0123456789")) return FPM_AF_INET; -+ -+ return FPM_AF_UNIX; -+} -+ -+static int fpm_socket_af_inet_listening_socket(struct fpm_worker_pool_s *wp) -+{ -+ struct sockaddr_in sa_in; -+ char *dup_address = strdup(wp->config->listen_address); -+ char *port_str = strchr(dup_address, ':'); -+ char *addr = NULL; -+ int port = 0; -+ -+ if (port_str) { /* this is host:port pair */ -+ *port_str++ = '\0'; -+ port = atoi(port_str); -+ addr = dup_address; -+ } -+ else if (strlen(dup_address) == strspn(dup_address, "0123456789")) { /* this is port */ -+ port = atoi(dup_address); -+ port_str = dup_address; -+ } -+ -+ if (port == 0) { -+ zlog(ZLOG_STUFF, ZLOG_ERROR, "invalid port value '%s'", port_str); -+ return -1; -+ } -+ -+ memset(&sa_in, 0, sizeof(sa_in)); -+ -+ if (addr) { -+ -+ sa_in.sin_addr.s_addr = inet_addr(addr); -+ -+ if (sa_in.sin_addr.s_addr == INADDR_NONE) { /* do resolve */ -+ if (0 > fpm_sockets_resolve_af_inet(addr, NULL, &sa_in)) { -+ return -1; -+ } -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "address '%s' resolved as %u.%u.%u.%u", addr, IPQUAD(&sa_in.sin_addr)); -+ } -+ } -+ else { -+ -+ sa_in.sin_addr.s_addr = htonl(INADDR_ANY); -+ -+ } -+ -+ sa_in.sin_family = AF_INET; -+ sa_in.sin_port = htons(port); -+ -+ free(dup_address); -+ -+ return fpm_sockets_get_listening_socket(wp, (struct sockaddr *) &sa_in, sizeof(struct sockaddr_in)); -+} -+ -+static int fpm_socket_af_unix_listening_socket(struct fpm_worker_pool_s *wp) -+{ -+ struct sockaddr_un sa_un; -+ -+ memset(&sa_un, 0, sizeof(sa_un)); -+ -+ cpystrn(sa_un.sun_path, wp->config->listen_address, sizeof(sa_un.sun_path)); -+ sa_un.sun_family = AF_UNIX; -+ -+ return fpm_sockets_get_listening_socket(wp, (struct sockaddr *) &sa_un, sizeof(struct sockaddr_un)); -+} -+ -+int fpm_sockets_init_main() -+{ -+ int i; -+ struct fpm_worker_pool_s *wp; -+ char *inherited = getenv("FPM_SOCKETS"); -+ struct listening_socket_s *ls; -+ -+ if (0 == fpm_array_init(&sockets_list, sizeof(struct listening_socket_s), 10)) { -+ return -1; -+ } -+ -+ /* import inherited sockets */ -+ while (inherited && *inherited) { -+ char *comma = strchr(inherited, ','); -+ int type, fd_no; -+ char *eq; -+ -+ if (comma) *comma = '\0'; -+ -+ eq = strchr(inherited, '='); -+ -+ if (eq) { -+ *eq = '\0'; -+ -+ fd_no = atoi(eq + 1); -+ -+ type = fpm_sockets_domain_from_address(inherited); -+ -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "using inherited socket fd=%d, \"%s\"", fd_no, inherited); -+ -+ fpm_sockets_hash_op(fd_no, 0, inherited, type, FPM_STORE_SOCKET); -+ } -+ -+ if (comma) inherited = comma + 1; -+ else inherited = 0; -+ } -+ -+ /* create all required sockets */ -+ for (wp = fpm_worker_all_pools; wp; wp = wp->next) { -+ -+ if (!wp->is_template) { -+ -+ switch (wp->listen_address_domain) { -+ -+ case FPM_AF_INET : -+ -+ wp->listening_socket = fpm_socket_af_inet_listening_socket(wp); -+ break; -+ -+ case FPM_AF_UNIX : -+ -+ if (0 > fpm_unix_resolve_socket_premissions(wp)) { -+ return -1; -+ } -+ -+ wp->listening_socket = fpm_socket_af_unix_listening_socket(wp); -+ break; -+ -+ } -+ -+ if (wp->listening_socket == -1) { -+ return -1; -+ } -+ } -+ -+ } -+ -+ /* close unused sockets that was inherited */ -+ ls = sockets_list.data; -+ -+ for (i = 0; i < sockets_list.used; ) { -+ -+ if (ls->refcount == 0) { -+ close(ls->sock); -+ if (ls->type == FPM_AF_UNIX) { -+ unlink(ls->key); -+ } -+ free(ls->key); -+ fpm_array_item_remove(&sockets_list, i); -+ } -+ else { -+ ++i; -+ ++ls; -+ } -+ } -+ -+ if (0 > fpm_cleanup_add(FPM_CLEANUP_ALL, fpm_sockets_cleanup, 0)) { -+ return -1; -+ } -+ -+ return 0; -+} -diff --git a/sapi/cgi/fpm/fpm_sockets.h b/sapi/cgi/fpm/fpm_sockets.h -new file mode 100644 -index 0000000..d5433e3 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_sockets.h -@@ -0,0 +1,37 @@ -+ -+ /* $Id: fpm_sockets.h,v 1.12 2008/08/26 15:09:15 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_MISC_H -+#define FPM_MISC_H 1 -+ -+#include -+#include -+ -+#include "fpm_worker_pool.h" -+ -+enum fpm_address_domain fpm_sockets_domain_from_address(char *addr); -+int fpm_sockets_init_main(); -+ -+ -+static inline int fd_set_blocked(int fd, int blocked) -+{ -+ int flags = fcntl(fd, F_GETFL); -+ -+ if (flags < 0) return -1; -+ -+ if (blocked) -+ flags &= ~O_NONBLOCK; -+ else -+ flags |= O_NONBLOCK; -+ -+ return fcntl(fd, F_SETFL, flags); -+} -+ -+#define IPQUAD(sin_addr) \ -+ (unsigned int) ((unsigned char *) &(sin_addr)->s_addr)[0], \ -+ (unsigned int) ((unsigned char *) &(sin_addr)->s_addr)[1], \ -+ (unsigned int) ((unsigned char *) &(sin_addr)->s_addr)[2], \ -+ (unsigned int) ((unsigned char *) &(sin_addr)->s_addr)[3] -+ -+#endif -diff --git a/sapi/cgi/fpm/fpm_stdio.c b/sapi/cgi/fpm/fpm_stdio.c -new file mode 100644 -index 0000000..a6818d7 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_stdio.c -@@ -0,0 +1,286 @@ -+ -+ /* $Id: fpm_stdio.c,v 1.22.2.2 2008/12/13 03:32:24 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#include -+#include -+#include -+#include -+#include -+#include -+ -+#include "fpm.h" -+#include "fpm_children.h" -+#include "fpm_events.h" -+#include "fpm_sockets.h" -+#include "fpm_stdio.h" -+#include "zlog.h" -+ -+static int fd_stdout[2]; -+static int fd_stderr[2]; -+ -+int fpm_stdio_init_main() -+{ -+ int fd = open("/dev/null", O_RDWR); -+ -+ if (0 > fd) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "open(\"/dev/null\") failed"); -+ return -1; -+ } -+ -+ if (0 > dup2(fd, STDIN_FILENO) || 0 > dup2(fd, STDOUT_FILENO)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "dup2() failed"); -+ return -1; -+ } -+ -+ close(fd); -+ -+ return 0; -+} -+ -+int fpm_stdio_init_final() -+{ -+ if (fpm_global_config.daemonize) { -+ -+ if (fpm_globals.error_log_fd != STDERR_FILENO) { -+ /* there might be messages to stderr from libevent, we need to log them all */ -+ if (0 > dup2(fpm_globals.error_log_fd, STDERR_FILENO)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "dup2() failed"); -+ return -1; -+ } -+ } -+ -+ zlog_set_level(fpm_globals.log_level); -+ -+ zlog_set_fd(fpm_globals.error_log_fd); -+ } -+ -+ return 0; -+} -+ -+int fpm_stdio_init_child(struct fpm_worker_pool_s *wp) -+{ -+ close(fpm_globals.error_log_fd); -+ fpm_globals.error_log_fd = -1; -+ zlog_set_fd(-1); -+ -+ if (wp->listening_socket != STDIN_FILENO) { -+ if (0 > dup2(wp->listening_socket, STDIN_FILENO)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "dup2() failed"); -+ return -1; -+ } -+ } -+ -+ return 0; -+} -+ -+static void fpm_stdio_child_said(int fd, short which, void *arg) -+{ -+ static const int max_buf_size = 1024; -+ char buf[max_buf_size]; -+ struct fpm_child_s *child = arg; -+ int is_stdout = fd == child->fd_stdout; -+ struct event *ev = is_stdout ? &child->ev_stdout : &child->ev_stderr; -+ int fifo_in = 1, fifo_out = 1; -+ int is_last_message = 0; -+ int in_buf = 0; -+ int res; -+ -+#if 0 -+ zlog(ZLOG_STUFF, ZLOG_DEBUG, "child %d said %s", (int) child->pid, is_stdout ? "stdout" : "stderr"); -+#endif -+ -+ while (fifo_in || fifo_out) { -+ -+ if (fifo_in) { -+ -+ res = read(fd, buf + in_buf, max_buf_size - 1 - in_buf); -+ -+ if (res <= 0) { /* no data */ -+ fifo_in = 0; -+ -+ if (res < 0 && (errno == EAGAIN || errno == EWOULDBLOCK)) { -+ /* just no more data ready */ -+ } -+ else { /* error or pipe is closed */ -+ -+ if (res < 0) { /* error */ -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "read() failed"); -+ } -+ -+ fpm_event_del(ev); -+ is_last_message = 1; -+ -+ if (is_stdout) { -+ close(child->fd_stdout); -+ child->fd_stdout = -1; -+ } -+ else { -+ close(child->fd_stderr); -+ child->fd_stderr = -1; -+ } -+ -+#if 0 -+ if (in_buf == 0 && !fpm_globals.is_child) { -+ zlog(ZLOG_STUFF, ZLOG_DEBUG, "child %d (pool %s) %s pipe is closed", (int) child->pid, -+ child->wp->config->name, is_stdout ? "stdout" : "stderr"); -+ } -+#endif -+ } -+ } -+ else { -+ in_buf += res; -+ } -+ } -+ -+ if (fifo_out) { -+ if (in_buf == 0) { -+ fifo_out = 0; -+ } -+ else { -+ char *nl; -+ int should_print = 0; -+ buf[in_buf] = '\0'; -+ -+ /* FIXME: there might be binary data */ -+ -+ /* we should print if no more space in the buffer */ -+ if (in_buf == max_buf_size - 1) { -+ should_print = 1; -+ } -+ -+ /* we should print if no more data to come */ -+ if (!fifo_in) { -+ should_print = 1; -+ } -+ -+ nl = strchr(buf, '\n'); -+ -+ if (nl || should_print) { -+ -+ if (nl) { -+ *nl = '\0'; -+ } -+ -+ zlog(ZLOG_STUFF, ZLOG_WARNING, "child %d (pool %s) said into %s: \"%s\"%s", (int) child->pid, -+ child->wp->config->name, is_stdout ? "stdout" : "stderr", buf, is_last_message ? ", pipe is closed" : ""); -+ -+ if (nl) { -+ int out_buf = 1 + nl - buf; -+ memmove(buf, buf + out_buf, in_buf - out_buf); -+ in_buf -= out_buf; -+ } -+ else { -+ in_buf = 0; -+ } -+ } -+ } -+ } -+ } -+ -+} -+ -+int fpm_stdio_prepare_pipes(struct fpm_child_s *child) -+{ -+ if (0 == child->wp->config->catch_workers_output) { /* not required */ -+ return 0; -+ } -+ -+ if (0 > pipe(fd_stdout)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "pipe() failed"); -+ return -1; -+ } -+ -+ if (0 > pipe(fd_stderr)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "pipe() failed"); -+ close(fd_stdout[0]); close(fd_stdout[1]); -+ return -1; -+ } -+ -+ if (0 > fd_set_blocked(fd_stdout[0], 0) || 0 > fd_set_blocked(fd_stderr[0], 0)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "fd_set_blocked() failed"); -+ close(fd_stdout[0]); close(fd_stdout[1]); -+ close(fd_stderr[0]); close(fd_stderr[1]); -+ return -1; -+ } -+ -+ return 0; -+} -+ -+int fpm_stdio_parent_use_pipes(struct fpm_child_s *child) -+{ -+ if (0 == child->wp->config->catch_workers_output) { /* not required */ -+ return 0; -+ } -+ -+ close(fd_stdout[1]); -+ close(fd_stderr[1]); -+ -+ child->fd_stdout = fd_stdout[0]; -+ child->fd_stderr = fd_stderr[0]; -+ -+ fpm_event_add(child->fd_stdout, &child->ev_stdout, fpm_stdio_child_said, child); -+ fpm_event_add(child->fd_stderr, &child->ev_stderr, fpm_stdio_child_said, child); -+ -+ return 0; -+} -+ -+int fpm_stdio_discard_pipes(struct fpm_child_s *child) -+{ -+ if (0 == child->wp->config->catch_workers_output) { /* not required */ -+ return 0; -+ } -+ -+ close(fd_stdout[1]); -+ close(fd_stderr[1]); -+ -+ close(fd_stdout[0]); -+ close(fd_stderr[0]); -+ -+ return 0; -+} -+ -+void fpm_stdio_child_use_pipes(struct fpm_child_s *child) -+{ -+ if (child->wp->config->catch_workers_output) { -+ dup2(fd_stdout[1], STDOUT_FILENO); -+ dup2(fd_stderr[1], STDERR_FILENO); -+ close(fd_stdout[0]); close(fd_stdout[1]); -+ close(fd_stderr[0]); close(fd_stderr[1]); -+ } -+ else { -+ /* stdout of parent is always /dev/null */ -+ dup2(STDOUT_FILENO, STDERR_FILENO); -+ } -+} -+ -+int fpm_stdio_open_error_log(int reopen) -+{ -+ int fd; -+ -+ fd = open(fpm_global_config.error_log, O_WRONLY | O_APPEND | O_CREAT, S_IRUSR | S_IWUSR); -+ -+ if (0 > fd) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "open(\"%s\") failed", fpm_global_config.error_log); -+ return -1; -+ } -+ -+ if (reopen) { -+ if (fpm_global_config.daemonize) { -+ dup2(fd, STDERR_FILENO); -+ } -+ -+ dup2(fd, fpm_globals.error_log_fd); -+ close(fd); -+ fd = fpm_globals.error_log_fd; /* for FD_CLOSEXEC to work */ -+ } -+ else { -+ fpm_globals.error_log_fd = fd; -+ } -+ -+ fcntl(fd, F_SETFD, fcntl(fd, F_GETFD) | FD_CLOEXEC); -+ -+ return 0; -+} -diff --git a/sapi/cgi/fpm/fpm_stdio.h b/sapi/cgi/fpm/fpm_stdio.h -new file mode 100644 -index 0000000..d3d61e4 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_stdio.h -@@ -0,0 +1,20 @@ -+ -+ /* $Id: fpm_stdio.h,v 1.9 2008/05/24 17:38:47 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_STDIO_H -+#define FPM_STDIO_H 1 -+ -+#include "fpm_worker_pool.h" -+ -+int fpm_stdio_init_main(); -+int fpm_stdio_init_final(); -+int fpm_stdio_init_child(struct fpm_worker_pool_s *wp); -+int fpm_stdio_prepare_pipes(struct fpm_child_s *child); -+void fpm_stdio_child_use_pipes(struct fpm_child_s *child); -+int fpm_stdio_parent_use_pipes(struct fpm_child_s *child); -+int fpm_stdio_discard_pipes(struct fpm_child_s *child); -+int fpm_stdio_open_error_log(int reopen); -+ -+#endif -+ -diff --git a/sapi/cgi/fpm/fpm_str.h b/sapi/cgi/fpm/fpm_str.h -new file mode 100644 -index 0000000..19e2055 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_str.h -@@ -0,0 +1,49 @@ -+ -+ /* $Id: fpm_str.h,v 1.3 2008/05/24 17:38:47 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_STR_H -+#define FPM_STR_H 1 -+ -+static inline char *cpystrn(char *dst, const char *src, size_t dst_size) -+{ -+ char *d, *end; -+ -+ if (!dst_size) return dst; -+ -+ d = dst; -+ end = dst + dst_size - 1; -+ -+ for (; d < end; ++d, ++src) { -+ if (!(*d = *src)) { -+ return d; -+ } -+ } -+ -+ *d = '\0'; -+ -+ return d; -+} -+ -+static inline char *str_purify_filename(char *dst, char *src, size_t size) -+{ -+ char *d, *end; -+ -+ d = dst; -+ end = dst + size - 1; -+ -+ for (; d < end && *src; ++d, ++src) { -+ if (* (unsigned char *) src < ' ' || * (unsigned char *) src > '\x7f') { -+ *d = '.'; -+ } -+ else { -+ *d = *src; -+ } -+ } -+ -+ *d = '\0'; -+ -+ return d; -+} -+ -+#endif -diff --git a/sapi/cgi/fpm/fpm_trace.c b/sapi/cgi/fpm/fpm_trace.c -new file mode 100644 -index 0000000..7996355 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_trace.c -@@ -0,0 +1,46 @@ -+ -+ /* $Id: fpm_trace.c,v 1.1 2008/07/20 20:59:00 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#include -+ -+#include "fpm_trace.h" -+ -+int fpm_trace_get_strz(char *buf, size_t sz, long addr) -+{ -+ int i; -+ long l; -+ char *lc = (char *) &l; -+ -+ if (0 > fpm_trace_get_long(addr, &l)) { -+ return -1; -+ } -+ -+ i = l % SIZEOF_LONG; -+ -+ l -= i; -+ -+ for (addr = l; ; addr += SIZEOF_LONG) { -+ -+ if (0 > fpm_trace_get_long(addr, &l)) { -+ return -1; -+ } -+ -+ for ( ; i < SIZEOF_LONG; i++) { -+ --sz; -+ -+ if (sz && lc[i]) { -+ *buf++ = lc[i]; -+ continue; -+ } -+ -+ *buf = '\0'; -+ return 0; -+ } -+ -+ i = 0; -+ } -+} -+ -diff --git a/sapi/cgi/fpm/fpm_trace.h b/sapi/cgi/fpm/fpm_trace.h -new file mode 100644 -index 0000000..b421172 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_trace.h -@@ -0,0 +1,17 @@ -+ -+ /* $Id: fpm_trace.h,v 1.3 2008/07/20 22:43:39 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_TRACE_H -+#define FPM_TRACE_H 1 -+ -+#include -+ -+int fpm_trace_signal(pid_t pid); -+int fpm_trace_ready(pid_t pid); -+int fpm_trace_close(pid_t pid); -+int fpm_trace_get_long(long addr, long *data); -+int fpm_trace_get_strz(char *buf, size_t sz, long addr); -+ -+#endif -+ -diff --git a/sapi/cgi/fpm/fpm_trace_mach.c b/sapi/cgi/fpm/fpm_trace_mach.c -new file mode 100644 -index 0000000..11cb9cf ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_trace_mach.c -@@ -0,0 +1,102 @@ -+ -+ /* $Id: fpm_trace_mach.c,v 1.4 2008/08/26 15:09:15 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#include -+#include -+ -+#include -+ -+#include "fpm_trace.h" -+#include "fpm_process_ctl.h" -+#include "fpm_unix.h" -+#include "zlog.h" -+ -+ -+static mach_port_name_t target; -+static vm_offset_t target_page_base; -+static vm_offset_t local_page; -+static mach_msg_type_number_t local_size; -+ -+static void fpm_mach_vm_deallocate() -+{ -+ if (local_page) { -+ mach_vm_deallocate(mach_task_self(), local_page, local_size); -+ target_page_base = 0; -+ local_page = 0; -+ local_size = 0; -+ } -+} -+ -+static int fpm_mach_vm_read_page(vm_offset_t page) -+{ -+ kern_return_t kr; -+ -+ kr = mach_vm_read(target, page, fpm_pagesize, &local_page, &local_size); -+ -+ if (kr != KERN_SUCCESS) { -+ zlog(ZLOG_STUFF, ZLOG_ERROR, "mach_vm_read() failed: %s (%d)", mach_error_string(kr), kr); -+ return -1; -+ } -+ -+ return 0; -+} -+ -+int fpm_trace_signal(pid_t pid) -+{ -+ if (0 > fpm_pctl_kill(pid, FPM_PCTL_STOP)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "kill(SIGSTOP) failed"); -+ return -1; -+ } -+ -+ return 0; -+} -+ -+int fpm_trace_ready(pid_t pid) -+{ -+ kern_return_t kr; -+ -+ kr = task_for_pid(mach_task_self(), pid, &target); -+ -+ if (kr != KERN_SUCCESS) { -+ char *msg = ""; -+ -+ if (kr == KERN_FAILURE) { -+ msg = " It seems that master process does not have enough privileges to trace processes."; -+ } -+ -+ zlog(ZLOG_STUFF, ZLOG_ERROR, "task_for_pid() failed: %s (%d)%s", mach_error_string(kr), kr, msg); -+ return -1; -+ } -+ -+ return 0; -+} -+ -+int fpm_trace_close(pid_t pid) -+{ -+ fpm_mach_vm_deallocate(); -+ -+ target = 0; -+ -+ return 0; -+} -+ -+int fpm_trace_get_long(long addr, long *data) -+{ -+ size_t offset = ((uintptr_t) (addr) % fpm_pagesize); -+ vm_offset_t base = (uintptr_t) (addr) - offset; -+ -+ if (base != target_page_base) { -+ fpm_mach_vm_deallocate(); -+ if (0 > fpm_mach_vm_read_page(base)) { -+ return -1; -+ } -+ } -+ -+ *data = * (long *) (local_page + offset); -+ -+ return 0; -+} -+ -diff --git a/sapi/cgi/fpm/fpm_trace_pread.c b/sapi/cgi/fpm/fpm_trace_pread.c -new file mode 100644 -index 0000000..f41bb91 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_trace_pread.c -@@ -0,0 +1,67 @@ -+ -+ /* $Id: fpm_trace_pread.c,v 1.7 2008/08/26 15:09:15 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#define _GNU_SOURCE -+#define _FILE_OFFSET_BITS 64 -+ -+#include "fpm_config.h" -+ -+#include -+ -+#include -+#include -+#include -+ -+#include "fpm_trace.h" -+#include "fpm_process_ctl.h" -+#include "zlog.h" -+ -+ -+static int mem_file = -1; -+ -+int fpm_trace_signal(pid_t pid) -+{ -+ if (0 > fpm_pctl_kill(pid, FPM_PCTL_STOP)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "kill(SIGSTOP) failed"); -+ return -1; -+ } -+ -+ return 0; -+} -+ -+int fpm_trace_ready(pid_t pid) -+{ -+ char buf[128]; -+ -+ sprintf(buf, "/proc/%d/" PROC_MEM_FILE, (int) pid); -+ -+ mem_file = open(buf, O_RDONLY); -+ -+ if (0 > mem_file) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "open(%s) failed", buf); -+ return -1; -+ } -+ -+ return 0; -+} -+ -+int fpm_trace_close(pid_t pid) -+{ -+ close(mem_file); -+ -+ mem_file = -1; -+ -+ return 0; -+} -+ -+int fpm_trace_get_long(long addr, long *data) -+{ -+ if (sizeof(*data) != pread(mem_file, (void *) data, sizeof(*data), (uintptr_t) addr)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "pread() failed"); -+ return -1; -+ } -+ -+ return 0; -+} -+ -diff --git a/sapi/cgi/fpm/fpm_trace_ptrace.c b/sapi/cgi/fpm/fpm_trace_ptrace.c -new file mode 100644 -index 0000000..11e2081 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_trace_ptrace.c -@@ -0,0 +1,85 @@ -+ -+ /* $Id: fpm_trace_ptrace.c,v 1.7 2008/09/18 23:34:11 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#include -+#include -+#include -+#include -+ -+#if defined(PT_ATTACH) && !defined(PTRACE_ATTACH) -+#define PTRACE_ATTACH PT_ATTACH -+#endif -+ -+#if defined(PT_DETACH) && !defined(PTRACE_DETACH) -+#define PTRACE_DETACH PT_DETACH -+#endif -+ -+#if defined(PT_READ_D) && !defined(PTRACE_PEEKDATA) -+#define PTRACE_PEEKDATA PT_READ_D -+#endif -+ -+#include "fpm_trace.h" -+#include "zlog.h" -+ -+static pid_t traced_pid; -+ -+int fpm_trace_signal(pid_t pid) -+{ -+ if (0 > ptrace(PTRACE_ATTACH, pid, 0, 0)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "ptrace(ATTACH) failed"); -+ return -1; -+ } -+ -+ return 0; -+} -+ -+int fpm_trace_ready(pid_t pid) -+{ -+ traced_pid = pid; -+ -+ return 0; -+} -+ -+int fpm_trace_close(pid_t pid) -+{ -+ if (0 > ptrace(PTRACE_DETACH, pid, (void *) 1, 0)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "ptrace(DETACH) failed"); -+ return -1; -+ } -+ -+ traced_pid = 0; -+ -+ return 0; -+} -+ -+int fpm_trace_get_long(long addr, long *data) -+{ -+#ifdef PT_IO -+ struct ptrace_io_desc ptio = { -+ .piod_op = PIOD_READ_D, -+ .piod_offs = (void *) addr, -+ .piod_addr = (void *) data, -+ .piod_len = sizeof(long) -+ }; -+ -+ if (0 > ptrace(PT_IO, traced_pid, (void *) &ptio, 0)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "ptrace(PT_IO) failed"); -+ return -1; -+ } -+#else -+ errno = 0; -+ -+ *data = ptrace(PTRACE_PEEKDATA, traced_pid, (void *) addr, 0); -+ -+ if (errno) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "ptrace(PEEKDATA) failed"); -+ return -1; -+ } -+#endif -+ -+ return 0; -+} -+ -diff --git a/sapi/cgi/fpm/fpm_unix.c b/sapi/cgi/fpm/fpm_unix.c -new file mode 100644 -index 0000000..4d5eecc ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_unix.c -@@ -0,0 +1,289 @@ -+ -+ /* $Id: fpm_unix.c,v 1.25.2.1 2008/12/13 03:18:23 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+ -+#ifdef HAVE_PRCTL -+#include -+#endif -+ -+#include "fpm.h" -+#include "fpm_conf.h" -+#include "fpm_cleanup.h" -+#include "fpm_clock.h" -+#include "fpm_stdio.h" -+#include "fpm_unix.h" -+#include "zlog.h" -+ -+size_t fpm_pagesize; -+ -+int fpm_unix_resolve_socket_premissions(struct fpm_worker_pool_s *wp) -+{ -+ struct fpm_listen_options_s *lo = wp->config->listen_options; -+ -+ /* uninitialized */ -+ wp->socket_uid = -1; -+ wp->socket_gid = -1; -+ wp->socket_mode = 0666; -+ -+ if (!lo) return 0; -+ -+ if (lo->owner && *lo->owner) { -+ struct passwd *pwd; -+ -+ pwd = getpwnam(lo->owner); -+ -+ if (!pwd) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "cannot get uid for user '%s', pool '%s'", lo->owner, wp->config->name); -+ return -1; -+ } -+ -+ wp->socket_uid = pwd->pw_uid; -+ wp->socket_gid = pwd->pw_gid; -+ } -+ -+ if (lo->group && *lo->group) { -+ struct group *grp; -+ -+ grp = getgrnam(lo->group); -+ -+ if (!grp) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "cannot get gid for group '%s', pool '%s'", lo->group, wp->config->name); -+ return -1; -+ } -+ -+ wp->socket_gid = grp->gr_gid; -+ } -+ -+ if (lo->mode && *lo->mode) { -+ wp->socket_mode = strtoul(lo->mode, 0, 8); -+ } -+ -+ return 0; -+} -+ -+static int fpm_unix_conf_wp(struct fpm_worker_pool_s *wp) -+{ -+ int is_root = !geteuid(); -+ -+ if (is_root) { -+ if (wp->config->user && *wp->config->user) { -+ -+ if (strlen(wp->config->user) == strspn(wp->config->user, "0123456789")) { -+ wp->set_uid = strtoul(wp->config->user, 0, 10); -+ } -+ else { -+ struct passwd *pwd; -+ -+ pwd = getpwnam(wp->config->user); -+ -+ if (!pwd) { -+ zlog(ZLOG_STUFF, ZLOG_ERROR, "cannot get uid for user '%s', pool '%s'", wp->config->user, wp->config->name); -+ return -1; -+ } -+ -+ wp->set_uid = pwd->pw_uid; -+ wp->set_gid = pwd->pw_gid; -+ -+ wp->user = strdup(pwd->pw_name); -+ wp->home = strdup(pwd->pw_dir); -+ } -+ } -+ -+ if (wp->config->group && *wp->config->group) { -+ -+ if (strlen(wp->config->group) == strspn(wp->config->group, "0123456789")) { -+ wp->set_gid = strtoul(wp->config->group, 0, 10); -+ } -+ else { -+ struct group *grp; -+ -+ grp = getgrnam(wp->config->group); -+ -+ if (!grp) { -+ zlog(ZLOG_STUFF, ZLOG_ERROR, "cannot get gid for group '%s', pool '%s'", wp->config->group, wp->config->name); -+ return -1; -+ } -+ -+ wp->set_gid = grp->gr_gid; -+ } -+ } -+ -+#ifndef I_REALLY_WANT_ROOT_PHP -+ if (wp->set_uid == 0 || wp->set_gid == 0) { -+ zlog(ZLOG_STUFF, ZLOG_ERROR, "please specify user and group other than root, pool '%s'", wp->config->name); -+ return -1; -+ } -+#endif -+ } -+ else { /* not root */ -+ if (wp->config->user && *wp->config->user) { -+ zlog(ZLOG_STUFF, ZLOG_WARNING, "'user' directive is ignored, pool '%s'", wp->config->name); -+ } -+ if (wp->config->group && *wp->config->group) { -+ zlog(ZLOG_STUFF, ZLOG_WARNING, "'group' directive is ignored, pool '%s'", wp->config->name); -+ } -+ if (wp->config->chroot && *wp->config->chroot) { -+ zlog(ZLOG_STUFF, ZLOG_WARNING, "'chroot' directive is ignored, pool '%s'", wp->config->name); -+ } -+ -+ { /* set up HOME and USER anyway */ -+ struct passwd *pwd; -+ -+ pwd = getpwuid(getuid()); -+ -+ if (pwd) { -+ wp->user = strdup(pwd->pw_name); -+ wp->home = strdup(pwd->pw_dir); -+ } -+ } -+ } -+ -+ return 0; -+} -+ -+int fpm_unix_init_child(struct fpm_worker_pool_s *wp) -+{ -+ int is_root = !geteuid(); -+ int made_chroot = 0; -+ -+ if (wp->config->rlimit_files) { -+ struct rlimit r; -+ -+ getrlimit(RLIMIT_NOFILE, &r); -+ -+ r.rlim_cur = (rlim_t) wp->config->rlimit_files; -+ r.rlim_max = r.rlim_cur; -+ if (0 > setrlimit(RLIMIT_NOFILE, &r)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "setrlimit(RLIMIT_NOFILE) failed"); -+ } -+ } -+ -+ if (wp->config->rlimit_core) { -+ struct rlimit r; -+ -+ getrlimit(RLIMIT_CORE, &r); -+ -+ r.rlim_cur = wp->config->rlimit_core == -1 ? (rlim_t) RLIM_INFINITY : (rlim_t) wp->config->rlimit_core; -+ r.rlim_max = r.rlim_cur; -+ if (0 > setrlimit(RLIMIT_CORE, &r)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "setrlimit(RLIMIT_CORE) failed"); -+ } -+ } -+ -+ if (is_root && wp->config->chroot && *wp->config->chroot) { -+ if (0 > chroot(wp->config->chroot)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "chroot(%s) failed", wp->config->chroot); -+ return -1; -+ } -+ made_chroot = 1; -+ } -+ -+ if (wp->config->chdir && *wp->config->chdir) { -+ if (0 > chdir(wp->config->chdir)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "chdir(%s) failed", wp->config->chdir); -+ return -1; -+ } -+ } -+ else if (made_chroot) { -+ chdir("/"); -+ } -+ -+ if (is_root) { -+ if (wp->set_gid) { -+ if (0 > setgid(wp->set_gid)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "setgid(%d) failed", wp->set_gid); -+ return -1; -+ } -+ } -+ if (wp->set_uid) { -+ if (0 > initgroups(wp->config->user, wp->set_gid)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "initgroups(%s, %d) failed", wp->config->user, wp->set_gid); -+ return -1; -+ } -+ if (0 > setuid(wp->set_uid)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "setuid(%d) failed", wp->set_uid); -+ return -1; -+ } -+ } -+ } -+ -+#ifdef HAVE_PRCTL -+ if (0 > prctl(PR_SET_DUMPABLE, 1, 0, 0, 0)) { -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "prctl(PR_SET_DUMPABLE) failed"); -+ } -+#endif -+ -+ if (0 > fpm_clock_init()) { -+ return -1; -+ } -+ -+ return 0; -+} -+ -+int fpm_unix_init_main() -+{ -+ struct fpm_worker_pool_s *wp; -+ -+ fpm_pagesize = getpagesize(); -+ -+ if (fpm_global_config.daemonize) { -+ -+ switch (fork()) { -+ -+ case -1 : -+ -+ zlog(ZLOG_STUFF, ZLOG_SYSERROR, "fork() failed"); -+ return -1; -+ -+ case 0 : -+ -+ break; -+ -+ default : -+ -+ fpm_cleanups_run(FPM_CLEANUP_PARENT_EXIT); -+ exit(0); -+ -+ } -+ -+ } -+ -+ setsid(); -+ -+ if (0 > fpm_clock_init()) { -+ return -1; -+ } -+ -+ fpm_globals.parent_pid = getpid(); -+ -+ for (wp = fpm_worker_all_pools; wp; wp = wp->next) { -+ -+ if (0 > fpm_unix_conf_wp(wp)) { -+ return -1; -+ } -+ -+ } -+ -+ fpm_stdio_init_final(); -+ -+ { -+ struct rlimit r; -+ getrlimit(RLIMIT_NOFILE, &r); -+ -+ zlog(ZLOG_STUFF, ZLOG_NOTICE, "getrlimit(nofile): max:%lld, cur:%lld", -+ (long long) r.rlim_max, (long long) r.rlim_cur); -+ } -+ -+ return 0; -+} -diff --git a/sapi/cgi/fpm/fpm_unix.h b/sapi/cgi/fpm/fpm_unix.h -new file mode 100644 -index 0000000..3451db1 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_unix.h -@@ -0,0 +1,17 @@ -+ -+ /* $Id: fpm_unix.h,v 1.8 2008/05/25 13:21:13 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_UNIX_H -+#define FPM_UNIX_H 1 -+ -+#include "fpm_worker_pool.h" -+ -+int fpm_unix_resolve_socket_premissions(struct fpm_worker_pool_s *wp); -+int fpm_unix_init_child(struct fpm_worker_pool_s *wp); -+int fpm_unix_init_main(); -+ -+extern size_t fpm_pagesize; -+ -+#endif -+ -diff --git a/sapi/cgi/fpm/fpm_worker_pool.c b/sapi/cgi/fpm/fpm_worker_pool.c -new file mode 100644 -index 0000000..49dd5a8 ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_worker_pool.c -@@ -0,0 +1,69 @@ -+ -+ /* $Id: fpm_worker_pool.c,v 1.15.2.1 2008/12/13 03:21:18 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#include -+#include -+#include -+ -+#include "fpm_worker_pool.h" -+#include "fpm_cleanup.h" -+#include "fpm_children.h" -+#include "fpm_shm.h" -+#include "fpm_shm_slots.h" -+#include "fpm_conf.h" -+ -+struct fpm_worker_pool_s *fpm_worker_all_pools; -+ -+static void fpm_worker_pool_cleanup(int which, void *arg) -+{ -+ struct fpm_worker_pool_s *wp, *wp_next; -+ -+ for (wp = fpm_worker_all_pools; wp; wp = wp_next) { -+ wp_next = wp->next; -+ fpm_worker_pool_config_free(wp->config); -+ fpm_children_free(wp->children); -+ fpm_array_free(&wp->slots_used); -+ fpm_array_free(&wp->slots_free); -+ fpm_shm_free_list(wp->shm_list, which == FPM_CLEANUP_CHILD ? fpm_shm_slots_mem() : 0); -+ free(wp->config); -+ free(wp->user); -+ free(wp->home); -+ free(wp); -+ } -+ -+ fpm_worker_all_pools = 0; -+} -+ -+struct fpm_worker_pool_s *fpm_worker_pool_alloc() -+{ -+ struct fpm_worker_pool_s *ret; -+ -+ ret = malloc(sizeof(struct fpm_worker_pool_s)); -+ -+ if (!ret) { -+ return 0; -+ } -+ -+ memset(ret, 0, sizeof(struct fpm_worker_pool_s)); -+ -+ if (!fpm_worker_all_pools) { -+ fpm_worker_all_pools = ret; -+ } -+ -+ fpm_array_init(&ret->slots_used, sizeof(struct fpm_shm_slot_ptr_s), 50); -+ fpm_array_init(&ret->slots_free, sizeof(struct fpm_shm_slot_ptr_s), 50); -+ -+ return ret; -+} -+ -+int fpm_worker_pool_init_main() -+{ -+ if (0 > fpm_cleanup_add(FPM_CLEANUP_ALL, fpm_worker_pool_cleanup, 0)) { -+ return -1; -+ } -+ -+ return 0; -+} -diff --git a/sapi/cgi/fpm/fpm_worker_pool.h b/sapi/cgi/fpm/fpm_worker_pool.h -new file mode 100644 -index 0000000..cc0dbbd ---- /dev/null -+++ b/sapi/cgi/fpm/fpm_worker_pool.h -@@ -0,0 +1,46 @@ -+ -+ /* $Id: fpm_worker_pool.h,v 1.13 2008/08/26 15:09:15 anight Exp $ */ -+ /* (c) 2007,2008 Andrei Nigmatulin */ -+ -+#ifndef FPM_WORKER_POOL_H -+#define FPM_WORKER_POOL_H 1 -+ -+#include "fpm_conf.h" -+#include "fpm_arrays.h" -+ -+struct fpm_worker_pool_s; -+struct fpm_child_s; -+struct fpm_child_stat_s; -+struct fpm_shm_s; -+ -+enum fpm_address_domain { -+ FPM_AF_UNIX = 1, -+ FPM_AF_INET = 2 -+}; -+ -+struct fpm_worker_pool_s { -+ struct fpm_worker_pool_s *next; -+ struct fpm_worker_pool_config_s *config; -+ char *user, *home; /* for setting env USER and HOME */ -+ enum fpm_address_domain listen_address_domain; -+ int listening_socket; -+ int set_uid, set_gid; /* config uid and gid */ -+ unsigned is_template:1; /* just config template, no processes will be created */ -+ int socket_uid, socket_gid, socket_mode; -+ -+ struct fpm_shm_s *shm_list; -+ struct fpm_array_s slots_used; -+ struct fpm_array_s slots_free; -+ -+ /* runtime */ -+ struct fpm_child_s *children; -+ int running_children; -+}; -+ -+struct fpm_worker_pool_s *fpm_worker_pool_alloc(); -+int fpm_worker_pool_init_main(); -+ -+extern struct fpm_worker_pool_s *fpm_worker_all_pools; -+ -+#endif -+ -diff --git a/sapi/cgi/fpm/init.d/php-fpm.in b/sapi/cgi/fpm/init.d/php-fpm.in -new file mode 100644 -index 0000000..0befa52 ---- /dev/null -+++ b/sapi/cgi/fpm/init.d/php-fpm.in -@@ -0,0 +1,139 @@ -+#! /bin/sh -+ -+php_fpm_BIN=@prefix@/bin/php-cgi -+php_fpm_CONF=@php_fpm_conf_path@ -+php_fpm_PID=@php_fpm_pid_path@ -+ -+ -+php_opts="--fpm-config $php_fpm_CONF" -+ -+ -+wait_for_pid () { -+ try=0 -+ -+ while test $try -lt 35 ; do -+ -+ case "$1" in -+ 'created') -+ if [ -f "$2" ] ; then -+ try='' -+ break -+ fi -+ ;; -+ -+ 'removed') -+ if [ ! -f "$2" ] ; then -+ try='' -+ break -+ fi -+ ;; -+ esac -+ -+ echo -n . -+ try=`expr $try + 1` -+ sleep 1 -+ -+ done -+ -+} -+ -+case "$1" in -+ start) -+ echo -n "Starting php_fpm " -+ -+ $php_fpm_BIN --fpm $php_opts -+ -+ if [ "$?" != 0 ] ; then -+ echo " failed" -+ exit 1 -+ fi -+ -+ wait_for_pid created $php_fpm_PID -+ -+ if [ -n "$try" ] ; then -+ echo " failed" -+ exit 1 -+ else -+ echo " done" -+ fi -+ ;; -+ -+ stop) -+ echo -n "Shutting down php_fpm " -+ -+ if [ ! -r $php_fpm_PID ] ; then -+ echo "warning, no pid file found - php-fpm is not running ?" -+ exit 1 -+ fi -+ -+ kill -TERM `cat $php_fpm_PID` -+ -+ wait_for_pid removed $php_fpm_PID -+ -+ if [ -n "$try" ] ; then -+ echo " failed" -+ exit 1 -+ else -+ echo " done" -+ fi -+ ;; -+ -+ quit) -+ echo -n "Gracefully shutting down php_fpm " -+ -+ if [ ! -r $php_fpm_PID ] ; then -+ echo "warning, no pid file found - php-fpm is not running ?" -+ exit 1 -+ fi -+ -+ kill -QUIT `cat $php_fpm_PID` -+ -+ wait_for_pid removed $php_fpm_PID -+ -+ if [ -n "$try" ] ; then -+ echo " failed" -+ exit 1 -+ else -+ echo " done" -+ fi -+ ;; -+ -+ restart) -+ $0 stop -+ $0 start -+ ;; -+ -+ reload) -+ -+ echo -n "Reload service php-fpm " -+ -+ if [ ! -r $php_fpm_PID ] ; then -+ echo "warning, no pid file found - php-fpm is not running ?" -+ exit 1 -+ fi -+ -+ kill -USR2 `cat $php_fpm_PID` -+ -+ echo " done" -+ ;; -+ -+ logrotate) -+ -+ echo -n "Re-opening php-fpm log file " -+ -+ if [ ! -r $php_fpm_PID ] ; then -+ echo "warning, no pid file found - php-fpm is not running ?" -+ exit 1 -+ fi -+ -+ kill -USR1 `cat $php_fpm_PID` -+ -+ echo " done" -+ ;; -+ -+ *) -+ echo "Usage: $0 {start|stop|quit|restart|reload|logrotate}" -+ exit 1 -+ ;; -+ -+esac -diff --git a/sapi/cgi/fpm/xml_config.c b/sapi/cgi/fpm/xml_config.c -new file mode 100644 -index 0000000..10eb77e ---- /dev/null -+++ b/sapi/cgi/fpm/xml_config.c -@@ -0,0 +1,278 @@ -+ -+ /* $Id: xml_config.c,v 1.9 2008/08/26 15:09:15 anight Exp $ */ -+ /* (c) 2004-2007 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#ifdef HAVE_ALLOCA_H -+#include -+#endif -+#include -+#include -+#include -+#include -+ -+#include -+#include -+ -+#include "xml_config.h" -+ -+static struct xml_conf_section **xml_conf_sections = 0; -+static int xml_conf_sections_allocated = 0; -+static int xml_conf_sections_used = 0; -+ -+char *xml_conf_set_slot_boolean(void **conf, char *name, void *vv, intptr_t offset) -+{ -+ char *value = vv; -+ long value_y = !strcasecmp(value, "yes") || !strcmp(value, "1") || !strcasecmp(value, "on"); -+ long value_n = !strcasecmp(value, "no") || !strcmp(value, "0") || !strcasecmp(value, "off"); -+ -+ if (!value_y && !value_n) { -+ return "xml_conf_set_slot(): invalid boolean value"; -+ } -+ -+#ifdef XML_CONF_DEBUG -+ fprintf(stderr, "setting boolean '%s' => %s\n", name, value_y ? "TRUE" : "FALSE"); -+#endif -+ -+ * (int *) ((char *) *conf + offset) = value_y ? 1 : 0; -+ -+ return NULL; -+} -+ -+char *xml_conf_set_slot_string(void **conf, char *name, void *vv, intptr_t offset) -+{ -+ char *value = vv; -+ char *v = strdup(value); -+ -+ if (!v) return "xml_conf_set_slot_string(): strdup() failed"; -+ -+#ifdef XML_CONF_DEBUG -+ fprintf(stderr, "setting string '%s' => '%s'\n", name, v); -+#endif -+ -+ * (char **) ((char *) *conf + offset) = v; -+ -+ return NULL; -+} -+ -+char *xml_conf_set_slot_integer(void **conf, char *name, void *vv, intptr_t offset) -+{ -+ char *value = vv; -+ int v = atoi(value); -+ -+ * (int *) ((char *) *conf + offset) = v; -+ -+#ifdef XML_CONF_DEBUG -+ fprintf(stderr, "setting integer '%s' => %d\n", name, v); -+#endif -+ -+ return NULL; -+} -+ -+char *xml_conf_set_slot_time(void **conf, char *name, void *vv, intptr_t offset) -+{ -+ char *value = vv; -+ int len = strlen(value); -+ char suffix; -+ int seconds; -+ -+ if (!len) return "xml_conf_set_slot_timeval(): invalid timeval value"; -+ -+ suffix = value[len-1]; -+ -+ value[len-1] = '\0'; -+ -+ switch (suffix) { -+ case 's' : -+ seconds = atoi(value); -+ break; -+ case 'm' : -+ seconds = 60 * atoi(value); -+ break; -+ case 'h' : -+ seconds = 60 * 60 * atoi(value); -+ break; -+ case 'd' : -+ seconds = 24 * 60 * 60 * atoi(value); -+ break; -+ default : -+ return "xml_conf_set_slot_timeval(): unknown suffix used in timeval value"; -+ } -+ -+ * (int *) ((char *) *conf + offset) = seconds; -+ -+#ifdef XML_CONF_DEBUG -+ fprintf(stderr, "setting time '%s' => %d:%02d:%02d:%02d\n", name, expand_dhms(seconds)); -+#endif -+ -+ return NULL; -+} -+ -+char *xml_conf_parse_section(void **conf, struct xml_conf_section *section, void *xml_node) -+{ -+ xmlNode *element = xml_node; -+ char *ret = 0; -+ -+#ifdef XML_CONF_DEBUG -+ fprintf(stderr, "processing a section %s\n", section->path); -+#endif -+ -+ for ( ; element; element = element->next) { -+ if (element->type == XML_ELEMENT_NODE && !strcmp((const char *) element->name, "value") && element->children) { -+ xmlChar *name = xmlGetProp(element, (unsigned char *) "name"); -+ -+ if (name) { -+ int i; -+ -+#ifdef XML_CONF_DEBUG -+ fprintf(stderr, "found a value: %s\n", name); -+#endif -+ for (i = 0; section->parsers[i].parser; i++) { -+ if (!section->parsers[i].name || !strcmp(section->parsers[i].name, (char *) name)) { -+ break; -+ } -+ } -+ -+ if (section->parsers[i].parser) { -+ if (section->parsers[i].type == XML_CONF_SCALAR) { -+ if (element->children->type == XML_TEXT_NODE) { -+ ret = section->parsers[i].parser(conf, (char *) name, element->children->content, section->parsers[i].offset); -+ } -+ else { -+ ret = "XML_TEXT_NODE is expected, something different is given"; -+ } -+ } -+ else { -+ ret = section->parsers[i].parser(conf, (char *) name, element->children, section->parsers[i].offset); -+ } -+ -+ xmlFree(name); -+ if (ret) return ret; -+ else continue; -+ } -+ -+ fprintf(stderr, "Warning, unknown setting '%s' in section '%s'\n", (char *) name, section->path); -+ -+ xmlFree(name); -+ } -+ } -+ } -+ -+ return NULL; -+} -+ -+static char *xml_conf_parse_file(xmlNode *element) -+{ -+ char *ret = 0; -+ -+ for ( ; element; element = element->next) { -+ -+ if (element->parent && element->type == XML_ELEMENT_NODE && !strcmp((const char *) element->name, "section")) { -+ xmlChar *name = xmlGetProp(element, (unsigned char *) "name"); -+ -+ if (name) { -+ char *parent_name = (char *) xmlGetNodePath(element->parent); -+ char *full_name; -+ int i; -+ struct xml_conf_section *section = NULL; -+ -+#ifdef XML_CONF_DEBUG -+ fprintf(stderr, "got a section: %s/%s\n", parent_name, name); -+#endif -+ full_name = alloca(strlen(parent_name) + strlen((char *) name) + 1 + 1); -+ -+ sprintf(full_name, "%s/%s", parent_name, (char *) name); -+ -+ xmlFree(parent_name); -+ xmlFree(name); -+ -+ for (i = 0; i < xml_conf_sections_used; i++) { -+ if (!strcmp(xml_conf_sections[i]->path, full_name)) { -+ section = xml_conf_sections[i]; -+ } -+ } -+ -+ if (section) { /* found a registered section */ -+ void *conf = section->conf(); -+ ret = xml_conf_parse_section(&conf, section, element->children); -+ if (ret) break; -+ } -+ -+ } -+ } -+ -+ if (element->children) { -+ ret = xml_conf_parse_file(element->children); -+ if (ret) break; -+ } -+ } -+ -+ return ret; -+} -+ -+char *xml_conf_load_file(char *file) -+{ -+ char *ret = 0; -+ xmlDoc *doc; -+ -+ LIBXML_TEST_VERSION -+ -+ doc = xmlParseFile(file); -+ -+ if (doc) { -+ ret = xml_conf_parse_file(doc->children); -+ xmlFreeDoc(doc); -+ } -+ else { -+ ret = "failed to parse conf file"; -+ } -+ -+ xmlCleanupParser(); -+ return ret; -+} -+ -+int xml_conf_init() -+{ -+ return 0; -+} -+ -+void xml_conf_clean() -+{ -+ if (xml_conf_sections) { -+ free(xml_conf_sections); -+ } -+} -+ -+int xml_conf_section_register(struct xml_conf_section *section) -+{ -+ if (xml_conf_sections_allocated == xml_conf_sections_used) { -+ int new_size = xml_conf_sections_used + 10; -+ void *new_ptr = realloc(xml_conf_sections, sizeof(struct xml_conf_section *) * new_size); -+ -+ if (new_ptr) { -+ xml_conf_sections = new_ptr; -+ xml_conf_sections_allocated = new_size; -+ } -+ else { -+ fprintf(stderr, "xml_conf_section_register(): out of memory\n"); -+ return -1; -+ } -+ } -+ -+ xml_conf_sections[xml_conf_sections_used++] = section; -+ -+ return 0; -+} -+ -+int xml_conf_sections_register(struct xml_conf_section *sections[]) -+{ -+ for ( ; sections && *sections; sections++) { -+ if (0 > xml_conf_section_register(*sections)) { -+ return -1; -+ } -+ } -+ -+ return 0; -+} -+ -diff --git a/sapi/cgi/fpm/xml_config.h b/sapi/cgi/fpm/xml_config.h -new file mode 100644 -index 0000000..b6169cd ---- /dev/null -+++ b/sapi/cgi/fpm/xml_config.h -@@ -0,0 +1,43 @@ -+ -+ /* $Id: xml_config.h,v 1.3 2008/09/18 23:02:58 anight Exp $ */ -+ /* (c) 2004-2007 Andrei Nigmatulin */ -+ -+#ifndef XML_CONFIG_H -+#define XML_CONFIG_H 1 -+ -+#include -+ -+struct xml_value_parser; -+ -+struct xml_value_parser { -+ int type; -+ char *name; -+ char *(*parser)(void **, char *, void *, intptr_t offset); -+ intptr_t offset; -+}; -+ -+struct xml_conf_section { -+ void *(*conf)(); -+ char *path; -+ struct xml_value_parser *parsers; -+}; -+ -+char *xml_conf_set_slot_boolean(void **conf, char *name, void *value, intptr_t offset); -+char *xml_conf_set_slot_string(void **conf, char *name, void *value, intptr_t offset); -+char *xml_conf_set_slot_integer(void **conf, char *name, void *value, intptr_t offset); -+char *xml_conf_set_slot_time(void **conf, char *name, void *value, intptr_t offset); -+ -+int xml_conf_init(); -+void xml_conf_clean(); -+char *xml_conf_load_file(char *file); -+char *xml_conf_parse_section(void **conf, struct xml_conf_section *section, void *ve); -+int xml_conf_section_register(struct xml_conf_section *section); -+int xml_conf_sections_register(struct xml_conf_section *sections[]); -+ -+#define expand_hms(value) (value) / 3600, ((value) % 3600) / 60, (value) % 60 -+ -+#define expand_dhms(value) (value) / 86400, ((value) % 86400) / 3600, ((value) % 3600) / 60, (value) % 60 -+ -+enum { XML_CONF_SCALAR = 1, XML_CONF_SUBSECTION = 2 }; -+ -+#endif -diff --git a/sapi/cgi/fpm/zlog.c b/sapi/cgi/fpm/zlog.c -new file mode 100644 -index 0000000..2fb6c45 ---- /dev/null -+++ b/sapi/cgi/fpm/zlog.c -@@ -0,0 +1,113 @@ -+ -+ /* $Id: zlog.c,v 1.7 2008/05/22 21:08:32 anight Exp $ */ -+ /* (c) 2004-2007 Andrei Nigmatulin */ -+ -+#include "fpm_config.h" -+ -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+ -+#include "zlog.h" -+ -+#define MAX_LINE_LENGTH 1024 -+ -+static int zlog_fd = -1; -+static int zlog_level = ZLOG_NOTICE; -+ -+static const char *level_names[] = { -+ [ZLOG_DEBUG] = "DEBUG", -+ [ZLOG_NOTICE] = "NOTICE", -+ [ZLOG_WARNING] = "WARNING", -+ [ZLOG_ERROR] = "ERROR", -+ [ZLOG_ALERT] = "ALERT", -+}; -+ -+size_t zlog_print_time(struct timeval *tv, char *timebuf, size_t timebuf_len) -+{ -+ struct tm t; -+ size_t len; -+ -+ len = strftime(timebuf, timebuf_len, "%b %d %H:%M:%S", localtime_r((const time_t *) &tv->tv_sec, &t)); -+ len += snprintf(timebuf + len, timebuf_len - len, ".%06d", (int) tv->tv_usec); -+ -+ return len; -+} -+ -+int zlog_set_fd(int new_fd) -+{ -+ int old_fd = zlog_fd; -+ zlog_fd = new_fd; -+ -+ return old_fd; -+} -+ -+int zlog_set_level(int new_value) -+{ -+ int old_value = zlog_level; -+ -+ zlog_level = new_value; -+ -+ return old_value; -+} -+ -+void zlog(const char *function, int line, int flags, const char *fmt, ...) -+{ -+ struct timeval tv; -+ char buf[MAX_LINE_LENGTH]; -+ const size_t buf_size = MAX_LINE_LENGTH; -+ va_list args; -+ size_t len; -+ int truncated = 0; -+ int saved_errno; -+ -+ if ((flags & ZLOG_LEVEL_MASK) < zlog_level) { -+ return; -+ } -+ -+ saved_errno = errno; -+ -+ gettimeofday(&tv, 0); -+ -+ len = zlog_print_time(&tv, buf, buf_size); -+ -+ len += snprintf(buf + len, buf_size - len, " [%s] %s(), line %d: ", level_names[flags & ZLOG_LEVEL_MASK], function, line); -+ -+ if (len > buf_size - 1) { -+ truncated = 1; -+ } -+ -+ if (!truncated) { -+ va_start(args, fmt); -+ -+ len += vsnprintf(buf + len, buf_size - len, fmt, args); -+ -+ va_end(args); -+ -+ if (len >= buf_size) { -+ truncated = 1; -+ } -+ } -+ -+ if (!truncated) { -+ if (flags & ZLOG_HAVE_ERRNO) { -+ len += snprintf(buf + len, buf_size - len, ": %s (%d)", strerror(saved_errno), saved_errno); -+ if (len >= buf_size) { -+ truncated = 1; -+ } -+ } -+ } -+ -+ if (truncated) { -+ memcpy(buf + buf_size - sizeof("..."), "...", sizeof("...") - 1); -+ len = buf_size - 1; -+ } -+ -+ buf[len++] = '\n'; -+ -+ write(zlog_fd > -1 ? zlog_fd : STDERR_FILENO, buf, len); -+} -diff --git a/sapi/cgi/fpm/zlog.h b/sapi/cgi/fpm/zlog.h -new file mode 100644 -index 0000000..b5ac3d9 ---- /dev/null -+++ b/sapi/cgi/fpm/zlog.h -@@ -0,0 +1,34 @@ -+ -+ /* $Id: zlog.h,v 1.7 2008/05/22 21:08:32 anight Exp $ */ -+ /* (c) 2004-2007 Andrei Nigmatulin */ -+ -+#ifndef ZLOG_H -+#define ZLOG_H 1 -+ -+#define ZLOG_STUFF __func__, __LINE__ -+ -+struct timeval; -+ -+int zlog_set_fd(int new_fd); -+int zlog_set_level(int new_value); -+ -+size_t zlog_print_time(struct timeval *tv, char *timebuf, size_t timebuf_len); -+ -+void zlog(const char *function, int line, int flags, const char *fmt, ...) -+ __attribute__ ((format(printf,4,5))); -+ -+enum { -+ ZLOG_DEBUG = 1, -+ ZLOG_NOTICE = 2, -+ ZLOG_WARNING = 3, -+ ZLOG_ERROR = 4, -+ ZLOG_ALERT = 5, -+}; -+ -+#define ZLOG_LEVEL_MASK 7 -+ -+#define ZLOG_HAVE_ERRNO 0x100 -+ -+#define ZLOG_SYSERROR (ZLOG_ERROR | ZLOG_HAVE_ERRNO) -+ -+#endif diff --git a/Dockerfiles/data/php-5.1.6-libxml2.patch b/Dockerfiles/data/php-5.1.6-libxml2.patch deleted file mode 100644 index f70e0c7..0000000 --- a/Dockerfiles/data/php-5.1.6-libxml2.patch +++ /dev/null @@ -1,54 +0,0 @@ -diff --git a/ext/dom/documenttype.c b/ext/dom/documenttype.c -index 000c03b..b064c60 100644 ---- a/ext/dom/documenttype.c -+++ b/ext/dom/documenttype.c -@@ -215,7 +215,11 @@ int dom_documenttype_internal_subset_read(dom_object *obj, zval **retval TSRMLS_ - if (buff != NULL) { - xmlNodeDumpOutput (buff, NULL, (xmlNodePtr) intsubset, 0, 0, NULL); - xmlOutputBufferFlush(buff); -+#ifdef LIBXML2_NEW_BUFFER -+ ZVAL_STRINGL(*retval, xmlOutputBufferGetContent(buff), xmlOutputBufferGetSize(buff), 1); -+#else - ZVAL_STRINGL(*retval, buff->buffer->content, buff->buffer->use, 1); -+#endif - (void)xmlOutputBufferClose(buff); - return SUCCESS; - } -diff --git a/ext/dom/node.c b/ext/dom/node.c -index 0d2bc77..3234342 100644 ---- a/ext/dom/node.c -+++ b/ext/dom/node.c -@@ -1950,9 +1950,17 @@ static void dom_canonicalization(INTERNAL_FUNCTION_PARAMETERS, int mode) - RETVAL_FALSE; - } else { - if (mode == 0) { -+#ifdef LIBXML2_NEW_BUFFER -+ ret = xmlOutputBufferGetSize(buf); -+#else - ret = buf->buffer->use; -+#endif - if (ret > 0) { -+#ifdef LIBXML2_NEW_BUFFER -+ RETVAL_STRINGL((char *) xmlOutputBufferGetContent(buf), ret, 1); -+#else - RETVAL_STRINGL((char *) buf->buffer->content, ret, 1); -+#endif - } else { - RETVAL_EMPTY_STRING(); - } -diff --git a/ext/simplexml/simplexml.c b/ext/simplexml/simplexml.c -index 64a6514..203b52b 100644 ---- a/ext/simplexml/simplexml.c -+++ b/ext/simplexml/simplexml.c -@@ -1343,7 +1343,11 @@ SXE_METHOD(asXML) - - xmlNodeDumpOutput(outbuf, (xmlDocPtr) sxe->document->ptr, node, 0, 0, ((xmlDocPtr) sxe->document->ptr)->encoding); - xmlOutputBufferFlush(outbuf); -+#ifdef LIBXML2_NEW_BUFFER -+ RETVAL_STRINGL((char *)xmlOutputBufferGetContent(outbuf), xmlOutputBufferGetSize(outbuf), 1); -+#else - RETVAL_STRINGL((char *)outbuf->buffer->content, outbuf->buffer->use, 1); -+#endif - xmlOutputBufferClose(outbuf); - } - } else { diff --git a/Dockerfiles/data/php-5.1.6-openssl.patch b/Dockerfiles/data/php-5.1.6-openssl.patch deleted file mode 100644 index 4a9491f..0000000 --- a/Dockerfiles/data/php-5.1.6-openssl.patch +++ /dev/null @@ -1,48 +0,0 @@ -diff --git a/ext/openssl/xp_ssl.c b/ext/openssl/xp_ssl.c -index ce5ecb5..6e5190c 100644 ---- a/ext/openssl/xp_ssl.c -+++ b/ext/openssl/xp_ssl.c -@@ -333,9 +333,14 @@ static inline int php_openssl_setup_crypto(php_stream *stream, - method = SSLv23_client_method(); - break; - case STREAM_CRYPTO_METHOD_SSLv2_CLIENT: -+#ifdef OPENSSL_NO_SSL2 -+ php_error_docref(NULL TSRMLS_CC, E_WARNING, "SSLv2 support is not compiled into the OpenSSL library PHP is linked against"); -+ return -1; -+#else - sslsock->is_client = 1; - method = SSLv2_client_method(); - break; -+#endif - case STREAM_CRYPTO_METHOD_SSLv3_CLIENT: - sslsock->is_client = 1; - method = SSLv3_client_method(); -@@ -353,9 +358,14 @@ static inline int php_openssl_setup_crypto(php_stream *stream, - method = SSLv3_server_method(); - break; - case STREAM_CRYPTO_METHOD_SSLv2_SERVER: -+#ifdef OPENSSL_NO_SSL2 -+ php_error_docref(NULL TSRMLS_CC, E_WARNING, "SSLv2 support is not compiled into the OpenSSL library PHP is linked against"); -+ return -1; -+#else - sslsock->is_client = 0; - method = SSLv2_server_method(); - break; -+#endif - case STREAM_CRYPTO_METHOD_TLS_SERVER: - sslsock->is_client = 0; - method = TLSv1_server_method(); -@@ -814,8 +824,13 @@ php_stream *php_openssl_ssl_socket_factory(const char *proto, long protolen, - sslsock->enable_on_connect = 1; - sslsock->method = STREAM_CRYPTO_METHOD_SSLv23_CLIENT; - } else if (strncmp(proto, "sslv2", protolen) == 0) { -+#ifdef OPENSSL_NO_SSL2 -+ php_error_docref(NULL TSRMLS_CC, E_WARNING, "SSLv2 support is not compiled into the OpenSSL library PHP is linked against"); -+ return NULL; -+#else - sslsock->enable_on_connect = 1; - sslsock->method = STREAM_CRYPTO_METHOD_SSLv2_CLIENT; -+#endif - } else if (strncmp(proto, "sslv3", protolen) == 0) { - sslsock->enable_on_connect = 1; - sslsock->method = STREAM_CRYPTO_METHOD_SSLv3_CLIENT; diff --git a/Dockerfiles/data/php-5.2.17-curl.patch b/Dockerfiles/data/php/php-5.2.17-curl.patch similarity index 100% rename from Dockerfiles/data/php-5.2.17-curl.patch rename to Dockerfiles/data/php/php-5.2.17-curl.patch diff --git a/Dockerfiles/data/php-5.2.17-fpm.patch b/Dockerfiles/data/php/php-5.2.17-fpm.patch similarity index 100% rename from Dockerfiles/data/php-5.2.17-fpm.patch rename to Dockerfiles/data/php/php-5.2.17-fpm.patch diff --git a/Dockerfiles/data/php-5.2.17-libxml2.patch b/Dockerfiles/data/php/php-5.2.17-libxml2.patch similarity index 100% rename from Dockerfiles/data/php-5.2.17-libxml2.patch rename to Dockerfiles/data/php/php-5.2.17-libxml2.patch diff --git a/Dockerfiles/data/php-5.2.17-openssl.patch b/Dockerfiles/data/php/php-5.2.17-openssl.patch similarity index 100% rename from Dockerfiles/data/php-5.2.17-openssl.patch rename to Dockerfiles/data/php/php-5.2.17-openssl.patch diff --git a/Dockerfiles/data/php/php-5.2.17.tar.xz b/Dockerfiles/data/php/php-5.2.17.tar.xz new file mode 100644 index 0000000000000000000000000000000000000000..3ecbe2238e8c51beb1331f10ee05cfbee0ee7442 GIT binary patch literal 7450444 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%0D#} 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 IWei6O<>dzCZ7$m-VOpVoC74ARC2-2hm27! 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�OP-x^okDyS&R!htk)Aon4qCe;eld@uCIGD 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�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 )_D%6#!>m)s10yPKhuEofp*$K&O;K>AYo14#5$1 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 z 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