]> granicus.if.org Git - cgit/commitdiff
ui-shared.c: fix segfault when repo is empty
authorFlorian Pritz <bluewind@xssn.at>
Mon, 1 Feb 2010 16:55:37 +0000 (17:55 +0100)
committerLars Hjemli <hjemli@gmail.com>
Sat, 27 Feb 2010 11:47:57 +0000 (12:47 +0100)
PATH_INFO="/$REPONAME/commit/?id=1" QUERY_STRING="id=1" ./cgit.cgi
triggers segfault when the repository is empty and therefore
ctx.qry.head is unset

Signed-off-by: Florian Pritz <bluewind@xssn.at>
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
ui-shared.c

index 4049a2b6811d42d44f5eacfaefbda05244063e1b..8a7cc323363cc39837092609fee076300be95f60 100644 (file)
@@ -246,7 +246,7 @@ static void reporevlink(char *page, char *name, char *title, char *class,
        char *delim;
 
        delim = repolink(title, class, page, head, path);
-       if (rev && strcmp(rev, ctx.qry.head)) {
+       if (rev && ctx.qry.head != NULL && strcmp(rev, ctx.qry.head)) {
                html(delim);
                html("id=");
                html_url_arg(rev);
@@ -346,7 +346,7 @@ void cgit_diff_link(char *name, char *title, char *class, char *head,
        char *delim;
 
        delim = repolink(title, class, "diff", head, path);
-       if (new_rev && strcmp(new_rev, ctx.qry.head)) {
+       if (new_rev && ctx.qry.head != NULL && strcmp(new_rev, ctx.qry.head)) {
                html(delim);
                html("id=");
                html_url_arg(new_rev);