# HG changeset patch # User Igor Sysoev # Date 1240931127 0 # Node ID 9d986c4e796f292415746a161ffcf99e4b09afb1 # Parent e4a4c889694f1cc2fbdab2da44b85e41cda14398 introduce ngx_write_console() to support OEM code pages diff --git a/src/core/ngx_log.c b/src/core/ngx_log.c --- a/src/core/ngx_log.c +++ b/src/core/ngx_log.c @@ -152,7 +152,7 @@ ngx_log_error_core(ngx_uint_t level, ngx (void) ngx_sprintf(msg, "[%V]: ", &err_levels[level]); - (void) ngx_write_fd(ngx_stderr, msg, p - msg); + (void) ngx_write_console(ngx_stderr, msg, p - msg); } @@ -224,7 +224,7 @@ ngx_log_stderr(ngx_err_t err, const char ngx_linefeed(p); - (void) ngx_write_fd(ngx_stderr, errstr, p - errstr); + (void) ngx_write_console(ngx_stderr, errstr, p - errstr); } diff --git a/src/os/unix/ngx_files.h b/src/os/unix/ngx_files.h --- a/src/os/unix/ngx_files.h +++ b/src/os/unix/ngx_files.h @@ -113,6 +113,10 @@ ngx_write_fd(ngx_fd_t fd, void *buf, siz #define ngx_write_fd_n "write()" + +#define ngx_write_console ngx_write_fd + + #define ngx_linefeed(p) *p++ = LF; #define NGX_LINEFEED_SIZE 1 diff --git a/src/os/win32/ngx_files.c b/src/os/win32/ngx_files.c --- a/src/os/win32/ngx_files.c +++ b/src/os/win32/ngx_files.c @@ -232,6 +232,21 @@ ngx_write_fd(ngx_fd_t fd, void *buf, siz } +ssize_t +ngx_write_console(ngx_fd_t fd, void *buf, size_t size) +{ + u_long n; + + (void) CharToOemBuff(buf, buf, size); + + if (WriteFile(fd, buf, size, &n, NULL) != 0) { + return (size_t) n; + } + + return -1; +} + + ngx_int_t ngx_win32_rename_file(ngx_str_t *from, ngx_str_t *to, ngx_log_t *log) { diff --git a/src/os/win32/ngx_files.h b/src/os/win32/ngx_files.h --- a/src/os/win32/ngx_files.h +++ b/src/os/win32/ngx_files.h @@ -98,6 +98,9 @@ ssize_t ngx_write_fd(ngx_fd_t fd, void * #define ngx_write_fd_n "WriteFile()" +ssize_t ngx_write_console(ngx_fd_t fd, void *buf, size_t size); + + #define ngx_linefeed(p) *p++ = CR; *p++ = LF; #define NGX_LINEFEED_SIZE 2