remove the artificial restriction tagsize < 8kb

Signed-off-by: Björn Engelmann <BjEngelmann@gmx.de>
Signed-off-by: Junio C Hamano <junkio@cox.net>
This commit is contained in:
Björn Engelmann 2006-05-23 20:19:04 +02:00 committed by Junio C Hamano
parent 405053d2d9
commit e7332f96b3
3 changed files with 46 additions and 20 deletions

View File

@ -154,6 +154,7 @@ extern int ce_match_stat(struct cache_entry *ce, struct stat *st, int);
extern int ce_modified(struct cache_entry *ce, struct stat *st, int); extern int ce_modified(struct cache_entry *ce, struct stat *st, int);
extern int ce_path_match(const struct cache_entry *ce, const char **pathspec); extern int ce_path_match(const struct cache_entry *ce, const char **pathspec);
extern int index_fd(unsigned char *sha1, int fd, struct stat *st, int write_object, const char *type); extern int index_fd(unsigned char *sha1, int fd, struct stat *st, int write_object, const char *type);
extern int read_pipe(int fd, char** return_buf, unsigned long* return_size);
extern int index_pipe(unsigned char *sha1, int fd, const char *type, int write_object); extern int index_pipe(unsigned char *sha1, int fd, const char *type, int write_object);
extern int index_path(unsigned char *sha1, const char *path, struct stat *st, int write_object); extern int index_path(unsigned char *sha1, const char *path, struct stat *st, int write_object);
extern void fill_stat_cache_info(struct cache_entry *ce, struct stat *st); extern void fill_stat_cache_info(struct cache_entry *ce, struct stat *st);

19
mktag.c
View File

@ -45,7 +45,7 @@ static int verify_tag(char *buffer, unsigned long size)
unsigned char sha1[20]; unsigned char sha1[20];
const char *object, *type_line, *tag_line, *tagger_line; const char *object, *type_line, *tag_line, *tagger_line;
if (size < 64 || size > MAXSIZE-1) if (size < 64)
return -1; return -1;
buffer[size] = 0; buffer[size] = 0;
@ -105,8 +105,8 @@ static int verify_tag(char *buffer, unsigned long size)
int main(int argc, char **argv) int main(int argc, char **argv)
{ {
unsigned long size; unsigned long size = 4096;
char buffer[MAXSIZE]; char *buffer = malloc(size);
unsigned char result_sha1[20]; unsigned char result_sha1[20];
if (argc != 1) if (argc != 1)
@ -114,13 +114,9 @@ int main(int argc, char **argv)
setup_git_directory(); setup_git_directory();
// Read the signature if (read_pipe(0, &buffer, &size)) {
size = 0; free(buffer);
for (;;) { die("could not read from stdin");
int ret = xread(0, buffer + size, MAXSIZE - size);
if (ret <= 0)
break;
size += ret;
} }
// Verify it for some basic sanity: it needs to start with "object <sha1>\ntype\ntagger " // Verify it for some basic sanity: it needs to start with "object <sha1>\ntype\ntagger "
@ -129,6 +125,9 @@ int main(int argc, char **argv)
if (write_sha1_file(buffer, size, tag_type, result_sha1) < 0) if (write_sha1_file(buffer, size, tag_type, result_sha1) < 0)
die("unable to write tag file"); die("unable to write tag file");
free(buffer);
printf("%s\n", sha1_to_hex(result_sha1)); printf("%s\n", sha1_to_hex(result_sha1));
return 0; return 0;
} }

View File

@ -1645,16 +1645,24 @@ int has_sha1_file(const unsigned char *sha1)
return find_sha1_file(sha1, &st) ? 1 : 0; return find_sha1_file(sha1, &st) ? 1 : 0;
} }
int index_pipe(unsigned char *sha1, int fd, const char *type, int write_object) /*
* reads from fd as long as possible into a supplied buffer of size bytes.
* If neccessary the buffer's size is increased using realloc()
*
* returns 0 if anything went fine and -1 otherwise
*
* NOTE: both buf and size may change, but even when -1 is returned
* you still have to free() it yourself.
*/
int read_pipe(int fd, char** return_buf, unsigned long* return_size)
{ {
unsigned long size = 4096; char* buf = *return_buf;
char *buf = malloc(size); unsigned long size = *return_size;
int iret, ret; int iret;
unsigned long off = 0; unsigned long off = 0;
unsigned char hdr[50];
int hdrlen;
do { do {
iret = read(fd, buf + off, size - off); iret = xread(fd, buf + off, size - off);
if (iret > 0) { if (iret > 0) {
off += iret; off += iret;
if (off == size) { if (off == size) {
@ -1663,16 +1671,34 @@ int index_pipe(unsigned char *sha1, int fd, const char *type, int write_object)
} }
} }
} while (iret > 0); } while (iret > 0);
if (iret < 0) {
*return_buf = buf;
*return_size = off;
if (iret < 0)
return -1;
return 0;
}
int index_pipe(unsigned char *sha1, int fd, const char *type, int write_object)
{
unsigned long size = 4096;
char *buf = malloc(size);
int ret;
unsigned char hdr[50];
int hdrlen;
if (read_pipe(fd, &buf, &size)) {
free(buf); free(buf);
return -1; return -1;
} }
if (!type) if (!type)
type = blob_type; type = blob_type;
if (write_object) if (write_object)
ret = write_sha1_file(buf, off, type, sha1); ret = write_sha1_file(buf, size, type, sha1);
else { else {
write_sha1_file_prepare(buf, off, type, sha1, hdr, &hdrlen); write_sha1_file_prepare(buf, size, type, sha1, hdr, &hdrlen);
ret = 0; ret = 0;
} }
free(buf); free(buf);