Re: [PATCH] http: use strbuf API in quote_ref_url

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi,

On Sat, 7 Mar 2009, Tay Ray Chuan wrote:

> In addition, ''quote_ref_url'' inserts a slash between the base URL and
> remote ref path only if needed. Previously, this insertion wasn't
> contingent on the lack of a separating slash.
> 
> Signed-off-by: Tay Ray Chuan <rctay89@xxxxxxxxx>
> Acked-by: Johannes Schindelin <johannes.schindelin@xxxxxx>
> ---

I would prefer to give my ACK explicitely... :-)

>  http.c |   29 ++++++++++-------------------
>  1 files changed, 10 insertions(+), 19 deletions(-)
> 
> diff --git a/http.c b/http.c
> index cdedeb6..9de4130 100644
> --- a/http.c
> +++ b/http.c
> @@ -577,31 +577,22 @@ static inline int hex(int v)
> 
>  static char *quote_ref_url(const char *base, const char *ref)
>  {
> +	struct strbuf buf = STRBUF_INIT;
>  	const char *cp;
> -	char *dp, *qref;
> -	int len, baselen, ch;
> +	int ch;
> +
> +	strbuf_addstr(&buf, base);
> +	if (strcmp(base+strlen(base)-1, "/") && strcmp(ref, "/"))
> +		strbuf_addstr(&buf, "/");

I would not have scratched my head that much if it read like this:

	if (buf.len && buf.buf[buf.len - 1] != '/' && *ref != '/')
		strbuf_addch(&buf, '/');

>  	for (cp = ref; (ch = *cp) != 0; cp++) {
> -		if (needs_quote(ch)) {
> -			*dp++ = '%';
> -			*dp++ = hex((ch >> 4) & 0xF);
> -			*dp++ = hex(ch & 0xF);
> -		}
> +		if (needs_quote(ch))
> +			strbuf_addf(&buf, "%%%02x", ch);
>  		else
> -			*dp++ = ch;
> +			strbuf_addch(&buf, *cp);
>  	}

Seems as if you could remove even the curly brackets here.

Other than that, it indeed looks like an ACK from me...

Ciao,
Dscho
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux