projects
/
git.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
git-daemon --base-path
[git.git]
/
tar-tree.c
diff --git
a/tar-tree.c
b/tar-tree.c
index
2716ae3
..
96bd143
100644
(file)
--- a/
tar-tree.c
+++ b/
tar-tree.c
@@
-34,10
+34,8
@@
struct path_prefix {
static void reliable_write(void *buf, unsigned long size)
{
while (size > 0) {
static void reliable_write(void *buf, unsigned long size)
{
while (size > 0) {
- long ret = write(1, buf, size);
+ long ret =
x
write(1, buf, size);
if (ret < 0) {
if (ret < 0) {
- if (errno == EAGAIN)
- continue;
if (errno == EPIPE)
exit(0);
die("git-tar-tree: %s", strerror(errno));
if (errno == EPIPE)
exit(0);
die("git-tar-tree: %s", strerror(errno));
@@
-353,6
+351,8
@@
static void traverse_tree(void *buffer, unsigned long size,
if (size < namelen + 20 || sscanf(buffer, "%o", &mode) != 1)
die("corrupt 'tree' file");
if (size < namelen + 20 || sscanf(buffer, "%o", &mode) != 1)
die("corrupt 'tree' file");
+ if (S_ISDIR(mode) || S_ISREG(mode))
+ mode |= (mode & 0100) ? 0777 : 0666;
buffer = sha1 + 20;
size -= namelen + 20;
buffer = sha1 + 20;
size -= namelen + 20;
@@
-405,6
+405,8
@@
int main(int argc, char **argv)
void *buffer;
unsigned long size;
void *buffer;
unsigned long size;
+ setup_git_directory();
+
switch (argc) {
case 3:
basedir = argv[2];
switch (argc) {
case 3:
basedir = argv[2];