diff options
author | Jakob Pfender <jpfender@elegosoft.com> | 2011-05-17 16:50:49 +0200 |
---|---|---|
committer | Vicent Marti <tanoku@gmail.com> | 2011-05-23 20:31:26 +0300 |
commit | 913691007eb113f1e1d50da19d19bb315736b601 (patch) | |
tree | ae34f6a798c5ace0f8cf5e120755858d4e308d5a /src/blob.c | |
parent | b0b527e0ad7b2b0d58e3d5039339d29892206f2d (diff) | |
download | libgit2-913691007eb113f1e1d50da19d19bb315736b601.tar.gz |
blob.c: Move to new error handling mechanism
Diffstat (limited to 'src/blob.c')
-rw-r--r-- | src/blob.c | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/src/blob.c b/src/blob.c index 987169358..0cc9b2a2d 100644 --- a/src/blob.c +++ b/src/blob.c @@ -69,6 +69,8 @@ int git_blob_create_frombuffer(git_oid *oid, git_repository *repo, const void *b error = stream->finalize_write(oid, stream); stream->free(stream); + if (error < GIT_SUCCESS) + return git__rethrow(error, "Failed to create blob"); return error; } @@ -86,16 +88,16 @@ int git_blob_create_fromfile(git_oid *oid, git_repository *repo, const char *pat git__joinpath(full_path, repo->path_workdir, path); if ((fd = gitfo_open(full_path, O_RDONLY)) < 0) - return GIT_ENOTFOUND; + return git__throw(GIT_ENOTFOUND, "Failed to create blob. Could not open %s", full_path); if ((size = gitfo_size(fd)) < 0 || !git__is_sizet(size)) { gitfo_close(fd); - return GIT_EOSERR; + return git__throw(GIT_EOSERR, "Failed to create blob. %s appears to be corrupted", full_path); } if ((error = git_odb_open_wstream(&stream, repo->db, (size_t)size, GIT_OBJ_BLOB)) < GIT_SUCCESS) { gitfo_close(fd); - return error; + return git__rethrow(error, "Failed to create blob"); } while (size > 0) { @@ -117,6 +119,8 @@ int git_blob_create_fromfile(git_oid *oid, git_repository *repo, const char *pat stream->free(stream); gitfo_close(fd); + if (error < GIT_SUCCESS) + return git__rethrow(error, "Failed to create blob"); return error; } |