author | Harley Laue <losinggeneration@aim.com> | 2008-04-29 15:59:53 (UTC) |
---|---|---|
committer | Lars Hjemli <hjemli@gmail.com> | 2008-04-29 15:59:53 (UTC) |
commit | 112b2080626c62fff27cf8aaa9ac2fb07eb50b74 (patch) (unidiff) | |
tree | d683b43290e997a713c935c5163ca7cfcaaa3f3d | |
parent | 905dbaef5aa33ea11d385b82de0188fee73dd655 (diff) | |
download | cgit-112b2080626c62fff27cf8aaa9ac2fb07eb50b74.zip cgit-112b2080626c62fff27cf8aaa9ac2fb07eb50b74.tar.gz cgit-112b2080626c62fff27cf8aaa9ac2fb07eb50b74.tar.bz2 |
Print an error if filename is not found in html_include.
Normally when html_include cannot open the file it fails silently and
things can be a bit hard to figure out from just looking at apache's
log. This will be beneficial for those initially setting up their server
with cgit.
Signed-off-by: Harley Laue <losinggeneration@aim.com>
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
-rw-r--r-- | html.c | 6 |
1 files changed, 5 insertions, 1 deletions
@@ -1,241 +1,245 @@ | |||
1 | /* html.c: helper functions for html output | 1 | /* html.c: helper functions for html output |
2 | * | 2 | * |
3 | * Copyright (C) 2006 Lars Hjemli | 3 | * Copyright (C) 2006 Lars Hjemli |
4 | * | 4 | * |
5 | * Licensed under GNU General Public License v2 | 5 | * Licensed under GNU General Public License v2 |
6 | * (see COPYING for full license text) | 6 | * (see COPYING for full license text) |
7 | */ | 7 | */ |
8 | 8 | ||
9 | #include <unistd.h> | 9 | #include <unistd.h> |
10 | #include <stdio.h> | 10 | #include <stdio.h> |
11 | #include <stdlib.h> | 11 | #include <stdlib.h> |
12 | #include <stdarg.h> | 12 | #include <stdarg.h> |
13 | #include <string.h> | 13 | #include <string.h> |
14 | #include <errno.h> | ||
14 | 15 | ||
15 | int htmlfd = STDOUT_FILENO; | 16 | int htmlfd = STDOUT_FILENO; |
16 | 17 | ||
17 | char *fmt(const char *format, ...) | 18 | char *fmt(const char *format, ...) |
18 | { | 19 | { |
19 | static char buf[8][1024]; | 20 | static char buf[8][1024]; |
20 | static int bufidx; | 21 | static int bufidx; |
21 | int len; | 22 | int len; |
22 | va_list args; | 23 | va_list args; |
23 | 24 | ||
24 | bufidx++; | 25 | bufidx++; |
25 | bufidx &= 7; | 26 | bufidx &= 7; |
26 | 27 | ||
27 | va_start(args, format); | 28 | va_start(args, format); |
28 | len = vsnprintf(buf[bufidx], sizeof(buf[bufidx]), format, args); | 29 | len = vsnprintf(buf[bufidx], sizeof(buf[bufidx]), format, args); |
29 | va_end(args); | 30 | va_end(args); |
30 | if (len>sizeof(buf[bufidx])) { | 31 | if (len>sizeof(buf[bufidx])) { |
31 | fprintf(stderr, "[html.c] string truncated: %s\n", format); | 32 | fprintf(stderr, "[html.c] string truncated: %s\n", format); |
32 | exit(1); | 33 | exit(1); |
33 | } | 34 | } |
34 | return buf[bufidx]; | 35 | return buf[bufidx]; |
35 | } | 36 | } |
36 | 37 | ||
37 | void html(const char *txt) | 38 | void html(const char *txt) |
38 | { | 39 | { |
39 | write(htmlfd, txt, strlen(txt)); | 40 | write(htmlfd, txt, strlen(txt)); |
40 | } | 41 | } |
41 | 42 | ||
42 | void htmlf(const char *format, ...) | 43 | void htmlf(const char *format, ...) |
43 | { | 44 | { |
44 | static char buf[65536]; | 45 | static char buf[65536]; |
45 | va_list args; | 46 | va_list args; |
46 | 47 | ||
47 | va_start(args, format); | 48 | va_start(args, format); |
48 | vsnprintf(buf, sizeof(buf), format, args); | 49 | vsnprintf(buf, sizeof(buf), format, args); |
49 | va_end(args); | 50 | va_end(args); |
50 | html(buf); | 51 | html(buf); |
51 | } | 52 | } |
52 | 53 | ||
53 | void html_txt(char *txt) | 54 | void html_txt(char *txt) |
54 | { | 55 | { |
55 | char *t = txt; | 56 | char *t = txt; |
56 | while(t && *t){ | 57 | while(t && *t){ |
57 | int c = *t; | 58 | int c = *t; |
58 | if (c=='<' || c=='>' || c=='&') { | 59 | if (c=='<' || c=='>' || c=='&') { |
59 | write(htmlfd, txt, t - txt); | 60 | write(htmlfd, txt, t - txt); |
60 | if (c=='>') | 61 | if (c=='>') |
61 | html(">"); | 62 | html(">"); |
62 | else if (c=='<') | 63 | else if (c=='<') |
63 | html("<"); | 64 | html("<"); |
64 | else if (c=='&') | 65 | else if (c=='&') |
65 | html("&"); | 66 | html("&"); |
66 | txt = t+1; | 67 | txt = t+1; |
67 | } | 68 | } |
68 | t++; | 69 | t++; |
69 | } | 70 | } |
70 | if (t!=txt) | 71 | if (t!=txt) |
71 | html(txt); | 72 | html(txt); |
72 | } | 73 | } |
73 | 74 | ||
74 | void html_ntxt(int len, char *txt) | 75 | void html_ntxt(int len, char *txt) |
75 | { | 76 | { |
76 | char *t = txt; | 77 | char *t = txt; |
77 | while(t && *t && len--){ | 78 | while(t && *t && len--){ |
78 | int c = *t; | 79 | int c = *t; |
79 | if (c=='<' || c=='>' || c=='&') { | 80 | if (c=='<' || c=='>' || c=='&') { |
80 | write(htmlfd, txt, t - txt); | 81 | write(htmlfd, txt, t - txt); |
81 | if (c=='>') | 82 | if (c=='>') |
82 | html(">"); | 83 | html(">"); |
83 | else if (c=='<') | 84 | else if (c=='<') |
84 | html("<"); | 85 | html("<"); |
85 | else if (c=='&') | 86 | else if (c=='&') |
86 | html("&"); | 87 | html("&"); |
87 | txt = t+1; | 88 | txt = t+1; |
88 | } | 89 | } |
89 | t++; | 90 | t++; |
90 | } | 91 | } |
91 | if (t!=txt) | 92 | if (t!=txt) |
92 | write(htmlfd, txt, t - txt); | 93 | write(htmlfd, txt, t - txt); |
93 | if (len<0) | 94 | if (len<0) |
94 | html("..."); | 95 | html("..."); |
95 | } | 96 | } |
96 | 97 | ||
97 | void html_attr(char *txt) | 98 | void html_attr(char *txt) |
98 | { | 99 | { |
99 | char *t = txt; | 100 | char *t = txt; |
100 | while(t && *t){ | 101 | while(t && *t){ |
101 | int c = *t; | 102 | int c = *t; |
102 | if (c=='<' || c=='>' || c=='\'') { | 103 | if (c=='<' || c=='>' || c=='\'') { |
103 | write(htmlfd, txt, t - txt); | 104 | write(htmlfd, txt, t - txt); |
104 | if (c=='>') | 105 | if (c=='>') |
105 | html(">"); | 106 | html(">"); |
106 | else if (c=='<') | 107 | else if (c=='<') |
107 | html("<"); | 108 | html("<"); |
108 | else if (c=='\'') | 109 | else if (c=='\'') |
109 | html(""e;"); | 110 | html(""e;"); |
110 | txt = t+1; | 111 | txt = t+1; |
111 | } | 112 | } |
112 | t++; | 113 | t++; |
113 | } | 114 | } |
114 | if (t!=txt) | 115 | if (t!=txt) |
115 | html(txt); | 116 | html(txt); |
116 | } | 117 | } |
117 | 118 | ||
118 | void html_hidden(char *name, char *value) | 119 | void html_hidden(char *name, char *value) |
119 | { | 120 | { |
120 | html("<input type='hidden' name='"); | 121 | html("<input type='hidden' name='"); |
121 | html_attr(name); | 122 | html_attr(name); |
122 | html("' value='"); | 123 | html("' value='"); |
123 | html_attr(value); | 124 | html_attr(value); |
124 | html("'/>"); | 125 | html("'/>"); |
125 | } | 126 | } |
126 | 127 | ||
127 | void html_option(char *value, char *text, char *selected_value) | 128 | void html_option(char *value, char *text, char *selected_value) |
128 | { | 129 | { |
129 | html("<option value='"); | 130 | html("<option value='"); |
130 | html_attr(value); | 131 | html_attr(value); |
131 | html("'"); | 132 | html("'"); |
132 | if (selected_value && !strcmp(selected_value, value)) | 133 | if (selected_value && !strcmp(selected_value, value)) |
133 | html(" selected='selected'"); | 134 | html(" selected='selected'"); |
134 | html(">"); | 135 | html(">"); |
135 | html_txt(text); | 136 | html_txt(text); |
136 | html("</option>\n"); | 137 | html("</option>\n"); |
137 | } | 138 | } |
138 | 139 | ||
139 | void html_link_open(char *url, char *title, char *class) | 140 | void html_link_open(char *url, char *title, char *class) |
140 | { | 141 | { |
141 | html("<a href='"); | 142 | html("<a href='"); |
142 | html_attr(url); | 143 | html_attr(url); |
143 | if (title) { | 144 | if (title) { |
144 | html("' title='"); | 145 | html("' title='"); |
145 | html_attr(title); | 146 | html_attr(title); |
146 | } | 147 | } |
147 | if (class) { | 148 | if (class) { |
148 | html("' class='"); | 149 | html("' class='"); |
149 | html_attr(class); | 150 | html_attr(class); |
150 | } | 151 | } |
151 | html("'>"); | 152 | html("'>"); |
152 | } | 153 | } |
153 | 154 | ||
154 | void html_link_close(void) | 155 | void html_link_close(void) |
155 | { | 156 | { |
156 | html("</a>"); | 157 | html("</a>"); |
157 | } | 158 | } |
158 | 159 | ||
159 | void html_fileperm(unsigned short mode) | 160 | void html_fileperm(unsigned short mode) |
160 | { | 161 | { |
161 | htmlf("%c%c%c", (mode & 4 ? 'r' : '-'), | 162 | htmlf("%c%c%c", (mode & 4 ? 'r' : '-'), |
162 | (mode & 2 ? 'w' : '-'), (mode & 1 ? 'x' : '-')); | 163 | (mode & 2 ? 'w' : '-'), (mode & 1 ? 'x' : '-')); |
163 | } | 164 | } |
164 | 165 | ||
165 | int html_include(const char *filename) | 166 | int html_include(const char *filename) |
166 | { | 167 | { |
167 | FILE *f; | 168 | FILE *f; |
168 | char buf[4096]; | 169 | char buf[4096]; |
169 | size_t len; | 170 | size_t len; |
170 | 171 | ||
171 | if (!(f = fopen(filename, "r"))) | 172 | if (!(f = fopen(filename, "r"))) { |
173 | fprintf(stderr, "[cgit] Failed to include file %s: %s (%d).\n", | ||
174 | filename, strerror(errno), errno); | ||
172 | return -1; | 175 | return -1; |
176 | } | ||
173 | while((len = fread(buf, 1, 4096, f)) > 0) | 177 | while((len = fread(buf, 1, 4096, f)) > 0) |
174 | write(htmlfd, buf, len); | 178 | write(htmlfd, buf, len); |
175 | fclose(f); | 179 | fclose(f); |
176 | return 0; | 180 | return 0; |
177 | } | 181 | } |
178 | 182 | ||
179 | int hextoint(char c) | 183 | int hextoint(char c) |
180 | { | 184 | { |
181 | if (c >= 'a' && c <= 'f') | 185 | if (c >= 'a' && c <= 'f') |
182 | return 10 + c - 'a'; | 186 | return 10 + c - 'a'; |
183 | else if (c >= 'A' && c <= 'F') | 187 | else if (c >= 'A' && c <= 'F') |
184 | return 10 + c - 'A'; | 188 | return 10 + c - 'A'; |
185 | else if (c >= '0' && c <= '9') | 189 | else if (c >= '0' && c <= '9') |
186 | return c - '0'; | 190 | return c - '0'; |
187 | else | 191 | else |
188 | return -1; | 192 | return -1; |
189 | } | 193 | } |
190 | 194 | ||
191 | char *convert_query_hexchar(char *txt) | 195 | char *convert_query_hexchar(char *txt) |
192 | { | 196 | { |
193 | int d1, d2; | 197 | int d1, d2; |
194 | if (strlen(txt) < 3) { | 198 | if (strlen(txt) < 3) { |
195 | *txt = '\0'; | 199 | *txt = '\0'; |
196 | return txt-1; | 200 | return txt-1; |
197 | } | 201 | } |
198 | d1 = hextoint(*(txt+1)); | 202 | d1 = hextoint(*(txt+1)); |
199 | d2 = hextoint(*(txt+2)); | 203 | d2 = hextoint(*(txt+2)); |
200 | if (d1<0 || d2<0) { | 204 | if (d1<0 || d2<0) { |
201 | strcpy(txt, txt+3); | 205 | strcpy(txt, txt+3); |
202 | return txt-1; | 206 | return txt-1; |
203 | } else { | 207 | } else { |
204 | *txt = d1 * 16 + d2; | 208 | *txt = d1 * 16 + d2; |
205 | strcpy(txt+1, txt+3); | 209 | strcpy(txt+1, txt+3); |
206 | return txt; | 210 | return txt; |
207 | } | 211 | } |
208 | } | 212 | } |
209 | 213 | ||
210 | int http_parse_querystring(char *txt, void (*fn)(const char *name, const char *value)) | 214 | int http_parse_querystring(char *txt, void (*fn)(const char *name, const char *value)) |
211 | { | 215 | { |
212 | char *t, *value = NULL, c; | 216 | char *t, *value = NULL, c; |
213 | 217 | ||
214 | if (!txt) | 218 | if (!txt) |
215 | return 0; | 219 | return 0; |
216 | 220 | ||
217 | t = txt = strdup(txt); | 221 | t = txt = strdup(txt); |
218 | if (t == NULL) { | 222 | if (t == NULL) { |
219 | printf("Out of memory\n"); | 223 | printf("Out of memory\n"); |
220 | exit(1); | 224 | exit(1); |
221 | } | 225 | } |
222 | while((c=*t) != '\0') { | 226 | while((c=*t) != '\0') { |
223 | if (c=='=') { | 227 | if (c=='=') { |
224 | *t = '\0'; | 228 | *t = '\0'; |
225 | value = t+1; | 229 | value = t+1; |
226 | } else if (c=='+') { | 230 | } else if (c=='+') { |
227 | *t = ' '; | 231 | *t = ' '; |
228 | } else if (c=='%') { | 232 | } else if (c=='%') { |
229 | t = convert_query_hexchar(t); | 233 | t = convert_query_hexchar(t); |
230 | } else if (c=='&') { | 234 | } else if (c=='&') { |
231 | *t = '\0'; | 235 | *t = '\0'; |
232 | (*fn)(txt, value); | 236 | (*fn)(txt, value); |
233 | txt = t+1; | 237 | txt = t+1; |
234 | value = NULL; | 238 | value = NULL; |
235 | } | 239 | } |
236 | t++; | 240 | t++; |
237 | } | 241 | } |
238 | if (t!=txt) | 242 | if (t!=txt) |
239 | (*fn)(txt, value); | 243 | (*fn)(txt, value); |
240 | return 0; | 244 | return 0; |
241 | } | 245 | } |