Commit 2c9ed02e by Vicent Martí

Merge pull request #1859 from linquize/init.templatedir

Make init.templatedir work
parents 5a284edc 417472e3
......@@ -1132,44 +1132,39 @@ static int repo_init_structure(
/* Copy external template if requested */
if (external_tpl) {
git_config *cfg;
const char *tdir;
git_config *cfg = NULL;
const char *tdir = NULL;
bool default_template = false;
git_buf template_buf = GIT_BUF_INIT;
git_futils_find_template_dir(&template_buf);
if (opts->template_path)
tdir = opts->template_path;
else if ((error = git_config_open_default(&cfg)) < 0)
return error;
else {
else if ((error = git_config_open_default(&cfg)) >= 0) {
error = git_config_get_string(&tdir, cfg, "init.templatedir");
git_config_free(cfg);
if (error && error != GIT_ENOTFOUND)
return error;
giterr_clear();
tdir = template_buf.ptr;
}
if (!tdir) {
if ((error = git_futils_find_template_dir(&template_buf)) >= 0);
tdir = template_buf.ptr;
default_template = true;
}
error = git_futils_cp_r(tdir, repo_dir,
GIT_CPDIR_COPY_SYMLINKS | GIT_CPDIR_CHMOD_DIRS |
GIT_CPDIR_SIMPLE_TO_MODE, dmode);
git_buf_free(&template_buf);
git_config_free(cfg);
if (error < 0) {
if (strcmp(tdir, template_buf.ptr) != 0) {
git_buf_free(&template_buf);
if (!default_template)
return error;
}
/* if template was default, ignore error and use internal */
giterr_clear();
external_tpl = false;
error = 0;
}
git_buf_free(&template_buf);
}
/* Copy internal template
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment