mirror of
https://github.com/nginx/nginx.git
synced 2024-12-05 06:19:01 +08:00
0e5dc5cff6
*) Change: the "valid_referers" directive and the "$invalid_referer" variable were moved to the new ngx_http_referer_module from the ngx_http_rewrite_module. *) Change: the "$apache_bytes_sent" variable name was changed to "$body_bytes_sent". *) Feature: the "$sent_http_..." variables. *) Feature: the "if" directive supports the "=" and "!=" operations. *) Feature: the "proxy_pass" directive supports the HTTPS protocol. *) Feature: the "proxy_set_body" directive. *) Feature: the "post_action" directive. *) Feature: the ngx_http_empty_gif_module. *) Feature: the "worker_cpu_affinity" directive for Linux. *) Bugfix: the "rewrite" directive did not unescape URI part in redirect, now it is unescaped except the %00-%25 and %7F-%FF characters. *) Bugfix: nginx could not be built by the icc 9.0 compiler. *) Bugfix: if the SSI was enabled for zero size static file, then the chunked response was encoded incorrectly.
135 lines
3.0 KiB
Plaintext
135 lines
3.0 KiB
Plaintext
|
|
# Copyright (C) Igor Sysoev
|
|
|
|
|
|
NGX_USER=${NGX_USER:-nobody}
|
|
|
|
if [ -z "$NGX_GROUP" -a $NGX_USER = nobody ] ; then
|
|
if grep nobody /etc/group 2>&1 >/dev/null; then
|
|
echo "checking for nobody group ... found"
|
|
NGX_GROUP=nobody
|
|
else
|
|
echo "checking for nobody group ... not found"
|
|
|
|
if grep nogroup /etc/group 2>&1 >/dev/null; then
|
|
echo "checking for nogroup group ... found"
|
|
NGX_GROUP=nogroup
|
|
else
|
|
echo "checking for nogroup group ... not found"
|
|
NGX_GROUP=nobody
|
|
fi
|
|
fi
|
|
|
|
else
|
|
NGX_GROUP=$NGX_USER
|
|
fi
|
|
|
|
|
|
ngx_feature="poll()"
|
|
ngx_feature_name=
|
|
ngx_feature_run=no
|
|
ngx_feature_incs="#include <poll.h>"
|
|
ngx_feature_libs=
|
|
ngx_feature_test="int n, dp; struct pollfd pl;
|
|
dp = 0;
|
|
pl.fd = 0;
|
|
pl.events = 0;
|
|
pl.revents = 0;
|
|
n = poll(&pl, 1, 0)"
|
|
. auto/feature
|
|
|
|
if [ $ngx_found = no ]; then
|
|
EVENT_POLL=NONE
|
|
fi
|
|
|
|
|
|
ngx_feature="/dev/poll"
|
|
ngx_feature_name="NGX_HAVE_DEVPOLL"
|
|
ngx_feature_run=no
|
|
ngx_feature_incs="#include <sys/devpoll.h>"
|
|
ngx_feature_libs=
|
|
ngx_feature_test="int n, dp; struct dvpoll dvp;
|
|
dp = 0;
|
|
dvp.dp_fds = NULL;
|
|
dvp.dp_nfds = 0;
|
|
dvp.dp_timeout = 0;
|
|
n = ioctl(dp, DP_POLL, &dvp)"
|
|
. auto/feature
|
|
|
|
if [ $ngx_found = yes ]; then
|
|
CORE_SRCS="$CORE_SRCS $DEVPOLL_SRCS"
|
|
EVENT_MODULES="$EVENT_MODULES $DEVPOLL_MODULE"
|
|
EVENT_FOUND=YES
|
|
fi
|
|
|
|
|
|
if test -z "$NGX_KQUEUE_CHECKED"; then
|
|
ngx_feature="kqueue"
|
|
ngx_feature_name="NGX_HAVE_KQUEUE"
|
|
ngx_feature_run=no
|
|
ngx_feature_incs="#include <sys/event.h>"
|
|
ngx_feature_libs=
|
|
ngx_feature_test="int kq; kq = kqueue()"
|
|
. auto/feature
|
|
|
|
if [ $ngx_found = yes ]; then
|
|
|
|
have=NGX_HAVE_CLEAR_EVENT . auto/have
|
|
EVENT_MODULES="$EVENT_MODULES $KQUEUE_MODULE"
|
|
CORE_SRCS="$CORE_SRCS $KQUEUE_SRCS"
|
|
EVENT_FOUND=YES
|
|
|
|
ngx_feature="kqueue's NOTE_LOWAT"
|
|
ngx_feature_name="NGX_HAVE_LOWAT_EVENT"
|
|
ngx_feature_run=no
|
|
ngx_feature_incs="#include <sys/event.h>"
|
|
ngx_feature_libs=
|
|
ngx_feature_test="struct kevent kev;
|
|
kev.fflags = NOTE_LOWAT;"
|
|
. auto/feature
|
|
fi
|
|
fi
|
|
|
|
if [ "$NGX_SYSTEM" = "NetBSD" ]; then
|
|
|
|
have=NGX_HAVE_TIMER_EVENT . auto/have
|
|
echo " + kqueue's EVFILT_TIMER found"
|
|
|
|
# NetBSD 2.0 incompatibly defines kevent.udata as "intptr_t"
|
|
|
|
cat << END >> $NGX_AUTO_CONFIG_H
|
|
|
|
#define NGX_KQUEUE_UDATA_T
|
|
|
|
END
|
|
|
|
else
|
|
cat << END >> $NGX_AUTO_CONFIG_H
|
|
|
|
#define NGX_KQUEUE_UDATA_T (void *)
|
|
|
|
END
|
|
|
|
fi
|
|
|
|
|
|
ngx_feature="crypt()"
|
|
ngx_feature_name=
|
|
ngx_feature_run=no
|
|
ngx_feature_incs=
|
|
ngx_feature_libs=
|
|
ngx_feature_test="crypt(\"test\", \"salt\");"
|
|
. auto/feature
|
|
|
|
|
|
if [ $ngx_found = no ]; then
|
|
|
|
ngx_feature="crypt() in libcrypt"
|
|
ngx_feature_libs=-lcrypt
|
|
. auto/feature
|
|
|
|
if [ $ngx_found = yes ]; then
|
|
CRYPT_LIB="-lcrypt"
|
|
fi
|
|
fi
|