diff options
author | Igor Sysoev <igor@sysoev.ru> | 2003-11-14 07:20:34 +0000 |
---|---|---|
committer | Igor Sysoev <igor@sysoev.ru> | 2003-11-14 07:20:34 +0000 |
commit | 7f9d894e1069306f7361201a77efbe7b866024ff (patch) | |
tree | 9779ce5dd7d38af4c8039047768cedc92c31ec1f /src/os/win32/ngx_files.c | |
parent | 45890ea8c13a561fe3fd66bf639ad429f3c18846 (diff) | |
download | nginx-7f9d894e1069306f7361201a77efbe7b866024ff.tar.gz nginx-7f9d894e1069306f7361201a77efbe7b866024ff.zip |
nginx-0.0.1-2003-11-14-10:20:34 import
Diffstat (limited to 'src/os/win32/ngx_files.c')
-rw-r--r-- | src/os/win32/ngx_files.c | 123 |
1 files changed, 98 insertions, 25 deletions
diff --git a/src/os/win32/ngx_files.c b/src/os/win32/ngx_files.c index 139d141cb..35e83bfd6 100644 --- a/src/os/win32/ngx_files.c +++ b/src/os/win32/ngx_files.c @@ -6,13 +6,11 @@ ssize_t ngx_read_file(ngx_file_t *file, char *buf, size_t size, off_t offset) { size_t n; + long high_offset; + ngx_err_t err; OVERLAPPED ovlp, *povlp; -#if (WIN9X) - if (ngx_win32_version < NGX_WIN_NT) { - long high_offset; - ngx_err_t err; /* * in Win9X the overlapped pointer must be NULL @@ -47,8 +45,6 @@ ssize_t ngx_read_file(ngx_file_t *file, char *buf, size_t size, off_t offset) povlp = NULL; } else { - -#endif ovlp.Internal = 0; ovlp.InternalHigh = 0; ovlp.Offset = (DWORD) offset; @@ -56,10 +52,7 @@ ssize_t ngx_read_file(ngx_file_t *file, char *buf, size_t size, off_t offset) ovlp.hEvent = NULL; povlp = &ovlp; - -#if (WIN9X) } -#endif if (ReadFile(file->fd, buf, size, &n, povlp) == 0) { ngx_log_error(NGX_LOG_ERR, file->log, ngx_errno, "ReadFile() failed"); @@ -75,13 +68,11 @@ ssize_t ngx_read_file(ngx_file_t *file, char *buf, size_t size, off_t offset) ssize_t ngx_write_file(ngx_file_t *file, char *buf, size_t size, off_t offset) { size_t n; + long high_offset; + ngx_err_t err; OVERLAPPED ovlp, *povlp; -#if (WIN9X) - if (ngx_win32_version < NGX_WIN_NT) { - long high_offset; - ngx_err_t err; /* * in Win9X the overlapped pointer must be NULL @@ -116,9 +107,6 @@ ssize_t ngx_write_file(ngx_file_t *file, char *buf, size_t size, off_t offset) povlp = NULL; } else { - -#endif - ovlp.Internal = 0; ovlp.InternalHigh = 0; ovlp.Offset = (DWORD) offset; @@ -126,10 +114,7 @@ ssize_t ngx_write_file(ngx_file_t *file, char *buf, size_t size, off_t offset) ovlp.hEvent = NULL; povlp = &ovlp; - -#if (WIN9X) } -#endif if (WriteFile(file->fd, buf, size, &n, povlp) == 0) { ngx_log_error(NGX_LOG_ERR, file->log, ngx_errno, "WriteFile() failed"); @@ -142,15 +127,103 @@ ssize_t ngx_write_file(ngx_file_t *file, char *buf, size_t size, off_t offset) } -int ngx_file_append_mode(ngx_fd_t fd) +ssize_t ngx_write_chain_to_file(ngx_file_t *file, ngx_chain_t *cl, + off_t offset, ngx_pool_t *pool) { - ngx_err_t err; + char *buf, *prev; + size_t size; + ssize_t total, n; + + total = 0; + + while (cl) { + buf = cl->hunk->pos; + prev = buf; + size = 0; + + /* coalesce the neighbouring hunks */ + + while (cl && prev == cl->hunk->pos) { + size += cl->hunk->last - cl->hunk->pos; + prev = cl->hunk->last; + cl = cl->next; + } + + n = ngx_write_file(file, buf, size, offset); + + if (n == NGX_ERROR) { + return NGX_ERROR; + } + + total += n; + offset += n; + } + + return total; +} + + +int ngx_rename_file(ngx_str_t *from, ngx_str_t *to, ngx_pool_t *pool) +{ + int rc, collision; + u_int num; + char *name; + ngx_err_t err; + + name = ngx_palloc(pool, to->len + 1 + 10 + 1 + sizeof("DELETE")); + ngx_memcpy(name, to->data, to->len); + collision = 0; + + /* mutex_lock() (per cache or single ?) */ + + do { + num = ngx_next_temp_number(collision); + + ngx_snprintf(name + to->len, 1 + 10 + 1 + sizeof("DELETE"), + ".%010u.DELETE", num); + + if (MoveFile(to->data, name) == 0) { + err = ngx_errno; + if (err == NGX_ENOENT || err == NGX_ENOTDIR) { + return NGX_ERROR; + } + + collision = 1; + ngx_log_error(NGX_LOG_ERR, pool->log, ngx_errno, + "MoveFile() failed"); + } + + } while (collision); + + if (ngx_win32_version >= NGX_WIN_NT) { + if (DeleteFile(name) == 0) { + ngx_log_error(NGX_LOG_ERR, pool->log, ngx_errno, + "DeleteFile() failed"); + } + } + + if (MoveFile(from->data, to->data) == 0) { + rc = NGX_ERROR; + + } else { + rc = NGX_OK; + } + + if (rc == NGX_ERROR) { + ngx_log_error(NGX_LOG_ERR, pool->log, ngx_errno, "MoveFile() failed"); + } + + /* mutex_unlock() */ + + return rc; +} + + +int ngx_file_append_mode(ngx_fd_t fd) +{ if (SetFilePointer(fd, 0, NULL, FILE_END) == INVALID_SET_FILE_POINTER) { - err = ngx_errno; - if (err != NO_ERROR) { - ngx_log_error(NGX_LOG_ERR, file->log, err, - "SeekFilePointer() failed"); + if (ngx_errno != NO_ERROR) { return NGX_ERROR; } } |