diff options
author | Jeff King <peff@peff.net> | 2008-07-28 02:02:04 -0400 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2008-08-01 22:41:07 -0700 |
commit | d65d2b2fb44a8bc0fc917aaca973ab7ad14d13b4 (patch) | |
tree | ba28d620693bbf0e0c545bbcd070d445b9df6ef8 /builtin-init-db.c | |
parent | 1e5f7add985dbccc0e811dbb6eff5047d8843118 (diff) | |
download | git-d65d2b2fb44a8bc0fc917aaca973ab7ad14d13b4.tar.gz |
init: handle empty "template" parameter
If a user passes "--template=", then our template parameter
is blank. Unfortunately, copy_templates() assumes it has at
least one character, and does all sorts of bad things like
reading from template[-1] and then proceeding to link all of
'/' into the .git directory.
This patch just checks for that condition in copy_templates
and aborts. As a side effect, this means that --template=
now has the meaning "don't copy any templates."
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'builtin-init-db.c')
-rw-r--r-- | builtin-init-db.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/builtin-init-db.c b/builtin-init-db.c index e23b8438c7..c68a3b1e74 100644 --- a/builtin-init-db.c +++ b/builtin-init-db.c @@ -127,6 +127,8 @@ static void copy_templates(const char *template_dir) template_dir = strbuf_detach(&d, NULL); } } + if (!template_dir[0]) + return; strcpy(template_path, template_dir); template_len = strlen(template_path); if (template_path[template_len-1] != '/') { |