diff options
author | Michael Krelin | 2008-06-24 23:33:24 +0200 |
---|---|---|
committer | Michael Krelin | 2008-06-24 23:33:24 +0200 |
commit | 01d2dce7e73e3f022d186de27dd5d15574144ca8 (patch) | |
tree | eeb2cc9089b048ddb6ee7c2f2c1ca5738b6e6a51 /ui-blob.c | |
parent | e6b635c2b1a0b2c08170c70e8b9e59f4b9789431 (diff) | |
download | cgit-01d2dce7e73e3f022d186de27dd5d15574144ca8.tar.gz cgit-01d2dce7e73e3f022d186de27dd5d15574144ca8.tar.bz2 cgit-01d2dce7e73e3f022d186de27dd5d15574144ca8.zip |
allow blob extract blobs by head/path combination
If blob is invoked with no id=, it tries to look up h= and search for path= in
there. Once found, proceed as normal, otherwise, fail as normal.
Signed-off-by: Michael Krelin <hacker@klever.net>
Diffstat (limited to 'ui-blob.c')
-rw-r--r-- | ui-blob.c | 37 |
1 files changed, 33 insertions, 4 deletions
@@ -10,20 +10,49 @@ | |||
10 | #include "html.h" | 10 | #include "html.h" |
11 | #include "ui-shared.h" | 11 | #include "ui-shared.h" |
12 | 12 | ||
13 | void cgit_print_blob(const char *hex, char *path) | 13 | static char *match_path; |
14 | static unsigned char *matched_sha1; | ||
15 | |||
16 | static int walk_tree(const unsigned char *sha1, const char *base,int baselen, const char *pathname, unsigned mode, int stage) { | ||
17 | if(strncmp(base,match_path,baselen) | ||
18 | || strcmp(match_path+baselen,pathname) ) | ||
19 | return READ_TREE_RECURSIVE; | ||
20 | memmove(matched_sha1,sha1,20); | ||
21 | return 0; | ||
22 | } | ||
23 | |||
24 | void cgit_print_blob(const char *hex, char *path, const char *head) | ||
14 | { | 25 | { |
15 | 26 | ||
16 | unsigned char sha1[20]; | 27 | unsigned char sha1[20]; |
17 | enum object_type type; | 28 | enum object_type type; |
18 | unsigned char *buf; | 29 | unsigned char *buf; |
19 | unsigned long size; | 30 | unsigned long size; |
31 | struct commit *commit; | ||
32 | const char *paths[] = {path, NULL}; | ||
20 | 33 | ||
21 | if (get_sha1_hex(hex, sha1)){ | 34 | if (hex) { |
22 | cgit_print_error(fmt("Bad hex value: %s", hex)); | 35 | if (get_sha1_hex(hex, sha1)){ |
23 | return; | 36 | cgit_print_error(fmt("Bad hex value: %s", hex)); |
37 | return; | ||
38 | } | ||
39 | } else { | ||
40 | if (get_sha1(head,sha1)) { | ||
41 | cgit_print_error(fmt("Bad ref: %s", head)); | ||
42 | return; | ||
43 | } | ||
24 | } | 44 | } |
25 | 45 | ||
26 | type = sha1_object_info(sha1, &size); | 46 | type = sha1_object_info(sha1, &size); |
47 | |||
48 | if((!hex) && type == OBJ_COMMIT && path) { | ||
49 | commit = lookup_commit_reference(sha1); | ||
50 | match_path = path; | ||
51 | matched_sha1 = sha1; | ||
52 | read_tree_recursive(commit->tree, NULL, 0, 0, paths, walk_tree); | ||
53 | type = sha1_object_info(sha1,&size); | ||
54 | } | ||
55 | |||
27 | if (type == OBJ_BAD) { | 56 | if (type == OBJ_BAD) { |
28 | cgit_print_error(fmt("Bad object name: %s", hex)); | 57 | cgit_print_error(fmt("Bad object name: %s", hex)); |
29 | return; | 58 | return; |