aboutsummaryrefslogtreecommitdiff
path: root/src/os/win32/ngx_files.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/os/win32/ngx_files.c')
-rw-r--r--src/os/win32/ngx_files.c123
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;
}
}