summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorVicent Martí <vicent@github.com>2012-12-17 10:13:36 -0800
committerVicent Martí <vicent@github.com>2012-12-17 10:13:36 -0800
commit0d10e79dd9b4c5dee72066526a6a3c99e19c545b (patch)
tree649f1693dcb21b8733238fec2f4856aa56c8ebe5 /src
parentf79535092d86b531793640834bb010fa67dd4c3c (diff)
parenta3337f10bb604fce96e185088411feab53ab3d64 (diff)
downloadlibgit2-0d10e79dd9b4c5dee72066526a6a3c99e19c545b.tar.gz
Merge pull request #1149 from nulltoken/topic/blob_isbinary
Introduce git_blob_is_binary()
Diffstat (limited to 'src')
-rw-r--r--src/blob.c12
-rw-r--r--src/indexer.c6
-rw-r--r--src/win32/posix_w32.c1
3 files changed, 15 insertions, 4 deletions
diff --git a/src/blob.c b/src/blob.c
index b168df137..811bd850f 100644
--- a/src/blob.c
+++ b/src/blob.c
@@ -296,3 +296,15 @@ cleanup:
git__free(content);
return error;
}
+
+int git_blob_is_binary(git_blob *blob)
+{
+ git_buf content;
+
+ assert(blob);
+
+ content.ptr = blob->odb_object->raw.data;
+ content.size = min(blob->odb_object->raw.len, 4000);
+
+ return git_buf_text_is_binary(&content);
+}
diff --git a/src/indexer.c b/src/indexer.c
index 2fb780412..b9240f30b 100644
--- a/src/indexer.c
+++ b/src/indexer.c
@@ -201,7 +201,7 @@ static void hash_header(git_hash_ctx *ctx, git_off_t len, git_otype type)
char buffer[64];
size_t hdrlen;
- hdrlen = git_odb__format_object_header(buffer, sizeof(buffer), len, type);
+ hdrlen = git_odb__format_object_header(buffer, sizeof(buffer), (size_t)len, type);
git_hash_update(ctx, buffer, hdrlen);
}
@@ -269,11 +269,11 @@ static int crc_object(uint32_t *crc_out, git_mwindow_file *mwf, git_off_t start,
crc = crc32(0L, Z_NULL, 0);
while (size) {
- ptr = git_mwindow_open(mwf, &w, start, size, &left);
+ ptr = git_mwindow_open(mwf, &w, start, (size_t)size, &left);
if (ptr == NULL)
return -1;
- len = min(left, size);
+ len = min(left, (size_t)size);
crc = crc32(crc, ptr, len);
size -= len;
start += len;
diff --git a/src/win32/posix_w32.c b/src/win32/posix_w32.c
index 3a4398bbd..2ce92b9e5 100644
--- a/src/win32/posix_w32.c
+++ b/src/win32/posix_w32.c
@@ -59,7 +59,6 @@ static int do_lstat(
{
WIN32_FILE_ATTRIBUTE_DATA fdata;
wchar_t fbuf[GIT_WIN_PATH], lastch;
- DWORD last_error;
int flen;
flen = git__utf8_to_16(fbuf, GIT_WIN_PATH, file_name);