mirror of
https://github.com/nginx/nginx.git
synced 2025-01-20 21:33:20 -06:00
compatibility with glibc 2.3, warn_unused_result attribute for write()
This commit is contained in:
parent
ead8091746
commit
f2884e194a
@ -191,6 +191,8 @@ static char **ngx_os_environ;
|
|||||||
int ngx_cdecl
|
int ngx_cdecl
|
||||||
main(int argc, char *const *argv)
|
main(int argc, char *const *argv)
|
||||||
{
|
{
|
||||||
|
char *p;
|
||||||
|
ssize_t n;
|
||||||
ngx_int_t i;
|
ngx_int_t i;
|
||||||
ngx_log_t *log;
|
ngx_log_t *log;
|
||||||
ngx_cycle_t *cycle, init_cycle;
|
ngx_cycle_t *cycle, init_cycle;
|
||||||
@ -240,23 +242,30 @@ main(int argc, char *const *argv)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (ngx_show_version) {
|
if (ngx_show_version) {
|
||||||
ngx_write_fd(ngx_stderr_fileno, "nginx version: " NGINX_VER CRLF,
|
|
||||||
sizeof("nginx version: " NGINX_VER CRLF) - 1);
|
p = "nginx version: " NGINX_VER CRLF;
|
||||||
|
n = sizeof("nginx version: " NGINX_VER CRLF) - 1;
|
||||||
|
|
||||||
|
if (ngx_write_fd(ngx_stderr_fileno, p, n) != n) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
if (ngx_show_configure) {
|
if (ngx_show_configure) {
|
||||||
#ifdef NGX_COMPILER
|
#ifdef NGX_COMPILER
|
||||||
ngx_write_fd(ngx_stderr_fileno, "built by " NGX_COMPILER CRLF,
|
p = "built by " NGX_COMPILER CRLF;
|
||||||
sizeof("built by " NGX_COMPILER CRLF) - 1);
|
n = sizeof("built by " NGX_COMPILER CRLF) - 1;
|
||||||
|
|
||||||
|
if (ngx_write_fd(ngx_stderr_fileno, p, n) != n) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef __WATCOMC__
|
p = "configure arguments: " NGX_CONFIGURE CRLF;
|
||||||
|
n = sizeof("configure arguments :" NGX_CONFIGURE CRLF) - 1;
|
||||||
|
|
||||||
/* OpenWatcomC could not build the long NGX_CONFIGURE string */
|
if (ngx_write_fd(ngx_stderr_fileno, p, n) != n) {
|
||||||
|
return 1;
|
||||||
ngx_write_fd(ngx_stderr_fileno,
|
}
|
||||||
"configure arguments: " NGX_CONFIGURE CRLF,
|
|
||||||
sizeof("configure arguments :" NGX_CONFIGURE CRLF) - 1);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!ngx_test_config) {
|
if (!ngx_test_config) {
|
||||||
|
@ -912,6 +912,7 @@ ngx_conf_open_file(ngx_cycle_t *cycle, ngx_str_t *name)
|
|||||||
static void
|
static void
|
||||||
ngx_conf_flush_files(ngx_cycle_t *cycle)
|
ngx_conf_flush_files(ngx_cycle_t *cycle)
|
||||||
{
|
{
|
||||||
|
ssize_t n, len;
|
||||||
ngx_uint_t i;
|
ngx_uint_t i;
|
||||||
ngx_list_part_t *part;
|
ngx_list_part_t *part;
|
||||||
ngx_open_file_t *file;
|
ngx_open_file_t *file;
|
||||||
@ -932,11 +933,24 @@ ngx_conf_flush_files(ngx_cycle_t *cycle)
|
|||||||
i = 0;
|
i = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (file[i].buffer == NULL || file[i].pos - file[i].buffer == 0) {
|
len = file[i].pos - file[i].buffer;
|
||||||
|
|
||||||
|
if (file[i].buffer == NULL || len == 0) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_write_fd(file[i].fd, file[i].buffer, file[i].pos - file[i].buffer);
|
n = ngx_write_fd(file[i].fd, file[i].buffer, len);
|
||||||
|
|
||||||
|
if (n == NGX_FILE_ERROR) {
|
||||||
|
ngx_log_error(NGX_LOG_ALERT, cycle->log, ngx_errno,
|
||||||
|
ngx_write_fd_n " to \"%s\" failed",
|
||||||
|
file[i].name.data);
|
||||||
|
|
||||||
|
} else if (n != len) {
|
||||||
|
ngx_log_error(NGX_LOG_ALERT, cycle->log, 0,
|
||||||
|
ngx_write_fd_n " to \"%s\" was incomplete: %z of %uz",
|
||||||
|
file[i].name.data, n, len);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -996,6 +996,7 @@ ngx_test_lockfile(u_char *file, ngx_log_t *log)
|
|||||||
void
|
void
|
||||||
ngx_reopen_files(ngx_cycle_t *cycle, ngx_uid_t user)
|
ngx_reopen_files(ngx_cycle_t *cycle, ngx_uid_t user)
|
||||||
{
|
{
|
||||||
|
ssize_t n, len;
|
||||||
ngx_fd_t fd;
|
ngx_fd_t fd;
|
||||||
ngx_uint_t i;
|
ngx_uint_t i;
|
||||||
ngx_list_part_t *part;
|
ngx_list_part_t *part;
|
||||||
@ -1019,9 +1020,23 @@ ngx_reopen_files(ngx_cycle_t *cycle, ngx_uid_t user)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (file[i].buffer && file[i].pos - file[i].buffer != 0) {
|
len = file[i].pos - file[i].buffer;
|
||||||
ngx_write_fd(file[i].fd, file[i].buffer,
|
|
||||||
file[i].pos - file[i].buffer);
|
if (file[i].buffer && len != 0) {
|
||||||
|
|
||||||
|
n = ngx_write_fd(file[i].fd, file[i].buffer, len);
|
||||||
|
|
||||||
|
if (n == NGX_FILE_ERROR) {
|
||||||
|
ngx_log_error(NGX_LOG_ALERT, cycle->log, ngx_errno,
|
||||||
|
ngx_write_fd_n " to \"%s\" failed",
|
||||||
|
file[i].name.data);
|
||||||
|
|
||||||
|
} else if (n != len) {
|
||||||
|
ngx_log_error(NGX_LOG_ALERT, cycle->log, 0,
|
||||||
|
ngx_write_fd_n " to \"%s\" was incomplete: %z of %uz",
|
||||||
|
file[i].name.data, n, len);
|
||||||
|
}
|
||||||
|
|
||||||
file[i].pos = file[i].buffer;
|
file[i].pos = file[i].buffer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -158,7 +158,7 @@ ngx_log_error_core(ngx_uint_t level, ngx_log_t *log, ngx_err_t err,
|
|||||||
|
|
||||||
ngx_linefeed(p);
|
ngx_linefeed(p);
|
||||||
|
|
||||||
ngx_write_fd(log->file->fd, errstr, p - errstr);
|
(void) ngx_write_fd(log->file->fd, errstr, p - errstr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -99,7 +99,17 @@ ssize_t ngx_write_chain_to_file(ngx_file_t *file, ngx_chain_t *ce,
|
|||||||
#define ngx_read_fd read
|
#define ngx_read_fd read
|
||||||
#define ngx_read_fd_n "read()"
|
#define ngx_read_fd_n "read()"
|
||||||
|
|
||||||
#define ngx_write_fd write
|
/*
|
||||||
|
* we use inlined function instead of simple #define
|
||||||
|
* because glibc 2.3 sets warn_unused_result attribute for write()
|
||||||
|
* and in this case gcc 4.3 ignores (void) cast
|
||||||
|
*/
|
||||||
|
static ngx_inline ssize_t
|
||||||
|
ngx_write_fd(ngx_fd_t fd, void *buf, size_t n)
|
||||||
|
{
|
||||||
|
return write(fd, buf, n);
|
||||||
|
}
|
||||||
|
|
||||||
#define ngx_write_fd_n "write()"
|
#define ngx_write_fd_n "write()"
|
||||||
|
|
||||||
#define ngx_linefeed(p) *p++ = LF;
|
#define ngx_linefeed(p) *p++ = LF;
|
||||||
|
Loading…
Reference in New Issue
Block a user