From: Pascal Obry <pascal.obry@gmail.com>
To: git list <git@vger.kernel.org>,
Matthieu Moy <Matthieu.Moy@grenoble-inp.fr>
Subject: [PATCH v4] Do not decode url protocol.
Date: Tue, 22 Jun 2010 22:16:57 +0200 [thread overview]
Message-ID: <4C211A39.2080207@obry.net> (raw)
When using the protocol git+ssh:// for example we do not want to
decode the '+' as a space. The url decoding must take place only
for the server name and parameters.
This fixes a regression introduced in 9d2e942.
---
url.c | 19 +++++++++++++++----
1 files changed, 15 insertions(+), 4 deletions(-)
Ok, so this is the fourth version of this patch. Thanks again Matthieu
for the review. I think this time I got the place for the message right :)
Anyway, I think this time we properly skip the protocol decoding when
needed.
diff --git a/url.c b/url.c
index cd32b92..0eb7fb3 100644
--- a/url.c
+++ b/url.c
@@ -67,12 +67,23 @@ static int url_decode_char(const char *q)
return val;
}
-static char *url_decode_internal(const char **query, const char *stop_at)
+static char *url_decode_internal(const char **query, const char *stop_at,
+ int with_protocol)
{
const char *q = *query;
+ const char *first_slash;
struct strbuf out;
strbuf_init(&out, 16);
+
+ /* Skip protocol if present. */
+ if (with_protocol) {
+ first_slash = strchr(*query, '/');
+
+ while (q < first_slash)
+ strbuf_addch(&out, *q++);
+ }
+
do {
unsigned char c = *q;
@@ -104,15 +115,15 @@ static char *url_decode_internal(const char
**query, const char *stop_at)
char *url_decode(const char *url)
{
- return url_decode_internal(&url, NULL);
+ return url_decode_internal(&url, NULL, 1);
}
char *url_decode_parameter_name(const char **query)
{
- return url_decode_internal(query, "&=");
+ return url_decode_internal(query, "&=", 0);
}
char *url_decode_parameter_value(const char **query)
{
- return url_decode_internal(query, "&");
+ return url_decode_internal(query, "&", 0);
}
--
1.7.1.426.gb436.dirty
--
--|------------------------------------------------------
--| Pascal Obry Team-Ada Member
--| 45, rue Gabriel Peri - 78114 Magny Les Hameaux FRANCE
--|------------------------------------------------------
--| http://www.obry.net - http://v2p.fr.eu.org
--| "The best way to travel is by means of imagination"
--|
--| gpg --keyserver keys.gnupg.net --recv-key F949BD3B
next reply other threads:[~2010-06-22 20:15 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-06-22 20:16 Pascal Obry [this message]
2010-06-22 21:39 ` [PATCH v4] Do not decode url protocol Matthieu Moy
2010-06-22 22:46 ` Jeff King
2010-06-23 17:27 ` Junio C Hamano
2010-06-23 17:38 ` Jeff King
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4C211A39.2080207@obry.net \
--to=pascal.obry@gmail.com \
--cc=Matthieu.Moy@grenoble-inp.fr \
--cc=git@vger.kernel.org \
--cc=pascal@obry.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).