|
|
|
@@ -9,9 +9,9 @@ |
9 | #include "cgit.h" |
9 | #include "cgit.h" |
10 | #include "html.h" |
10 | #include "html.h" |
11 | #include "ui-shared.h" |
11 | #include "ui-shared.h" |
12 | |
12 | |
13 | char *match_path; |
13 | int match_baselen; |
14 | int match; |
14 | int match; |
15 | |
15 | |
16 | static void print_object(const unsigned char *sha1, const char *path) |
16 | static void print_object(const unsigned char *sha1, const char *path) |
17 | { |
17 | { |
@@ -55,15 +55,23 @@ static void print_object(const unsigned char *sha1, const char *path) |
55 | static int walk_tree(const unsigned char *sha1, const char *base, int baselen, |
55 | static int walk_tree(const unsigned char *sha1, const char *base, int baselen, |
56 | const char *pathname, unsigned mode, int stage, |
56 | const char *pathname, unsigned mode, int stage, |
57 | void *cbdata) |
57 | void *cbdata) |
58 | { |
58 | { |
59 | if (S_ISDIR(mode)) |
59 | if (baselen == match_baselen) { |
| |
60 | if (S_ISREG(mode)) |
| |
61 | print_object(sha1, pathname); |
| |
62 | } |
| |
63 | else if (S_ISDIR(mode)) |
60 | return READ_TREE_RECURSIVE; |
64 | return READ_TREE_RECURSIVE; |
61 | |
65 | |
62 | if (S_ISREG(mode) && !strncmp(base, match_path, baselen) && |
66 | return 0; |
63 | !strcmp(pathname, match_path + baselen)) |
67 | } |
64 | print_object(sha1, pathname); |
| |
65 | |
68 | |
| |
69 | static int basedir_len(const char *path) |
| |
70 | { |
| |
71 | char *p = strrchr(path, '/'); |
| |
72 | if (p) |
| |
73 | return p - path + 1; |
66 | return 0; |
74 | return 0; |
67 | } |
75 | } |
68 | |
76 | |
69 | void cgit_print_plain(struct cgit_context *ctx) |
77 | void cgit_print_plain(struct cgit_context *ctx) |
@@ -84,9 +92,9 @@ void cgit_print_plain(struct cgit_context *ctx) |
84 | if (!commit || parse_commit(commit)) { |
92 | if (!commit || parse_commit(commit)) { |
85 | html_status(404, "Not found", 0); |
93 | html_status(404, "Not found", 0); |
86 | return; |
94 | return; |
87 | } |
95 | } |
88 | match_path = ctx->qry.path; |
96 | match_baselen = basedir_len(paths[0]); |
89 | read_tree_recursive(commit->tree, "", 0, 0, paths, walk_tree, NULL); |
97 | read_tree_recursive(commit->tree, "", 0, 0, paths, walk_tree, NULL); |
90 | if (!match) |
98 | if (!match) |
91 | html_status(404, "Not found", 0); |
99 | html_status(404, "Not found", 0); |
92 | } |
100 | } |
|