diff options
Diffstat (limited to 'builtin/remote-ext.c')
| -rw-r--r-- | builtin/remote-ext.c | 13 | 
1 files changed, 5 insertions, 8 deletions
| diff --git a/builtin/remote-ext.c b/builtin/remote-ext.c index 692c834d9d..3b8c22cc75 100644 --- a/builtin/remote-ext.c +++ b/builtin/remote-ext.c @@ -30,16 +30,14 @@ static char *strip_escapes(const char *str, const char *service,  	size_t rpos = 0;  	int escape = 0;  	char special = 0; -	size_t psoff = 0; +	const char *service_noprefix = service;  	struct strbuf ret = STRBUF_INIT; -	/* Calculate prefix length for \s and lengths for \s and \S */ -	if (!strncmp(service, "git-", 4)) -		psoff = 4; +	skip_prefix(service_noprefix, "git-", &service_noprefix);  	/* Pass the service to command. */  	setenv("GIT_EXT_SERVICE", service, 1); -	setenv("GIT_EXT_SERVICE_NOPREFIX", service + psoff, 1); +	setenv("GIT_EXT_SERVICE_NOPREFIX", service_noprefix, 1);  	/* Scan the length of argument. */  	while (str[rpos] && (escape || str[rpos] != ' ')) { @@ -85,7 +83,7 @@ static char *strip_escapes(const char *str, const char *service,  				strbuf_addch(&ret, str[rpos]);  				break;  			case 's': -				strbuf_addstr(&ret, service + psoff); +				strbuf_addstr(&ret, service_noprefix);  				break;  			case 'S':  				strbuf_addstr(&ret, service); @@ -179,9 +177,8 @@ static void send_git_request(int stdin_fd, const char *serv, const char *repo,  static int run_child(const char *arg, const char *service)  {  	int r; -	struct child_process child; +	struct child_process child = CHILD_PROCESS_INIT; -	memset(&child, 0, sizeof(child));  	child.in = -1;  	child.out = -1;  	child.err = 0; | 
