From d2a3d7a3ffd60e1e28d2fcd631b38bf40328dde6 Mon Sep 17 00:00:00 2001 From: Xavier Roche Date: Fri, 5 Jul 2013 17:53:54 +0000 Subject: Do not unescape '+' before the query string Fixed issue 18 --- src/htsencoding.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) (limited to 'src/htsencoding.c') diff --git a/src/htsencoding.c b/src/htsencoding.c index e2a8fb2..184cca6 100644 --- a/src/htsencoding.c +++ b/src/htsencoding.c @@ -206,6 +206,7 @@ int hts_unescapeEntities(const char *src, char *dest, const size_t max) { int hts_unescapeUrl(const char *src, char *dest, const size_t max) { size_t i, j, lastI, lastJ, k, utfBufferJ, utfBufferSize; + int seenQuery = 0; char utfBuffer[32]; assert(src != dest); @@ -218,7 +219,7 @@ int hts_unescapeUrl(const char *src, char *dest, const size_t max) { unsigned char cUtf = (unsigned char) c; /* Replacement for ' ' */ - if (c == '+') { + if (c == '+' && seenQuery) { c = cUtf = ' '; k = 0; /* cancel any sequence */ } @@ -250,6 +251,9 @@ int hts_unescapeUrl(const char *src, char *dest, const size_t max) { /* ASCII (and not in %xx) */ else if (cUtf < 0x80 && i != lastI + 1) { k = 0; /* cancel any sequence */ + if (!seenQuery && c == '?') { + seenQuery = 1; + } } /* UTF-8 sequence in progress (either a raw or a %xx character) */ -- cgit v1.2.3