diff options
| author | Vicent Martà <tanoku@gmail.com> | 2011-06-28 10:39:07 -0700 |
|---|---|---|
| committer | Vicent Martà <tanoku@gmail.com> | 2011-06-28 10:39:07 -0700 |
| commit | 2fb520f19ac5defe8ba023681f22ddcceaf0c8ce (patch) | |
| tree | 0c7ac1c59ae6f4c1b061cc9d3c705269a2981069 /src | |
| parent | d5afc0390c3ef919fcde23300d7aefdaeafa5daa (diff) | |
| parent | 7b608b3b96d468427b2fbf2cad63988ed67be704 (diff) | |
| download | libgit2-2fb520f19ac5defe8ba023681f22ddcceaf0c8ce.tar.gz | |
Merge pull request #277 from schu/sign-compare
Fix warning: signed and unsigned type in cond expr
Diffstat (limited to 'src')
| -rw-r--r-- | src/blob.c | 21 |
1 files changed, 5 insertions, 16 deletions
diff --git a/src/blob.c b/src/blob.c index d18aa5c36..2e3c7b3b2 100644 --- a/src/blob.c +++ b/src/blob.c @@ -99,20 +99,12 @@ int git_blob_create_fromfile(git_oid *oid, git_repository *repo, const char *pat } islnk = S_ISLNK(st.st_mode); + size = st.st_size; - - if (!islnk) { + if (!islnk) if ((fd = gitfo_open(full_path, O_RDONLY)) < 0) 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__throw(GIT_EOSERR, "Failed to create blob. '%s' appears to be corrupted", full_path); - } - } else { - size = st.st_size; - } - if ((error = git_odb_open_wstream(&stream, repo->db, (size_t)size, GIT_OBJ_BLOB)) < GIT_SUCCESS) { if (!islnk) gitfo_close(fd); @@ -123,9 +115,9 @@ int git_blob_create_fromfile(git_oid *oid, git_repository *repo, const char *pat ssize_t read_len; if (!islnk) - read_len = gitfo_read(fd, buffer, (size_t)(size < sizeof(buffer) ? size : sizeof(buffer))); + read_len = gitfo_read(fd, buffer, sizeof(buffer)); else - read_len = gitfo_readlink(full_path, buffer, (size_t)size); + read_len = gitfo_readlink(full_path, buffer, sizeof(buffer)); if (read_len < 0) { if (!islnk) @@ -143,9 +135,6 @@ int git_blob_create_fromfile(git_oid *oid, git_repository *repo, const char *pat if (!islnk) gitfo_close(fd); - if (error < GIT_SUCCESS) - return git__rethrow(error, "Failed to create blob"); - - return GIT_SUCCESS; + return error == GIT_SUCCESS ? GIT_SUCCESS : git__rethrow(error, "Failed to create blob"); } |
