]> gitweb.ps.run Git - ps-cgit/blobdiff - parsing.c
Handle '+' in querystring
[ps-cgit] / parsing.c
index 6cab0e94701fe12f8e0fd6e48d05004d761f113f..1b22fcf5d059dfd5715e4b5acce911b773115bd2 100644 (file)
--- a/parsing.c
+++ b/parsing.c
@@ -92,6 +92,8 @@ int cgit_parse_query(char *txt, configfn fn)
                if (c=='=') {
                        *t = '\0';
                        value = t+1;
+               } else if (c=='+') {
+                       *t = ' ';
                } else if (c=='&') {
                        *t = '\0';
                        (*fn)(txt, value);
@@ -135,14 +137,22 @@ struct commitinfo *cgit_parse_commit(struct commit *commit)
                p += 7;
                t = strchr(p, '<') - 1;
                ret->author = substr(p, t);
-               p = strchr(p, '\n') + 1;
+               p = t;
+               t = strchr(t, '>') + 1;
+               ret->author_email = substr(p, t);
+               ret->author_date = atol(++t);
+               p = strchr(t, '\n') + 1;
        }
 
        if (!strncmp(p, "committer ", 9)) {
                p += 9;
                t = strchr(p, '<') - 1;
                ret->committer = substr(p, t);
-               p = strchr(p, '\n') + 1;
+               p = t;
+               t = strchr(t, '>') + 1;
+               ret->committer_email = substr(p, t);
+               ret->committer_date = atol(++t);
+               p = strchr(t, '\n') + 1;
        }
 
        while (*p == '\n')
@@ -150,6 +160,7 @@ struct commitinfo *cgit_parse_commit(struct commit *commit)
 
        t = strchr(p, '\n');
        ret->subject = substr(p, t);
+       p = t + 1;
 
        while (*p == '\n')
                p = strchr(p, '\n') + 1;