projects
/
git.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge branch 'master' of .
[git.git]
/
tar-tree.c
diff --git
a/tar-tree.c
b/tar-tree.c
index
c2eb21c
..
2716ae3
100644
(file)
--- a/
tar-tree.c
+++ b/
tar-tree.c
@@
-17,7
+17,7
@@
#define EXT_HEADER_PATH 1
#define EXT_HEADER_LINKPATH 2
#define EXT_HEADER_PATH 1
#define EXT_HEADER_LINKPATH 2
-static const char
*tar_tree_usage
= "git-tar-tree <key> [basedir]";
+static const char
tar_tree_usage[]
= "git-tar-tree <key> [basedir]";
static char block[BLOCKSIZE];
static unsigned long offset;
static char block[BLOCKSIZE];
static unsigned long offset;
@@
-77,7
+77,7
@@
static void write_trailer(void)
write_if_needed();
get_record();
write_if_needed();
write_if_needed();
get_record();
write_if_needed();
-
if
(offset) {
+
while
(offset) {
get_record();
write_if_needed();
}
get_record();
write_if_needed();
}
@@
-325,8
+325,8
@@
static void write_header(const unsigned char *sha1, char typeflag, const char *b
memcpy(&header[257], "ustar", 6);
memcpy(&header[263], "00", 2);
memcpy(&header[257], "ustar", 6);
memcpy(&header[263], "00", 2);
-
printf(&header[329], "%07o", 0);
/* devmajor */
-
printf(&header[337], "%07o", 0);
/* devminor */
+
sprintf(&header[329], "%07o", 0);
/* devmajor */
+
sprintf(&header[337], "%07o", 0);
/* devminor */
memset(&header[148], ' ', 8);
for (i = 0; i < RECORDSIZE; i++)
memset(&header[148], ' ', 8);
for (i = 0; i < RECORDSIZE; i++)
@@
-430,8
+430,8
@@
int main(int argc, char **argv)
if (!archive_time)
archive_time = time(NULL);
if (basedir)
if (!archive_time)
archive_time = time(NULL);
if (basedir)
- write_header(
"0", TYPEFLAG_DIR, NULL, NULL, basedir, 040755
,
-
NULL, 0);
+ write_header(
(unsigned char *)"0", TYPEFLAG_DIR, NULL, NULL
,
+
basedir, 040755,
NULL, 0);
traverse_tree(buffer, size, NULL);
free(buffer);
write_trailer();
traverse_tree(buffer, size, NULL);
free(buffer);
write_trailer();