]>
git.cameronkatri.com Git - cgit.git/blob - ui-diff.c
1 /* ui-diff.c: show diff between two blobs
3 * Copyright (C) 2006 Lars Hjemli
5 * Licensed under GNU General Public License v2
6 * (see COPYING for full license text)
13 * print a single line returned from xdiff
15 static void print_line(char *line
, int len
)
22 else if (line
[0] == '-')
24 else if (line
[0] == '@')
27 htmlf("<div class='%s'>", class);
34 static void header(unsigned char *sha1
, char *path1
, int mode1
,
35 unsigned char *sha2
, char *path2
, int mode2
)
37 char *abbrev1
, *abbrev2
;
40 subproject
= (S_ISGITLINK(mode1
) || S_ISGITLINK(mode2
));
41 html("<div class='head'>");
42 html("diff --git a/");
47 if (is_null_sha1(sha1
))
49 if (is_null_sha1(sha2
))
53 htmlf("<br/>new file mode %.6o", mode2
);
56 htmlf("<br/>deleted file mode %.6o", mode1
);
59 abbrev1
= xstrdup(find_unique_abbrev(sha1
, DEFAULT_ABBREV
));
60 abbrev2
= xstrdup(find_unique_abbrev(sha2
, DEFAULT_ABBREV
));
61 htmlf("<br/>index %s..%s", abbrev1
, abbrev2
);
64 if (mode1
!= 0 && mode2
!= 0) {
65 htmlf(" %.6o", mode1
);
67 htmlf("..%.6o", mode2
);
77 static void filepair_cb(struct diff_filepair
*pair
)
79 header(pair
->one
->sha1
, pair
->one
->path
, pair
->one
->mode
,
80 pair
->two
->sha1
, pair
->two
->path
, pair
->two
->mode
);
81 if (S_ISGITLINK(pair
->one
->mode
) || S_ISGITLINK(pair
->two
->mode
)) {
82 if (S_ISGITLINK(pair
->one
->mode
))
83 print_line(fmt("-Subproject %s", sha1_to_hex(pair
->one
->sha1
)), 52);
84 if (S_ISGITLINK(pair
->two
->mode
))
85 print_line(fmt("+Subproject %s", sha1_to_hex(pair
->two
->sha1
)), 52);
88 if (cgit_diff_files(pair
->one
->sha1
, pair
->two
->sha1
, print_line
))
89 cgit_print_error("Error running diff");
92 void cgit_print_diff(const char *head
, const char *old_hex
, const char *new_hex
, char *path
)
94 unsigned char sha1
[20], sha2
[20];
95 enum object_type type
;
97 struct commit
*commit
;
99 if (head
&& !old_hex
&& !new_hex
) {
100 get_sha1(head
, sha1
);
101 commit
= lookup_commit_reference(sha1
);
102 if (commit
&& !parse_commit(commit
)) {
103 html("<table class='diff'>");
105 cgit_diff_commit(commit
, filepair_cb
);
112 get_sha1(old_hex
, sha1
);
113 get_sha1(new_hex
, sha2
);
115 type
= sha1_object_info(sha1
, &size
);
116 if (type
== OBJ_BAD
) {
117 type
= sha1_object_info(sha2
, &size
);
118 if (type
== OBJ_BAD
) {
119 cgit_print_error(fmt("Bad object names: %s, %s", old_hex
, new_hex
));
124 html("<table class='diff'>");
128 header(sha1
, path
, 0644, sha2
, path
, 0644);
129 if (cgit_diff_files(sha1
, sha2
, print_line
))
130 cgit_print_error("Error running diff");
134 cgit_diff_tree(sha1
, sha2
, filepair_cb
);
137 cgit_print_error(fmt("Unhandled object type: %s",