diff options
author | Grégoire Barbier <gb@gbarbier.org> | 2008-01-19 16:22:50 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2008-01-20 15:18:34 -0800 |
commit | 3057ded057f17add305cd38fe0b73173e94c540e (patch) | |
tree | 2c8a5ec604c07cc23a60c1521ae5cbf83bcbb175 /builtin-http-fetch.c | |
parent | 325ce3959ccee623eb973136f41741ca4e0ca56e (diff) | |
download | git-3057ded057f17add305cd38fe0b73173e94c540e.tar.gz |
http-push and http-fetch: handle URLs without trailing /
The URL to a repository http-push and http-fetch takes should
have a trailing slash. Instead of failing the request, add it
ourselves before attempting such a request.
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'builtin-http-fetch.c')
-rw-r--r-- | builtin-http-fetch.c | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/builtin-http-fetch.c b/builtin-http-fetch.c index 4a50dbd95b..7f450c61d9 100644 --- a/builtin-http-fetch.c +++ b/builtin-http-fetch.c @@ -9,6 +9,7 @@ int cmd_http_fetch(int argc, const char **argv, const char *prefix) const char **write_ref = NULL; char **commit_id; const char *url; + char *rewritten_url = NULL; int arg = 1; int rc = 0; int get_tree = 0; @@ -51,6 +52,12 @@ int cmd_http_fetch(int argc, const char **argv, const char *prefix) commits = 1; } url = argv[arg]; + if (url && url[strlen(url)-1] != '/') { + rewritten_url = malloc(strlen(url)+2); + strcpy(rewritten_url, url); + strcat(rewritten_url, "/"); + url = rewritten_url; + } walker = get_http_walker(url); walker->get_tree = get_tree; @@ -73,5 +80,8 @@ int cmd_http_fetch(int argc, const char **argv, const char *prefix) walker_free(walker); + if (rewritten_url) + free(rewritten_url); + return rc; } |