connect.c: move duplicated code to a new function 'get_host_and_port'
The following functions: git_tcp_connect_sock (IPV6 version) git_tcp_connect_sock (no IPV6 version), git_proxy_connect have common block of code. Move it to a new function 'get_host_and_port' Signed-off-by: Michael Lukashov <michael.lukashov@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
e923eaeb90
commit
72a534dab0
83
connect.c
83
connect.c
@ -152,6 +152,28 @@ static enum protocol get_protocol(const char *name)
|
|||||||
#define STR_(s) # s
|
#define STR_(s) # s
|
||||||
#define STR(s) STR_(s)
|
#define STR(s) STR_(s)
|
||||||
|
|
||||||
|
static void get_host_and_port(char **host, const char **port)
|
||||||
|
{
|
||||||
|
char *colon, *end;
|
||||||
|
|
||||||
|
if (*host[0] == '[') {
|
||||||
|
end = strchr(*host + 1, ']');
|
||||||
|
if (end) {
|
||||||
|
*end = 0;
|
||||||
|
end++;
|
||||||
|
(*host)++;
|
||||||
|
} else
|
||||||
|
end = *host;
|
||||||
|
} else
|
||||||
|
end = *host;
|
||||||
|
colon = strchr(end, ':');
|
||||||
|
|
||||||
|
if (colon) {
|
||||||
|
*colon = 0;
|
||||||
|
*port = colon + 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#ifndef NO_IPV6
|
#ifndef NO_IPV6
|
||||||
|
|
||||||
static const char *ai_name(const struct addrinfo *ai)
|
static const char *ai_name(const struct addrinfo *ai)
|
||||||
@ -170,30 +192,14 @@ static const char *ai_name(const struct addrinfo *ai)
|
|||||||
static int git_tcp_connect_sock(char *host, int flags)
|
static int git_tcp_connect_sock(char *host, int flags)
|
||||||
{
|
{
|
||||||
int sockfd = -1, saved_errno = 0;
|
int sockfd = -1, saved_errno = 0;
|
||||||
char *colon, *end;
|
|
||||||
const char *port = STR(DEFAULT_GIT_PORT);
|
const char *port = STR(DEFAULT_GIT_PORT);
|
||||||
struct addrinfo hints, *ai0, *ai;
|
struct addrinfo hints, *ai0, *ai;
|
||||||
int gai;
|
int gai;
|
||||||
int cnt = 0;
|
int cnt = 0;
|
||||||
|
|
||||||
if (host[0] == '[') {
|
get_host_and_port(&host, &port);
|
||||||
end = strchr(host + 1, ']');
|
if (!*port)
|
||||||
if (end) {
|
port = "<none>";
|
||||||
*end = 0;
|
|
||||||
end++;
|
|
||||||
host++;
|
|
||||||
} else
|
|
||||||
end = host;
|
|
||||||
} else
|
|
||||||
end = host;
|
|
||||||
colon = strchr(end, ':');
|
|
||||||
|
|
||||||
if (colon) {
|
|
||||||
*colon = 0;
|
|
||||||
port = colon + 1;
|
|
||||||
if (!*port)
|
|
||||||
port = "<none>";
|
|
||||||
}
|
|
||||||
|
|
||||||
memset(&hints, 0, sizeof(hints));
|
memset(&hints, 0, sizeof(hints));
|
||||||
hints.ai_socktype = SOCK_STREAM;
|
hints.ai_socktype = SOCK_STREAM;
|
||||||
@ -251,30 +257,15 @@ static int git_tcp_connect_sock(char *host, int flags)
|
|||||||
static int git_tcp_connect_sock(char *host, int flags)
|
static int git_tcp_connect_sock(char *host, int flags)
|
||||||
{
|
{
|
||||||
int sockfd = -1, saved_errno = 0;
|
int sockfd = -1, saved_errno = 0;
|
||||||
char *colon, *end;
|
const char *port = STR(DEFAULT_GIT_PORT);
|
||||||
char *port = STR(DEFAULT_GIT_PORT), *ep;
|
char *ep;
|
||||||
struct hostent *he;
|
struct hostent *he;
|
||||||
struct sockaddr_in sa;
|
struct sockaddr_in sa;
|
||||||
char **ap;
|
char **ap;
|
||||||
unsigned int nport;
|
unsigned int nport;
|
||||||
int cnt;
|
int cnt;
|
||||||
|
|
||||||
if (host[0] == '[') {
|
get_host_and_port(&host, &port);
|
||||||
end = strchr(host + 1, ']');
|
|
||||||
if (end) {
|
|
||||||
*end = 0;
|
|
||||||
end++;
|
|
||||||
host++;
|
|
||||||
} else
|
|
||||||
end = host;
|
|
||||||
} else
|
|
||||||
end = host;
|
|
||||||
colon = strchr(end, ':');
|
|
||||||
|
|
||||||
if (colon) {
|
|
||||||
*colon = 0;
|
|
||||||
port = colon + 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (flags & CONNECT_VERBOSE)
|
if (flags & CONNECT_VERBOSE)
|
||||||
fprintf(stderr, "Looking up %s ... ", host);
|
fprintf(stderr, "Looking up %s ... ", host);
|
||||||
@ -406,26 +397,10 @@ static int git_use_proxy(const char *host)
|
|||||||
static void git_proxy_connect(int fd[2], char *host)
|
static void git_proxy_connect(int fd[2], char *host)
|
||||||
{
|
{
|
||||||
const char *port = STR(DEFAULT_GIT_PORT);
|
const char *port = STR(DEFAULT_GIT_PORT);
|
||||||
char *colon, *end;
|
|
||||||
const char *argv[4];
|
const char *argv[4];
|
||||||
struct child_process proxy;
|
struct child_process proxy;
|
||||||
|
|
||||||
if (host[0] == '[') {
|
get_host_and_port(&host, &port);
|
||||||
end = strchr(host + 1, ']');
|
|
||||||
if (end) {
|
|
||||||
*end = 0;
|
|
||||||
end++;
|
|
||||||
host++;
|
|
||||||
} else
|
|
||||||
end = host;
|
|
||||||
} else
|
|
||||||
end = host;
|
|
||||||
colon = strchr(end, ':');
|
|
||||||
|
|
||||||
if (colon) {
|
|
||||||
*colon = 0;
|
|
||||||
port = colon + 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
argv[0] = git_proxy_command;
|
argv[0] = git_proxy_command;
|
||||||
argv[1] = host;
|
argv[1] = host;
|
||||||
|
Loading…
Reference in New Issue
Block a user