For example, if I have two repos (remove-suffix is enabled): /foo /foo/bar http://cgit/foo/bar/ is interpreted as "repository 'foo', command 'bar'" instead of "repository 'foo/bar'"
@ -17,7 +17,8 @@
*/
void cgit_parse_url(const char *url)
{
char *cmd, *p;
char *c, *cmd, *p;
struct cgit_repo *repo;
ctx.repo = NULL;
if (!url || url[0] == '\0')
@ -29,16 +30,20 @@ void cgit_parse_url(const char *url)
return;
}
cmd = strchr(url, '/');
cmd = NULL;
while (!ctx.repo && cmd) {
c = strchr(url, '/');
cmd[0] = '\0';
while (c) {
ctx.repo = cgit_get_repoinfo(url);
c[0] = '\0';
if (ctx.repo == NULL) {
repo = cgit_get_repoinfo(url);
cmd[0] = '/';
if (repo) {
cmd = strchr(cmd + 1, '/');
ctx.repo = repo;
continue;
cmd = c;
c[0] = '/';
c = strchr(c + 1, '/');
if (ctx.repo) {
ctx.qry.repo = ctx.repo->url;
p = strchr(cmd + 1, '/');
if (p) {