Mike Hommey <[email protected]> writes:
> Currently, get_host_and_port() is called in git_connect() for the ssh
> protocol, and in git_tcp_connect_sock() for the git protocol. Instead
> of doing this, just call it from a single place, right after
> parse_connect_url(), and pass the host and port separately to
> git_*_connect() functions.
>
> We however preserve hostandport, at least for now.
>
> Note that in git_tcp_connect_sock, the port was set to "<none>" in a
> case that never can happen, so that code path was removed.
Can never happen because?
!*port means get_host_and_port() made the "port" pointer point at
a NUL byte. That does not happen because the only case port is
moved by that function is to have it point at a byte after we
found ':', and the "port" string is a decimal integer whose value
is between 0 and 65535, so there is no way port points at an empty
string.
OK.
> struct child_process *git_connect(int fd[2], const char *url,
> const char *prog, int flags)
> ...
> @@ -683,6 +681,8 @@ struct child_process *git_connect(int fd[2], const char
> *url,
> signal(SIGCHLD, SIG_DFL);
>
> protocol = parse_connect_url(url, &hostandport, &path);
> + host = xstrdup(hostandport);
> + get_host_and_port(&host, &port);
> if ((flags & CONNECT_DIAG_URL) && (protocol != PROTO_SSH)) {
> printf("Diag: url=%s\n", url ? url : "NULL");
> printf("Diag: protocol=%s\n", prot_name(protocol));
> ...
> @@ -737,22 +737,20 @@ struct child_process *git_connect(int fd[2], const char
> *url,
> if (protocol == PROTO_SSH) {
> const char *ssh;
> int putty = 0, tortoiseplink = 0;
> - char *ssh_host = hostandport;
> - const char *port = NULL;
> transport_check_allowed("ssh");
> - get_host_and_port(&ssh_host, &port);
>
> if (!port)
> - port = get_port(ssh_host);
> + port = get_port(host);
This looks strange. We asked get_host_and_port() to split
hostandport into host and port already, and learned that port is
empty, i.e. it wasn't <host>:<port> where <port> is a decimal
integer between 0 and 65535. It could have been "<host>:" in which
case get_host_and_port() would have turned that colon into NUL.
Would there be a case where this get_port() call does anthing
useful?
--
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