On Wed, Jul 29, 2015 at 11:51 AM, Patrick Steinhardt <[email protected]> wrote:
> parse_connect_url() checks if the path component of the URL is
> empty and if so causes the program to die. As the function is to
> be used at other call sites which do not require this check, move
> up the error checking to the existing caller.
>
> Signed-off-by: Patrick Steinhardt <[email protected]>
> ---
> diff --git a/connect.c b/connect.c
> index bdbcee4..e8b813d 100644
> --- a/connect.c
> +++ b/connect.c
> @@ -613,9 +613,6 @@ enum protocol parse_connect_url(const char *url_orig,
> char **ret_host,
> else
> path = strchr(end, separator);
>
> - if (!path || !*path)
> - die("No path specified. See 'man git-pull' for valid url
> syntax");
> -
Given that there are several dereferences of 'path' following this bit
of code, won't this change lead to a crash when path==NULL?
> /*
> * null-terminate hostname and point path to ~ for URL's like this:
> * ssh://host.xz/~user/repo
> @@ -665,6 +662,9 @@ struct child_process *git_connect(int fd[2], const char
> *url,
> signal(SIGCHLD, SIG_DFL);
>
> protocol = parse_connect_url(url, &hostandport, &path);
> + if (!path || !*path)
> + die("No path specified. See 'man git-pull' for valid url
> syntax");
> +
> if ((flags & CONNECT_DIAG_URL) && (protocol != PROTO_SSH)) {
> printf("Diag: url=%s\n", url ? url : "NULL");
> printf("Diag: protocol=%s\n", prot_name(protocol));
> --
> 2.5.0
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html