summaryrefslogtreecommitdiffabout
authorHarley Laue <losinggeneration@aim.com>2008-04-29 15:59:53 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2008-04-29 15:59:53 (UTC)
commit112b2080626c62fff27cf8aaa9ac2fb07eb50b74 (patch) (unidiff)
treed683b43290e997a713c935c5163ca7cfcaaa3f3d
parent905dbaef5aa33ea11d385b82de0188fee73dd655 (diff)
downloadcgit-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>
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--html.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/html.c b/html.c
index 937b5e7..bddb04d 100644
--- a/html.c
+++ b/html.c
@@ -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
15int htmlfd = STDOUT_FILENO; 16int htmlfd = STDOUT_FILENO;
16 17
17char *fmt(const char *format, ...) 18char *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
37void html(const char *txt) 38void html(const char *txt)
38{ 39{
39 write(htmlfd, txt, strlen(txt)); 40 write(htmlfd, txt, strlen(txt));
40} 41}
41 42
42void htmlf(const char *format, ...) 43void 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
53void html_txt(char *txt) 54void 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("&gt;"); 62 html("&gt;");
62 else if (c=='<') 63 else if (c=='<')
63 html("&lt;"); 64 html("&lt;");
64 else if (c=='&') 65 else if (c=='&')
65 html("&amp;"); 66 html("&amp;");
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
74void html_ntxt(int len, char *txt) 75void 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("&gt;"); 83 html("&gt;");
83 else if (c=='<') 84 else if (c=='<')
84 html("&lt;"); 85 html("&lt;");
85 else if (c=='&') 86 else if (c=='&')
86 html("&amp;"); 87 html("&amp;");
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
97void html_attr(char *txt) 98void 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("&gt;"); 106 html("&gt;");
106 else if (c=='<') 107 else if (c=='<')
107 html("&lt;"); 108 html("&lt;");
108 else if (c=='\'') 109 else if (c=='\'')
109 html("&quote;"); 110 html("&quote;");
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
118void html_hidden(char *name, char *value) 119void 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
127void html_option(char *value, char *text, char *selected_value) 128void 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
139void html_link_open(char *url, char *title, char *class) 140void 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
154void html_link_close(void) 155void html_link_close(void)
155{ 156{
156 html("</a>"); 157 html("</a>");
157} 158}
158 159
159void html_fileperm(unsigned short mode) 160void 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
165int html_include(const char *filename) 166int 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
179int hextoint(char c) 183int 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
191char *convert_query_hexchar(char *txt) 195char *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
210int http_parse_querystring(char *txt, void (*fn)(const char *name, const char *value)) 214int 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}