diff options
| author | Junio C Hamano <junkio@cox.net> | 2006-07-30 23:42:10 -0700 | 
|---|---|---|
| committer | Junio C Hamano <junkio@cox.net> | 2006-07-30 23:42:10 -0700 | 
| commit | c1a788aceecb0a8e95d6442938ade9ca43df033e (patch) | |
| tree | 30d99ae60a57281f75586d64f9853429fa3d26e7 /builtin-tar-tree.c | |
| parent | f59aac47f3839367d0da04019b0fc2bd61345225 (diff) | |
| parent | 076b0adcf9dac7bd9d18624087f679cc811aeb77 (diff) | |
| download | git-c1a788aceecb0a8e95d6442938ade9ca43df033e.tar.gz | |
Merge branch 'js/read-tree' into js/c-merge-recursive
* js/read-tree: (107 commits)
  read-tree: move merge functions to the library
  read-trees: refactor the unpack_trees() part
  tar-tree: illustrate an obscure feature better
  git.c: allow alias expansion without a git directory
  setup_git_directory_gently: do not barf when GIT_DIR is given.
  Build on Debian GNU/kFreeBSD
  Call setup_git_directory() much earlier
  Call setup_git_directory() early
  Display an error from update-ref if target ref name is invalid.
  Fix http-fetch
  t4103: fix binary patch application test.
  git-apply -R: binary patches are irreversible for now.
  Teach git-apply about '-R'
  Makefile: ssh-pull.o depends on ssh-fetch.c
  log and diff family: honor config even from subdirectories
  git-reset: detect update-ref error and report it.
  lost-found: use fsck-objects --full
  Teach git-http-fetch the --stdin switch
  Teach git-local-fetch the --stdin switch
  Make pull() support fetching multiple targets at once
  ...
Diffstat (limited to 'builtin-tar-tree.c')
| -rw-r--r-- | builtin-tar-tree.c | 30 | 
1 files changed, 22 insertions, 8 deletions
| diff --git a/builtin-tar-tree.c b/builtin-tar-tree.c index f2e48aae2a..7c48db9ec8 100644 --- a/builtin-tar-tree.c +++ b/builtin-tar-tree.c @@ -20,6 +20,7 @@ static char block[BLOCKSIZE];  static unsigned long offset;  static time_t archive_time; +static int tar_umask;  /* tries hard to write, either succeeds or dies in the attempt */  static void reliable_write(const void *data, unsigned long size) @@ -188,13 +189,13 @@ static void write_entry(const unsigned char *sha1, struct strbuf *path,  	} else {  		if (S_ISDIR(mode)) {  			*header.typeflag = TYPEFLAG_DIR; -			mode |= 0777; +			mode = (mode | 0777) & ~tar_umask;  		} else if (S_ISLNK(mode)) {  			*header.typeflag = TYPEFLAG_LNK;  			mode |= 0777;  		} else if (S_ISREG(mode)) {  			*header.typeflag = TYPEFLAG_REG; -			mode |= (mode & 0100) ? 0777 : 0666; +			mode = (mode | ((mode & 0100) ? 0777 : 0666)) & ~tar_umask;  		} else {  			error("unsupported file mode: 0%o (SHA1: %s)",  			      mode, sha1_to_hex(sha1)); @@ -293,7 +294,21 @@ static void traverse_tree(struct tree_desc *tree, struct strbuf *path)  	}  } -static int generate_tar(int argc, const char **argv, char** envp) +int git_tar_config(const char *var, const char *value) +{ +	if (!strcmp(var, "tar.umask")) { +		if (!strcmp(value, "user")) { +			tar_umask = umask(0); +			umask(tar_umask); +		} else { +			tar_umask = git_config_int(var, value); +		} +		return 0; +	} +	return git_default_config(var, value); +} + +static int generate_tar(int argc, const char **argv, const char *prefix)  {  	unsigned char sha1[20], tree_sha1[20];  	struct commit *commit; @@ -304,8 +319,7 @@ static int generate_tar(int argc, const char **argv, char** envp)  	current_path.alloc = PATH_MAX;  	current_path.len = current_path.eof = 0; -	setup_git_directory(); -	git_config(git_default_config); +	git_config(git_tar_config);  	switch (argc) {  	case 3: @@ -387,19 +401,19 @@ static int remote_tar(int argc, const char **argv)  	return !!ret;  } -int cmd_tar_tree(int argc, const char **argv, char **envp) +int cmd_tar_tree(int argc, const char **argv, const char *prefix)  {  	if (argc < 2)  		usage(tar_tree_usage);  	if (!strncmp("--remote=", argv[1], 9))  		return remote_tar(argc, argv); -	return generate_tar(argc, argv, envp); +	return generate_tar(argc, argv, prefix);  }  /* ustar header + extended global header content */  #define HEADERSIZE (2 * RECORDSIZE) -int cmd_get_tar_commit_id(int argc, const char **argv, char **envp) +int cmd_get_tar_commit_id(int argc, const char **argv, const char *prefix)  {  	char buffer[HEADERSIZE];  	struct ustar_header *header = (struct ustar_header *)buffer; | 
