summaryrefslogtreecommitdiffabout
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--cgit.h4
-rw-r--r--parsing.c12
2 files changed, 14 insertions, 2 deletions
diff --git a/cgit.h b/cgit.h
index b6b60c6..f06a941 100644
--- a/cgit.h
+++ b/cgit.h
@@ -9,25 +9,29 @@
9typedef void (*configfn)(const char *name, const char *value); 9typedef void (*configfn)(const char *name, const char *value);
10 10
11struct cacheitem { 11struct cacheitem {
12 char *name; 12 char *name;
13 struct stat st; 13 struct stat st;
14 int ttl; 14 int ttl;
15 int fd; 15 int fd;
16}; 16};
17 17
18struct commitinfo { 18struct commitinfo {
19 struct commit *commit; 19 struct commit *commit;
20 char *author; 20 char *author;
21 char *author_email;
22 unsigned long author_date;
21 char *committer; 23 char *committer;
24 char *committer_email;
25 unsigned long committer_date;
22 char *subject; 26 char *subject;
23 char *msg; 27 char *msg;
24}; 28};
25 29
26extern const char cgit_version[]; 30extern const char cgit_version[];
27 31
28extern char *cgit_root; 32extern char *cgit_root;
29extern char *cgit_root_title; 33extern char *cgit_root_title;
30extern char *cgit_css; 34extern char *cgit_css;
31extern char *cgit_logo; 35extern char *cgit_logo;
32extern char *cgit_logo_link; 36extern char *cgit_logo_link;
33extern char *cgit_virtual_root; 37extern char *cgit_virtual_root;
diff --git a/parsing.c b/parsing.c
index be471b5..4d5cc74 100644
--- a/parsing.c
+++ b/parsing.c
@@ -126,32 +126,40 @@ struct commitinfo *cgit_parse_commit(struct commit *commit)
126 if (strncmp(p, "tree ", 5)) 126 if (strncmp(p, "tree ", 5))
127 die("Bad commit: %s", sha1_to_hex(commit->object.sha1)); 127 die("Bad commit: %s", sha1_to_hex(commit->object.sha1));
128 else 128 else
129 p += 46; // "tree " + hex[40] + "\n" 129 p += 46; // "tree " + hex[40] + "\n"
130 130
131 while (!strncmp(p, "parent ", 7)) 131 while (!strncmp(p, "parent ", 7))
132 p += 48; // "parent " + hex[40] + "\n" 132 p += 48; // "parent " + hex[40] + "\n"
133 133
134 if (!strncmp(p, "author ", 7)) { 134 if (!strncmp(p, "author ", 7)) {
135 p += 7; 135 p += 7;
136 t = strchr(p, '<') - 1; 136 t = strchr(p, '<') - 1;
137 ret->author = substr(p, t); 137 ret->author = substr(p, t);
138 p = strchr(p, '\n') + 1; 138 p = t;
139 t = strchr(t, '>') + 1;
140 ret->author_email = substr(p, t);
141 ret->author_date = atol(++t);
142 p = strchr(t, '\n') + 1;
139 } 143 }
140 144
141 if (!strncmp(p, "committer ", 9)) { 145 if (!strncmp(p, "committer ", 9)) {
142 p += 9; 146 p += 9;
143 t = strchr(p, '<') - 1; 147 t = strchr(p, '<') - 1;
144 ret->committer = substr(p, t); 148 ret->committer = substr(p, t);
145 p = strchr(p, '\n') + 1; 149 p = t;
150 t = strchr(t, '>') + 1;
151 ret->committer_email = substr(p, t);
152 ret->committer_date = atol(++t);
153 p = strchr(t, '\n') + 1;
146 } 154 }
147 155
148 while (*p == '\n') 156 while (*p == '\n')
149 p = strchr(p, '\n') + 1; 157 p = strchr(p, '\n') + 1;
150 158
151 t = strchr(p, '\n'); 159 t = strchr(p, '\n');
152 ret->subject = substr(p, t); 160 ret->subject = substr(p, t);
153 p = t + 1; 161 p = t + 1;
154 162
155 while (*p == '\n') 163 while (*p == '\n')
156 p = strchr(p, '\n') + 1; 164 p = strchr(p, '\n') + 1;
157 ret->msg = p; 165 ret->msg = p;