diff options
author | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-04-12 03:02:00 +0200 |
---|---|---|
committer | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-04-12 03:02:00 +0200 |
commit | 3607c27f5fa144992c7962bb8817b950e033fe94 (patch) | |
tree | ac0272a74f3bf08bdc6c403dd624048521c89021 /update-cache.c | |
parent | Make the rev-tree output more regular. This is the last (diff) | |
download | git-3607c27f5fa144992c7962bb8817b950e033fe94.tar.xz git-3607c27f5fa144992c7962bb8817b950e033fe94.zip |
Allow zero-sized files to be checked in.
The kernel may not want it, but others probably do.
Noted (again) by Junio Hamano.
Diffstat (limited to 'update-cache.c')
-rw-r--r-- | update-cache.c | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/update-cache.c b/update-cache.c index 25db78908a..d08e895238 100644 --- a/update-cache.c +++ b/update-cache.c @@ -17,12 +17,16 @@ static int allow_add = 0, allow_remove = 0; static int index_fd(const char *path, int namelen, struct cache_entry *ce, int fd, struct stat *st) { z_stream stream; - int max_out_bytes = namelen + st->st_size + 200; + unsigned long size = st->st_size; + int max_out_bytes = namelen + size + 200; void *out = malloc(max_out_bytes); void *metadata = malloc(namelen + 200); - void *in = mmap(NULL, st->st_size, PROT_READ, MAP_PRIVATE, fd, 0); + void *in; SHA_CTX c; + in = ""; + if (size) + in = mmap(NULL, size, PROT_READ, MAP_PRIVATE, fd, 0); close(fd); if (!out || (int)(long)in == -1) return -1; @@ -34,7 +38,7 @@ static int index_fd(const char *path, int namelen, struct cache_entry *ce, int f * ASCII size + nul byte */ stream.next_in = metadata; - stream.avail_in = 1+sprintf(metadata, "blob %lu", (unsigned long) st->st_size); + stream.avail_in = 1+sprintf(metadata, "blob %lu", size); stream.next_out = out; stream.avail_out = max_out_bytes; while (deflate(&stream, 0) == Z_OK) @@ -44,7 +48,7 @@ static int index_fd(const char *path, int namelen, struct cache_entry *ce, int f * File content */ stream.next_in = in; - stream.avail_in = st->st_size; + stream.avail_in = size; while (deflate(&stream, Z_FINISH) == Z_OK) /*nothing */; |