fix reflog entries for "git-branch"
Even when -l is not given from the command line, the repository may have the configuration variable core.logallrefupdates set, or an old-timer might have done ": >.git/logs/refs/heads/new" before running "git branch new". In these cases, the code gave an uninitialized msg[] from the stack to be written out as the reflog message. This also passes a different message when '-f' option is used. Saying "git branch -f branch some-commit" is a moral equilvalent of doing "git-reset some-commit" while on the branch. Signed-off-by: Junio C Hamano <junkio@cox.net>
This commit is contained in:
parent
505739f6c0
commit
5f856dd47d
@ -316,6 +316,7 @@ static void create_branch(const char *name, const char *start_name,
|
|||||||
struct commit *commit;
|
struct commit *commit;
|
||||||
unsigned char sha1[20];
|
unsigned char sha1[20];
|
||||||
char ref[PATH_MAX], msg[PATH_MAX + 20];
|
char ref[PATH_MAX], msg[PATH_MAX + 20];
|
||||||
|
int forcing = 0;
|
||||||
|
|
||||||
snprintf(ref, sizeof ref, "refs/heads/%s", name);
|
snprintf(ref, sizeof ref, "refs/heads/%s", name);
|
||||||
if (check_ref_format(ref))
|
if (check_ref_format(ref))
|
||||||
@ -326,6 +327,7 @@ static void create_branch(const char *name, const char *start_name,
|
|||||||
die("A branch named '%s' already exists.", name);
|
die("A branch named '%s' already exists.", name);
|
||||||
else if (!is_bare_repository() && !strcmp(head, name))
|
else if (!is_bare_repository() && !strcmp(head, name))
|
||||||
die("Cannot force update the current branch.");
|
die("Cannot force update the current branch.");
|
||||||
|
forcing = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (start_sha1)
|
if (start_sha1)
|
||||||
@ -342,11 +344,15 @@ static void create_branch(const char *name, const char *start_name,
|
|||||||
if (!lock)
|
if (!lock)
|
||||||
die("Failed to lock ref for update: %s.", strerror(errno));
|
die("Failed to lock ref for update: %s.", strerror(errno));
|
||||||
|
|
||||||
if (reflog) {
|
if (reflog)
|
||||||
log_all_ref_updates = 1;
|
log_all_ref_updates = 1;
|
||||||
|
|
||||||
|
if (forcing)
|
||||||
|
snprintf(msg, sizeof msg, "branch: Reset from %s",
|
||||||
|
start_name);
|
||||||
|
else
|
||||||
snprintf(msg, sizeof msg, "branch: Created from %s",
|
snprintf(msg, sizeof msg, "branch: Created from %s",
|
||||||
start_name);
|
start_name);
|
||||||
}
|
|
||||||
|
|
||||||
if (write_ref_sha1(lock, sha1, msg) < 0)
|
if (write_ref_sha1(lock, sha1, msg) < 0)
|
||||||
die("Failed to write ref: %s.", strerror(errno));
|
die("Failed to write ref: %s.", strerror(errno));
|
||||||
|
Loading…
Reference in New Issue
Block a user