author | Lars Hjemli <hjemli@gmail.com> | 2008-06-26 10:54:44 (UTC) |
---|---|---|
committer | Lars Hjemli <hjemli@gmail.com> | 2008-06-26 10:54:44 (UTC) |
commit | 29b37e9781ce1bb04e558c7490d2c29eb1a477e5 (patch) (unidiff) | |
tree | 5a9a7b0b976b442cc8dda6195b804993c603d28d | |
parent | 833b0d2732f808281496df16eb917d6fdb0a274f (diff) | |
parent | 42effc939090b2fbf1b2b76cd1d9c30fabcd230e (diff) | |
download | cgit-29b37e9781ce1bb04e558c7490d2c29eb1a477e5.zip cgit-29b37e9781ce1bb04e558c7490d2c29eb1a477e5.tar.gz cgit-29b37e9781ce1bb04e558c7490d2c29eb1a477e5.tar.bz2 |
Merge branch 'master' of git://git.klever.net/patchwork/cgit
* 'master' of git://git.klever.net/patchwork/cgit:
allow specification of directly linked blobs mimetypes
allow blob extract blobs by head/path combination
-rw-r--r-- | cgit.c | 2 | ||||
-rw-r--r-- | cgit.h | 1 | ||||
-rw-r--r-- | cmd.c | 2 | ||||
-rw-r--r-- | ui-blob.c | 39 | ||||
-rw-r--r-- | ui-blob.h | 2 |
5 files changed, 39 insertions, 7 deletions
@@ -146,2 +146,4 @@ static void querystring_cb(const char *name, const char *value) | |||
146 | ctx.qry.name = xstrdup(value); | 146 | ctx.qry.name = xstrdup(value); |
147 | } else if (!strcmp(name, "mimetype")) { | ||
148 | ctx.qry.mimetype = xstrdup(value); | ||
147 | } | 149 | } |
@@ -118,2 +118,3 @@ struct cgit_query { | |||
118 | char *name; | 118 | char *name; |
119 | char *mimetype; | ||
119 | int ofs; | 120 | int ofs; |
@@ -34,3 +34,3 @@ static void blob_fn(struct cgit_context *ctx) | |||
34 | { | 34 | { |
35 | cgit_print_blob(ctx->qry.sha1, ctx->qry.path); | 35 | cgit_print_blob(ctx->qry.sha1, ctx->qry.path, ctx->qry.head); |
36 | } | 36 | } |
@@ -12,3 +12,14 @@ | |||
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 | { |
@@ -19,6 +30,15 @@ void cgit_print_blob(const char *hex, char *path) | |||
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 | } |
@@ -26,2 +46,11 @@ void cgit_print_blob(const char *hex, char *path) | |||
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) { |
@@ -38,3 +67,3 @@ void cgit_print_blob(const char *hex, char *path) | |||
38 | buf[size] = '\0'; | 67 | buf[size] = '\0'; |
39 | ctx.page.mimetype = NULL; | 68 | ctx.page.mimetype = ctx.qry.mimetype; |
40 | ctx.page.filename = path; | 69 | ctx.page.filename = path; |
@@ -3,3 +3,3 @@ | |||
3 | 3 | ||
4 | extern void cgit_print_blob(const char *hex, char *path); | 4 | extern void cgit_print_blob(const char *hex, char *path, const char *head); |
5 | 5 | ||