Commit 374db5f9 by Jakob Pfender Committed by Vicent Marti

filebuf.c: Move to new error handling mechanism

parent 68384a27
...@@ -36,7 +36,7 @@ static int lock_file(git_filebuf *file, int flags) ...@@ -36,7 +36,7 @@ static int lock_file(git_filebuf *file, int flags)
if (flags & GIT_FILEBUF_FORCE) if (flags & GIT_FILEBUF_FORCE)
gitfo_unlink(file->path_lock); gitfo_unlink(file->path_lock);
else else
return GIT_EOSERR; return git__throw(GIT_EOSERR, "Failed to lock file");
} }
/* create path to the file buffer is required */ /* create path to the file buffer is required */
...@@ -47,7 +47,7 @@ static int lock_file(git_filebuf *file, int flags) ...@@ -47,7 +47,7 @@ static int lock_file(git_filebuf *file, int flags)
} }
if (file->fd < 0) if (file->fd < 0)
return GIT_EOSERR; return git__throw(GIT_EOSERR, "Failed to create lock");
/* TODO: do a flock() in the descriptor file_lock */ /* TODO: do a flock() in the descriptor file_lock */
...@@ -58,7 +58,7 @@ static int lock_file(git_filebuf *file, int flags) ...@@ -58,7 +58,7 @@ static int lock_file(git_filebuf *file, int flags)
source = gitfo_open(file->path_original, O_RDONLY); source = gitfo_open(file->path_original, O_RDONLY);
if (source < 0) if (source < 0)
return GIT_EOSERR; return git__throw(GIT_EOSERR, "Failed to lock file. Could not open %s", file->path_original);
while ((read_bytes = gitfo_read(source, buffer, 2048)) > 0) { while ((read_bytes = gitfo_read(source, buffer, 2048)) > 0) {
gitfo_write(file->fd, buffer, read_bytes); gitfo_write(file->fd, buffer, read_bytes);
...@@ -133,7 +133,7 @@ static int write_deflate(git_filebuf *file, const void *source, size_t len) ...@@ -133,7 +133,7 @@ static int write_deflate(git_filebuf *file, const void *source, size_t len)
have = file->buf_size - zs->avail_out; have = file->buf_size - zs->avail_out;
if (gitfo_write(file->fd, file->z_buf, have) < GIT_SUCCESS) if (gitfo_write(file->fd, file->z_buf, have) < GIT_SUCCESS)
return GIT_EOSERR; return git__throw(GIT_EOSERR, "Failed to write to file");
} while (zs->avail_out == 0); } while (zs->avail_out == 0);
...@@ -245,7 +245,7 @@ int git_filebuf_open(git_filebuf *file, const char *path, int flags) ...@@ -245,7 +245,7 @@ int git_filebuf_open(git_filebuf *file, const char *path, int flags)
cleanup: cleanup:
git_filebuf_cleanup(file); git_filebuf_cleanup(file);
return error; return git__rethrow(error, "Failed to open file");
} }
int git_filebuf_hash(git_oid *oid, git_filebuf *file) int git_filebuf_hash(git_oid *oid, git_filebuf *file)
...@@ -253,10 +253,10 @@ int git_filebuf_hash(git_oid *oid, git_filebuf *file) ...@@ -253,10 +253,10 @@ int git_filebuf_hash(git_oid *oid, git_filebuf *file)
int error; int error;
if (file->digest == NULL) if (file->digest == NULL)
return GIT_ERROR; return git__throw(GIT_ERROR, "Failed to get hash for file. File has no digest");
if ((error = flush_buffer(file)) < GIT_SUCCESS) if ((error = flush_buffer(file)) < GIT_SUCCESS)
return error; return git__rethrow(error, "Failed to get hash for file");
git_hash_final(oid, file->digest); git_hash_final(oid, file->digest);
git_hash_free_ctx(file->digest); git_hash_free_ctx(file->digest);
...@@ -281,7 +281,7 @@ int git_filebuf_commit(git_filebuf *file) ...@@ -281,7 +281,7 @@ int git_filebuf_commit(git_filebuf *file)
/* tmp file cannot be commited */ /* tmp file cannot be commited */
if (file->path_original == NULL) if (file->path_original == NULL)
return GIT_EOSERR; return git__throw(GIT_EOSERR, "Failed to commit from buffer. File path does not exist");
file->flush_mode = Z_FINISH; file->flush_mode = Z_FINISH;
if ((error = flush_buffer(file)) < GIT_SUCCESS) if ((error = flush_buffer(file)) < GIT_SUCCESS)
...@@ -294,6 +294,8 @@ int git_filebuf_commit(git_filebuf *file) ...@@ -294,6 +294,8 @@ int git_filebuf_commit(git_filebuf *file)
cleanup: cleanup:
git_filebuf_cleanup(file); git_filebuf_cleanup(file);
if (error < GIT_SUCCESS)
return git__rethrow(error, "Failed to commit from buffer");
return error; return error;
} }
...@@ -322,7 +324,7 @@ int git_filebuf_write(git_filebuf *file, const void *buff, size_t len) ...@@ -322,7 +324,7 @@ int git_filebuf_write(git_filebuf *file, const void *buff, size_t len)
add_to_cache(file, buf, space_left); add_to_cache(file, buf, space_left);
if ((error = flush_buffer(file)) < GIT_SUCCESS) if ((error = flush_buffer(file)) < GIT_SUCCESS)
return error; return git__rethrow(error, "Failed to write to buffer");
len -= space_left; len -= space_left;
buf += space_left; buf += space_left;
...@@ -332,7 +334,7 @@ int git_filebuf_write(git_filebuf *file, const void *buff, size_t len) ...@@ -332,7 +334,7 @@ int git_filebuf_write(git_filebuf *file, const void *buff, size_t len)
if (len > file->buf_size) { if (len > file->buf_size) {
error = file->write(file, buf, len); error = file->write(file, buf, len);
if (error < GIT_SUCCESS) if (error < GIT_SUCCESS)
return error; return git__rethrow(error, "Failed to write to buffer");
} }
} }
} }
...@@ -349,7 +351,7 @@ int git_filebuf_reserve(git_filebuf *file, void **buffer, size_t len) ...@@ -349,7 +351,7 @@ int git_filebuf_reserve(git_filebuf *file, void **buffer, size_t len)
if (space_left <= len) { if (space_left <= len) {
if ((error = flush_buffer(file)) < GIT_SUCCESS) if ((error = flush_buffer(file)) < GIT_SUCCESS)
return error; return git__rethrow(error, "Failed to reserve buffer");
} }
*buffer = (file->buffer + file->buf_pos); *buffer = (file->buffer + file->buf_pos);
...@@ -370,7 +372,7 @@ int git_filebuf_printf(git_filebuf *file, const char *format, ...) ...@@ -370,7 +372,7 @@ int git_filebuf_printf(git_filebuf *file, const char *format, ...)
if (len < 0 || (size_t)len >= space_left) { if (len < 0 || (size_t)len >= space_left) {
if ((error = flush_buffer(file)) < GIT_SUCCESS) if ((error = flush_buffer(file)) < GIT_SUCCESS)
return error; return git__rethrow(error, "Failed to print to buffer");
len = vsnprintf((char *)file->buffer + file->buf_pos, space_left, format, arglist); len = vsnprintf((char *)file->buffer + file->buf_pos, space_left, format, arglist);
if (len < 0 || (size_t)len > file->buf_size) if (len < 0 || (size_t)len > file->buf_size)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment