cgit

commit a342ac6b4d7830f82230b0f6a29bc9378d66747e

Author: Lars Hjemli <hjemli@gmail.com>

cgit.css: try to make diffs look a little bit nicer

This makes the diffview look more like 'git-diff' in a terminal.

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

 cgit.css | 13 ++++++-------
 ui-diff.c | 32 ++++++++++++++++++++++++++------


diff --git a/cgit.css b/cgit.css
index 97ae4d141a5fff5ac1ec59536273b445c1f59993..53c93f2d41b296503193fee9dd2e0bea4cc69466 100644
--- a/cgit.css
+++ b/cgit.css
@@ -294,19 +294,18 @@ 	color: #888;
 	padding-top: 0.5em;
 }
 
-table.diff th {
-	padding: 1em 0em 0.1em 0.1em;
-	text-align: left;
-}
-
 table.diff td {
-	border: solid 1px black;
 	font-family: monospace;
 	white-space: pre;
 }
 
+table.diff td div.head {
+	font-weight: bold;
+	padding-top: 1em;
+}
+
 table.diff td div.hunk {
-	background: #ccc;
+	color: #009;
 }
 
 table.diff td div.add {




diff --git a/ui-diff.c b/ui-diff.c
index 10330d3d66d823296d6d0b21b9b64783345571fa..7ec5701a4ea668990572b3088cd004f7d2dfc7bd 100644
--- a/ui-diff.c
+++ b/ui-diff.c
@@ -31,12 +31,33 @@ 	html("
"); line[len-1] = c; } -static void filepair_cb(struct diff_filepair *pair) +static void header(unsigned char *sha1, char *path1, + unsigned char *sha2, char *path2) { - html("<tr><th>"); - html_txt(pair->two->path); - html("</th></tr>"); + char *abbrev1, *abbrev2; + html("<tr><td>"); + html("<div class='head'>"); + html("diff --git a/"); + html_txt(path1); + html(" b/"); + html_txt(path2); + abbrev1 = xstrdup(find_unique_abbrev(sha1, DEFAULT_ABBREV)); + abbrev2 = xstrdup(find_unique_abbrev(sha2, DEFAULT_ABBREV)); + htmlf("\nindex %s..%s", abbrev1, abbrev2); + free(abbrev1); + free(abbrev2); + html("\n--- a/"); + html_txt(path1); + html("\n+++ b/"); + html_txt(path2); + html("</div>"); +} + +static void filepair_cb(struct diff_filepair *pair) +{ + header(pair->one->sha1, pair->one->path, + pair->two->sha1, pair->two->path); if (cgit_diff_files(pair->one->sha1, pair->two->sha1, print_line)) cgit_print_error("Error running diff"); html("</tr></td>"); @@ -63,9 +84,8 @@ html("<table class='diff'>"); switch(type) { case OBJ_BLOB: - if (path) - htmlf("<tr><th>%s</th></tr>", path); html("<tr><td>"); + header(sha1, path, sha2, path); if (cgit_diff_files(sha1, sha2, print_line)) cgit_print_error("Error running diff"); html("</tr></td>");