remote.c: drop extraneous local variable from migrate_file
It's an anti-pattern to assign the result of git_path to a variable, since other calls may reuse our buffer. In this case, we feed the result to unlink_or_warn immediately afterwards, so it's OK. However, it's nice to avoid assignment entirely, which makes it more obvious that there's no bug. We can just pass the result directly to unlink_or_warn, which is a known-simple function. As a bonus, the code flow is a little more obvious, as we eliminate an extra conditional (a reader does not have to wonder any more "under which circumstances is 'path' set?"). Signed-off-by: Jeff King <peff@peff.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
e3cf230324
commit
b21a5d6605
@ -581,7 +581,6 @@ static int migrate_file(struct remote *remote)
|
|||||||
{
|
{
|
||||||
struct strbuf buf = STRBUF_INIT;
|
struct strbuf buf = STRBUF_INIT;
|
||||||
int i;
|
int i;
|
||||||
const char *path = NULL;
|
|
||||||
|
|
||||||
strbuf_addf(&buf, "remote.%s.url", remote->name);
|
strbuf_addf(&buf, "remote.%s.url", remote->name);
|
||||||
for (i = 0; i < remote->url_nr; i++)
|
for (i = 0; i < remote->url_nr; i++)
|
||||||
@ -601,11 +600,9 @@ static int migrate_file(struct remote *remote)
|
|||||||
return error(_("Could not append '%s' to '%s'"),
|
return error(_("Could not append '%s' to '%s'"),
|
||||||
remote->fetch_refspec[i], buf.buf);
|
remote->fetch_refspec[i], buf.buf);
|
||||||
if (remote->origin == REMOTE_REMOTES)
|
if (remote->origin == REMOTE_REMOTES)
|
||||||
path = git_path("remotes/%s", remote->name);
|
unlink_or_warn(git_path("remotes/%s", remote->name));
|
||||||
else if (remote->origin == REMOTE_BRANCHES)
|
else if (remote->origin == REMOTE_BRANCHES)
|
||||||
path = git_path("branches/%s", remote->name);
|
unlink_or_warn(git_path("branches/%s", remote->name));
|
||||||
if (path)
|
|
||||||
unlink_or_warn(path);
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user