From 866e958c5dea5f985b26ba29c92a3c4af2bb51af Mon Sep 17 00:00:00 2001 From: Igor Sysoev Date: Wed, 16 Sep 2009 13:30:13 +0000 Subject: [PATCH] win32 ngx_file_info() utf8 support --- src/os/win32/ngx_files.c | 20 ++++++++++++++++---- 1 file changed, 16 insertions(+), 4 deletions(-) diff --git a/src/os/win32/ngx_files.c b/src/os/win32/ngx_files.c index d86b22be0..e4c42c79d 100644 --- a/src/os/win32/ngx_files.c +++ b/src/os/win32/ngx_files.c @@ -319,14 +319,26 @@ ngx_win32_rename_file(ngx_str_t *from, ngx_str_t *to, ngx_log_t *log) ngx_int_t ngx_file_info(u_char *file, ngx_file_info_t *sb) { - WIN32_FILE_ATTRIBUTE_DATA fa; + long rc; + u_short *u; + ngx_err_t err; + WIN32_FILE_ATTRIBUTE_DATA fa; + u_short utf16[NGX_UTF16_BUFLEN]; - /* NT4 and Win98 */ + u = ngx_utf8_to_utf16(utf16, file, NGX_UTF16_BUFLEN); - if (GetFileAttributesEx((char *) file, GetFileExInfoStandard, &fa) == 0) { + if (u == NULL) { return NGX_FILE_ERROR; } + rc = GetFileAttributesExW(u, GetFileExInfoStandard, &fa); + + if (u != utf16) { + err = ngx_errno; + ngx_free(u); + ngx_set_errno(err); + } + sb->dwFileAttributes = fa.dwFileAttributes; sb->ftCreationTime = fa.ftCreationTime; sb->ftLastAccessTime = fa.ftLastAccessTime; @@ -334,7 +346,7 @@ ngx_file_info(u_char *file, ngx_file_info_t *sb) sb->nFileSizeHigh = fa.nFileSizeHigh; sb->nFileSizeLow = fa.nFileSizeLow; - return ~NGX_FILE_ERROR; + return rc; }