]> granicus.if.org Git - cgit/commitdiff
Handle single-line and empty commit subjects
authorOndrej Jirman <ondrej.jirman@zonio.net>
Sat, 26 May 2007 00:19:38 +0000 (02:19 +0200)
committerLars Hjemli <hjemli@gmail.com>
Thu, 31 May 2007 08:21:50 +0000 (10:21 +0200)
If commit object ends with \0 after subject line, then info->subject
was not set.

This commit fixes this and also sets subject to ** empty ** if it
would otherwise be empty, so that there is something to click on.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
parsing.c

index 4420e5867cacf716df3aec1649241acd3354dced..b86467aed5a8720d6bbd829fe81cc852410e8dc9 100644 (file)
--- a/parsing.c
+++ b/parsing.c
@@ -234,14 +234,19 @@ struct commitinfo *cgit_parse_commit(struct commit *commit)
                p = strchr(p, '\n') + 1;
 
        t = strchr(p, '\n');
-       if (t && *t) {
-               ret->subject = substr(p, t);
+       if (t) {
+               if (*t == '\0')
+                       ret->subject = strdup("** empty **");
+               else
+                       ret->subject = substr(p, t);
                p = t + 1;
 
                while (*p == '\n')
                        p = strchr(p, '\n') + 1;
                ret->msg = p;
-       }
+       } else
+               ret->subject = substr(p, p+strlen(p));
+
        return ret;
 }