diff --git a/ui-repolist.c b/ui-repolist.c
index 4b16b6e..12ac1fc 100644
--- a/ui-repolist.c
+++ b/ui-repolist.c
@@ -108,7 +108,7 @@ static int is_in_url(struct cgit_repo *repo)
static void print_sort_header(const char *title, const char *sort)
{
html("
owner);
html("'>");
diff --git a/ui-shared.c b/ui-shared.c
index f8e5bef..838437c 100644
--- a/ui-shared.c
+++ b/ui-shared.c
@@ -65,6 +65,13 @@ const char *cgit_hosturl()
return fmtalloc("%s:%s", ctx.env.server_name, ctx.env.server_port);
}
+const char *cgit_currenturl()
+{
+ if (!ctx.qry.url)
+ return cgit_rooturl();
+ return ctx.qry.url;
+}
+
const char *cgit_rooturl()
{
if (ctx.cfg.virtual_root)
@@ -145,7 +152,7 @@ static void site_url(const char *page, const char *search, const char *sort, int
char *delim = "?";
if (!page)
- html_attr(ctx.qry.url);
+ html_attr(cgit_currenturl());
else
html_attr(cgit_rooturl());
@@ -952,7 +959,7 @@ void cgit_print_pageheader(void)
NULL, NULL, 0);
html(" | ");
html(" |