|
diff --git a/cgit.c b/cgit.c index 30a9a2a..52d9bd3 100644 --- a/ cgit.c+++ b/ cgit.c |
|
@@ -63,102 +63,70 @@ void cgit_repo_config_cb(const char *name, const char *value) |
63 | { |
63 | { |
64 | if (!strcmp(name, "name")) |
64 | if (!strcmp(name, "name")) |
65 | cgit_repo_name = xstrdup(value); |
65 | cgit_repo_name = xstrdup(value); |
66 | else if (!strcmp(name, "desc")) |
66 | else if (!strcmp(name, "desc")) |
67 | cgit_repo_desc = xstrdup(value); |
67 | cgit_repo_desc = xstrdup(value); |
68 | else if (!strcmp(name, "owner")) |
68 | else if (!strcmp(name, "owner")) |
69 | cgit_repo_owner = xstrdup(value); |
69 | cgit_repo_owner = xstrdup(value); |
70 | } |
70 | } |
71 | |
71 | |
72 | void cgit_querystring_cb(const char *name, const char *value) |
72 | void cgit_querystring_cb(const char *name, const char *value) |
73 | { |
73 | { |
74 | if (!strcmp(name,"r")) |
74 | if (!strcmp(name,"r")) |
75 | cgit_query_repo = xstrdup(value); |
75 | cgit_query_repo = xstrdup(value); |
76 | else if (!strcmp(name, "p")) |
76 | else if (!strcmp(name, "p")) |
77 | cgit_query_page = xstrdup(value); |
77 | cgit_query_page = xstrdup(value); |
78 | else if (!strcmp(name, "h")) { |
78 | else if (!strcmp(name, "h")) { |
79 | cgit_query_head = xstrdup(value); |
79 | cgit_query_head = xstrdup(value); |
80 | cgit_query_has_symref = 1; |
80 | cgit_query_has_symref = 1; |
81 | } else if (!strcmp(name, "id")) { |
81 | } else if (!strcmp(name, "id")) { |
82 | cgit_query_sha1 = xstrdup(value); |
82 | cgit_query_sha1 = xstrdup(value); |
83 | cgit_query_has_sha1 = 1; |
83 | cgit_query_has_sha1 = 1; |
84 | } |
84 | } |
85 | } |
85 | } |
86 | |
86 | |
87 | static void cgit_print_object(char *hex) |
| |
88 | { |
| |
89 | unsigned char sha1[20]; |
| |
90 | //struct object *object; |
| |
91 | char type[20]; |
| |
92 | unsigned char *buf; |
| |
93 | unsigned long size; |
| |
94 | |
| |
95 | if (get_sha1_hex(hex, sha1)){ |
| |
96 | cgit_print_error(fmt("Bad hex value: %s", hex)); |
| |
97 | return; |
| |
98 | } |
| |
99 | |
| |
100 | if (sha1_object_info(sha1, type, NULL)){ |
| |
101 | cgit_print_error("Bad object name"); |
| |
102 | return; |
| |
103 | } |
| |
104 | |
| |
105 | buf = read_sha1_file(sha1, type, &size); |
| |
106 | if (!buf) { |
| |
107 | cgit_print_error("Error reading object"); |
| |
108 | return; |
| |
109 | } |
| |
110 | |
| |
111 | buf[size] = '\0'; |
| |
112 | html("<h2>Object view</h2>"); |
| |
113 | htmlf("sha1=%s<br/>type=%s<br/>size=%i<br/>", hex, type, size); |
| |
114 | html("<pre>"); |
| |
115 | html_txt(buf); |
| |
116 | html("</pre>"); |
| |
117 | } |
| |
118 | |
| |
119 | static void cgit_print_repo_page(struct cacheitem *item) |
87 | static void cgit_print_repo_page(struct cacheitem *item) |
120 | { |
88 | { |
121 | if (chdir(fmt("%s/%s", cgit_root, cgit_query_repo)) || |
89 | if (chdir(fmt("%s/%s", cgit_root, cgit_query_repo)) || |
122 | cgit_read_config("info/cgit", cgit_repo_config_cb)) { |
90 | cgit_read_config("info/cgit", cgit_repo_config_cb)) { |
123 | char *title = fmt("%s - %s", cgit_root_title, "Bad request"); |
91 | char *title = fmt("%s - %s", cgit_root_title, "Bad request"); |
124 | cgit_print_docstart(title, item); |
92 | cgit_print_docstart(title, item); |
125 | cgit_print_pageheader(title); |
93 | cgit_print_pageheader(title); |
126 | cgit_print_error(fmt("Unable to scan repository: %s", |
94 | cgit_print_error(fmt("Unable to scan repository: %s", |
127 | strerror(errno))); |
95 | strerror(errno))); |
128 | cgit_print_docend(); |
96 | cgit_print_docend(); |
129 | return; |
97 | return; |
130 | } |
98 | } |
131 | setenv("GIT_DIR", fmt("%s/%s", cgit_root, cgit_query_repo), 1); |
99 | setenv("GIT_DIR", fmt("%s/%s", cgit_root, cgit_query_repo), 1); |
132 | char *title = fmt("%s - %s", cgit_repo_name, cgit_repo_desc); |
100 | char *title = fmt("%s - %s", cgit_repo_name, cgit_repo_desc); |
133 | cgit_print_docstart(title, item); |
101 | cgit_print_docstart(title, item); |
134 | cgit_print_pageheader(title); |
102 | cgit_print_pageheader(title); |
135 | if (!cgit_query_page) |
103 | if (!cgit_query_page) |
136 | cgit_print_summary(); |
104 | cgit_print_summary(); |
137 | else if (!strcmp(cgit_query_page, "log")) { |
105 | else if (!strcmp(cgit_query_page, "log")) { |
138 | cgit_print_log(cgit_query_head, 0, 100); |
106 | cgit_print_log(cgit_query_head, 0, 100); |
139 | } else if (!strcmp(cgit_query_page, "view")) { |
107 | } else if (!strcmp(cgit_query_page, "view")) { |
140 | cgit_print_object(cgit_query_sha1); |
108 | cgit_print_view(cgit_query_sha1); |
141 | } |
109 | } |
142 | cgit_print_docend(); |
110 | cgit_print_docend(); |
143 | } |
111 | } |
144 | |
112 | |
145 | static void cgit_fill_cache(struct cacheitem *item) |
113 | static void cgit_fill_cache(struct cacheitem *item) |
146 | { |
114 | { |
147 | htmlfd = item->fd; |
115 | htmlfd = item->fd; |
148 | item->st.st_mtime = time(NULL); |
116 | item->st.st_mtime = time(NULL); |
149 | if (cgit_query_repo) |
117 | if (cgit_query_repo) |
150 | cgit_print_repo_page(item); |
118 | cgit_print_repo_page(item); |
151 | else |
119 | else |
152 | cgit_print_repolist(item); |
120 | cgit_print_repolist(item); |
153 | } |
121 | } |
154 | |
122 | |
155 | static void cgit_refresh_cache(struct cacheitem *item) |
123 | static void cgit_refresh_cache(struct cacheitem *item) |
156 | { |
124 | { |
157 | int i = 0; |
125 | int i = 0; |
158 | |
126 | |
159 | cache_prepare(item); |
127 | cache_prepare(item); |
160 | top: |
128 | top: |
161 | if (++i > cgit_max_lock_attempts) { |
129 | if (++i > cgit_max_lock_attempts) { |
162 | die("cgit_refresh_cache: unable to lock %s: %s", |
130 | die("cgit_refresh_cache: unable to lock %s: %s", |
163 | item->name, strerror(errno)); |
131 | item->name, strerror(errno)); |
164 | } |
132 | } |
|