Mercurial > hg > nginx-quic
view src/os/win32/ngx_errno.c @ 543:511a89da35ad release-0.2.0
nginx-0.2.0-RELEASE import
*) The pid-file names used during online upgrade was changed and now is
not required a manual rename operation. The old master process adds
the ".oldbin" suffix to its pid-file and executes a new binary file.
The new master process creates usual pid-file without the ".newbin"
suffix. If the master process exits, then old master process renames
back its pid-file with the ".oldbin" suffix to the pid-file without
suffix.
*) Change: the "worker_connections" directive, new name of the
"connections" directive; now the directive specifies maximum number
of connections, but not maximum socket descriptor number.
*) Feature: SSL supports the session cache inside one worker process.
*) Feature: the "satisfy_any" directive.
*) Change: the ngx_http_access_module and ngx_http_auth_basic_module do
not run for subrequests.
*) Feature: the "worker_rlimit_nofile" and "worker_rlimit_sigpending"
directives.
*) Bugfix: if all backend using in load-balancing failed after one
error, then nginx did not try do connect to them during 60 seconds.
*) Bugfix: in IMAP/POP3 command argument parsing.
Thanks to Rob Mueller.
*) Bugfix: errors while using SSL in IMAP/POP3 proxy.
*) Bugfix: errors while using SSI and gzipping.
*) Bugfix: the "Expires" and "Cache-Control" header lines were omitted
from the 304 responses.
Thanks to Alexandr Kukushkin.
author | Igor Sysoev <igor@sysoev.ru> |
---|---|
date | Fri, 23 Sep 2005 11:02:22 +0000 |
parents | 8e8f3af115b5 |
children | 3d8ab5957202 |
line wrap: on
line source
/* * Copyright (C) Igor Sysoev */ /* * TODO: * add WSA error messages for NT and 98 * test for English only messages */ #include <ngx_config.h> #include <ngx_core.h> static ngx_str_t wsa_errors[] = { ngx_string("An invalid argument was supplied"), /* WSAEINVAL 10022 */ ngx_string("Too many open sockets"), /* WSAEMFILE 10023 */ ngx_null_string, /* 10024 */ ngx_null_string, /* 10025 */ ngx_null_string, /* 10026 */ ngx_null_string, /* 10027 */ ngx_null_string, /* 10028 */ ngx_null_string, /* 10029 */ ngx_null_string, /* 10030 */ ngx_null_string, /* 10031 */ ngx_null_string, /* 10032 */ ngx_null_string, /* 10033 */ ngx_null_string, /* 10034 */ /* WSAEWOULDBLOCK 10035 */ ngx_string("A non-blocking socket operation could not be completed " "immediately"), ngx_null_string, /* 10036 */ ngx_null_string, /* 10037 */ /* WSAENOTSOCK 10038 */ ngx_string("An operation was attempted on something that is not a socket"), ngx_null_string, /* 10039 */ ngx_null_string, /* 10040 */ ngx_null_string, /* 10041 */ /* WSAENOPROTOOPT 10042 */ ngx_string("An unknown, invalid, or unsupported option or level was " "specified in a getsockopt or setsockopt call"), ngx_null_string, /* 10043 */ ngx_null_string, /* 10044 */ ngx_null_string, /* 10045 */ ngx_null_string, /* 10046 */ ngx_null_string, /* 10047 */ ngx_null_string, /* 10048 */ ngx_null_string, /* 10049 */ ngx_null_string, /* 10050 */ ngx_null_string, /* 10051 */ ngx_null_string, /* 10052 */ ngx_null_string, /* 10053 */ /* WSAECONNRESET 10054 */ ngx_string("An existing connection was forcibly closed by the remote host"), /* WSAENOBUFS 10055 */ ngx_string("An operation on a socket could not be performed because " "the system lacked sufficient buffer space or " "because a queue was full"), /* WSAEISCONN 10056 */ ngx_string("A connect request was made on an already connected socket"), /* WSAENOTCONN 10057 */ ngx_string("A request to send or receive data was disallowed because" "the socket is not connected and (when sending on a datagram " "socket using a sendto call) no address was supplied"), ngx_null_string, /* 10058 */ ngx_null_string, /* 10059 */ /* WSAETIMEDOUT 10060 */ ngx_string("A connection attempt failed because the connected party " "did not properly respond after a period of time, " "or established connection failed because connected host " "has failed to respond"), /* WSAECONNREFUSED 10061 */ ngx_string("No connection could be made because the target machine " "actively refused it") }; u_char *ngx_strerror_r(ngx_err_t err, u_char *errstr, size_t size) { int n; u_int len; ngx_err_t format_error; if (size == 0) { return errstr; } len = FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM |FORMAT_MESSAGE_IGNORE_INSERTS, NULL, err, MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), (char *) errstr, size, NULL); if (len == 0) { format_error = GetLastError(); if (format_error == ERROR_MR_MID_NOT_FOUND) { n = err - WSAEINVAL; if (n >= 0 && n <= WSAECONNREFUSED - WSAEINVAL) { len = wsa_errors[n].len; if (len) { if (len > size) { len = size; } ngx_memcpy(errstr, wsa_errors[n].data, len); return errstr + len; } } } return ngx_snprintf(errstr, size, "FormatMessage() error:(%d)", format_error); } /* remove ".\r\n\0" */ while (errstr[len] == '\0' || errstr[len] == CR || errstr[len] == LF || errstr[len] == '.') { --len; } return &errstr[++len]; }