diff options
Diffstat (limited to 'builtin/init-db.c')
| -rw-r--r-- | builtin/init-db.c | 17 | 
1 files changed, 12 insertions, 5 deletions
| diff --git a/builtin/init-db.c b/builtin/init-db.c index aab44d2e45..9966522b4a 100644 --- a/builtin/init-db.c +++ b/builtin/init-db.c @@ -119,15 +119,18 @@ static void copy_templates(const char *template_dir)  	DIR *dir;  	const char *git_dir = get_git_dir();  	int len = strlen(git_dir); +	char *to_free = NULL;  	if (!template_dir)  		template_dir = getenv(TEMPLATE_DIR_ENVIRONMENT);  	if (!template_dir)  		template_dir = init_db_template_dir;  	if (!template_dir) -		template_dir = system_path(DEFAULT_GIT_TEMPLATE_DIR); -	if (!template_dir[0]) +		template_dir = to_free = system_path(DEFAULT_GIT_TEMPLATE_DIR); +	if (!template_dir[0]) { +		free(to_free);  		return; +	}  	template_len = strlen(template_dir);  	if (PATH_MAX <= (template_len+strlen("/config")))  		die(_("insanely long template path %s"), template_dir); @@ -139,7 +142,7 @@ static void copy_templates(const char *template_dir)  	dir = opendir(template_path);  	if (!dir) {  		warning(_("templates not found %s"), template_dir); -		return; +		goto free_return;  	}  	/* Make sure that template is from the correct vintage */ @@ -155,8 +158,7 @@ static void copy_templates(const char *template_dir)  			"a wrong format version %d from '%s'"),  			repository_format_version,  			template_dir); -		closedir(dir); -		return; +		goto close_free_return;  	}  	memcpy(path, git_dir, len); @@ -166,7 +168,10 @@ static void copy_templates(const char *template_dir)  	copy_templates_1(path, len,  			 template_path, template_len,  			 dir); +close_free_return:  	closedir(dir); +free_return: +	free(to_free);  }  static int git_init_db_config(const char *k, const char *v, void *cb) @@ -256,6 +261,8 @@ static int create_default_files(const char *template_path)  				!lstat(path, &st2) &&  				st1.st_mode != st2.st_mode &&  				!chmod(path, st1.st_mode)); +		if (filemode && !reinit && (st1.st_mode & S_IXUSR)) +			filemode = 0;  	}  	git_config_set("core.filemode", filemode ? "true" : "false"); | 
