summaryrefslogtreecommitdiffabout
authorLars Hjemli <hjemli@gmail.com>2007-10-28 11:08:45 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2007-10-28 11:08:45 (UTC)
commit6ec5f36f279a85f59db2851ab476d9acd0015770 (patch) (unidiff)
tree18aff69bb319bbbf7427a1f401d86063ee850824
parent0c8dd9c4bcc7a1a7a49f4eca1f3eb869d0995ea2 (diff)
downloadcgit-6ec5f36f279a85f59db2851ab476d9acd0015770.zip
cgit-6ec5f36f279a85f59db2851ab476d9acd0015770.tar.gz
cgit-6ec5f36f279a85f59db2851ab476d9acd0015770.tar.bz2
Add html_option() function
This is a generic function used to output html "option" tags. Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--cgit.h1
-rw-r--r--html.c12
2 files changed, 13 insertions, 0 deletions
diff --git a/cgit.h b/cgit.h
index f8f0316..0baa679 100644
--- a/cgit.h
+++ b/cgit.h
@@ -111,166 +111,167 @@ struct refinfo {
111struct reflist { 111struct reflist {
112 struct refinfo **refs; 112 struct refinfo **refs;
113 int alloc; 113 int alloc;
114 int count; 114 int count;
115}; 115};
116 116
117extern const char *cgit_version; 117extern const char *cgit_version;
118 118
119extern struct repolist cgit_repolist; 119extern struct repolist cgit_repolist;
120extern struct repoinfo *cgit_repo; 120extern struct repoinfo *cgit_repo;
121extern int cgit_cmd; 121extern int cgit_cmd;
122 122
123extern char *cgit_root_title; 123extern char *cgit_root_title;
124extern char *cgit_css; 124extern char *cgit_css;
125extern char *cgit_logo; 125extern char *cgit_logo;
126extern char *cgit_index_header; 126extern char *cgit_index_header;
127extern char *cgit_logo_link; 127extern char *cgit_logo_link;
128extern char *cgit_module_link; 128extern char *cgit_module_link;
129extern char *cgit_agefile; 129extern char *cgit_agefile;
130extern char *cgit_virtual_root; 130extern char *cgit_virtual_root;
131extern char *cgit_script_name; 131extern char *cgit_script_name;
132extern char *cgit_cache_root; 132extern char *cgit_cache_root;
133extern char *cgit_repo_group; 133extern char *cgit_repo_group;
134 134
135extern int cgit_nocache; 135extern int cgit_nocache;
136extern int cgit_snapshots; 136extern int cgit_snapshots;
137extern int cgit_enable_index_links; 137extern int cgit_enable_index_links;
138extern int cgit_enable_log_filecount; 138extern int cgit_enable_log_filecount;
139extern int cgit_enable_log_linecount; 139extern int cgit_enable_log_linecount;
140extern int cgit_max_lock_attempts; 140extern int cgit_max_lock_attempts;
141extern int cgit_cache_root_ttl; 141extern int cgit_cache_root_ttl;
142extern int cgit_cache_repo_ttl; 142extern int cgit_cache_repo_ttl;
143extern int cgit_cache_dynamic_ttl; 143extern int cgit_cache_dynamic_ttl;
144extern int cgit_cache_static_ttl; 144extern int cgit_cache_static_ttl;
145extern int cgit_cache_max_create_time; 145extern int cgit_cache_max_create_time;
146extern int cgit_summary_log; 146extern int cgit_summary_log;
147extern int cgit_summary_tags; 147extern int cgit_summary_tags;
148extern int cgit_summary_branches; 148extern int cgit_summary_branches;
149 149
150extern int cgit_max_msg_len; 150extern int cgit_max_msg_len;
151extern int cgit_max_repodesc_len; 151extern int cgit_max_repodesc_len;
152extern int cgit_max_commit_count; 152extern int cgit_max_commit_count;
153 153
154extern int cgit_query_has_symref; 154extern int cgit_query_has_symref;
155extern int cgit_query_has_sha1; 155extern int cgit_query_has_sha1;
156 156
157extern char *cgit_querystring; 157extern char *cgit_querystring;
158extern char *cgit_query_repo; 158extern char *cgit_query_repo;
159extern char *cgit_query_page; 159extern char *cgit_query_page;
160extern char *cgit_query_search; 160extern char *cgit_query_search;
161extern char *cgit_query_head; 161extern char *cgit_query_head;
162extern char *cgit_query_sha1; 162extern char *cgit_query_sha1;
163extern char *cgit_query_sha2; 163extern char *cgit_query_sha2;
164extern char *cgit_query_path; 164extern char *cgit_query_path;
165extern char *cgit_query_name; 165extern char *cgit_query_name;
166extern int cgit_query_ofs; 166extern int cgit_query_ofs;
167 167
168extern int htmlfd; 168extern int htmlfd;
169 169
170extern int cgit_get_cmd_index(const char *cmd); 170extern int cgit_get_cmd_index(const char *cmd);
171extern struct repoinfo *cgit_get_repoinfo(const char *url); 171extern struct repoinfo *cgit_get_repoinfo(const char *url);
172extern void cgit_global_config_cb(const char *name, const char *value); 172extern void cgit_global_config_cb(const char *name, const char *value);
173extern void cgit_repo_config_cb(const char *name, const char *value); 173extern void cgit_repo_config_cb(const char *name, const char *value);
174extern void cgit_querystring_cb(const char *name, const char *value); 174extern void cgit_querystring_cb(const char *name, const char *value);
175 175
176extern int chk_zero(int result, char *msg); 176extern int chk_zero(int result, char *msg);
177extern int chk_positive(int result, char *msg); 177extern int chk_positive(int result, char *msg);
178extern int chk_non_negative(int result, char *msg); 178extern int chk_non_negative(int result, char *msg);
179 179
180extern int hextoint(char c); 180extern int hextoint(char c);
181extern char *trim_end(const char *str, char c); 181extern char *trim_end(const char *str, char c);
182 182
183extern void cgit_add_ref(struct reflist *list, struct refinfo *ref); 183extern void cgit_add_ref(struct reflist *list, struct refinfo *ref);
184extern int cgit_refs_cb(const char *refname, const unsigned char *sha1, 184extern int cgit_refs_cb(const char *refname, const unsigned char *sha1,
185 int flags, void *cb_data); 185 int flags, void *cb_data);
186 186
187extern void *cgit_free_commitinfo(struct commitinfo *info); 187extern void *cgit_free_commitinfo(struct commitinfo *info);
188 188
189extern int cgit_diff_files(const unsigned char *old_sha1, 189extern int cgit_diff_files(const unsigned char *old_sha1,
190 const unsigned char *new_sha1, 190 const unsigned char *new_sha1,
191 linediff_fn fn); 191 linediff_fn fn);
192 192
193extern void cgit_diff_tree(const unsigned char *old_sha1, 193extern void cgit_diff_tree(const unsigned char *old_sha1,
194 const unsigned char *new_sha1, 194 const unsigned char *new_sha1,
195 filepair_fn fn, const char *prefix); 195 filepair_fn fn, const char *prefix);
196 196
197extern void cgit_diff_commit(struct commit *commit, filepair_fn fn); 197extern void cgit_diff_commit(struct commit *commit, filepair_fn fn);
198 198
199extern char *fmt(const char *format,...); 199extern char *fmt(const char *format,...);
200 200
201extern void html(const char *txt); 201extern void html(const char *txt);
202extern void htmlf(const char *format,...); 202extern void htmlf(const char *format,...);
203extern void html_txt(char *txt); 203extern void html_txt(char *txt);
204extern void html_ntxt(int len, char *txt); 204extern void html_ntxt(int len, char *txt);
205extern void html_attr(char *txt); 205extern void html_attr(char *txt);
206extern void html_hidden(char *name, char *value); 206extern void html_hidden(char *name, char *value);
207extern void html_option(char *value, char *text, char *selected_value);
207extern void html_link_open(char *url, char *title, char *class); 208extern void html_link_open(char *url, char *title, char *class);
208extern void html_link_close(void); 209extern void html_link_close(void);
209extern void html_filemode(unsigned short mode); 210extern void html_filemode(unsigned short mode);
210extern int html_include(const char *filename); 211extern int html_include(const char *filename);
211 212
212extern int cgit_read_config(const char *filename, configfn fn); 213extern int cgit_read_config(const char *filename, configfn fn);
213extern int cgit_parse_query(char *txt, configfn fn); 214extern int cgit_parse_query(char *txt, configfn fn);
214extern struct commitinfo *cgit_parse_commit(struct commit *commit); 215extern struct commitinfo *cgit_parse_commit(struct commit *commit);
215extern struct taginfo *cgit_parse_tag(struct tag *tag); 216extern struct taginfo *cgit_parse_tag(struct tag *tag);
216extern void cgit_parse_url(const char *url); 217extern void cgit_parse_url(const char *url);
217 218
218extern char *cache_safe_filename(const char *unsafe); 219extern char *cache_safe_filename(const char *unsafe);
219extern int cache_lock(struct cacheitem *item); 220extern int cache_lock(struct cacheitem *item);
220extern int cache_unlock(struct cacheitem *item); 221extern int cache_unlock(struct cacheitem *item);
221extern int cache_cancel_lock(struct cacheitem *item); 222extern int cache_cancel_lock(struct cacheitem *item);
222extern int cache_exist(struct cacheitem *item); 223extern int cache_exist(struct cacheitem *item);
223extern int cache_expired(struct cacheitem *item); 224extern int cache_expired(struct cacheitem *item);
224 225
225extern char *cgit_repourl(const char *reponame); 226extern char *cgit_repourl(const char *reponame);
226extern char *cgit_fileurl(const char *reponame, const char *pagename, 227extern char *cgit_fileurl(const char *reponame, const char *pagename,
227 const char *filename, const char *query); 228 const char *filename, const char *query);
228extern char *cgit_pageurl(const char *reponame, const char *pagename, 229extern char *cgit_pageurl(const char *reponame, const char *pagename,
229 const char *query); 230 const char *query);
230 231
231extern const char *cgit_repobasename(const char *reponame); 232extern const char *cgit_repobasename(const char *reponame);
232 233
233extern void cgit_tree_link(char *name, char *title, char *class, char *head, 234extern void cgit_tree_link(char *name, char *title, char *class, char *head,
234 char *rev, char *path); 235 char *rev, char *path);
235extern void cgit_log_link(char *name, char *title, char *class, char *head, 236extern void cgit_log_link(char *name, char *title, char *class, char *head,
236 char *rev, char *path, int ofs); 237 char *rev, char *path, int ofs);
237extern void cgit_commit_link(char *name, char *title, char *class, char *head, 238extern void cgit_commit_link(char *name, char *title, char *class, char *head,
238 char *rev); 239 char *rev);
239extern void cgit_refs_link(char *name, char *title, char *class, char *head, 240extern void cgit_refs_link(char *name, char *title, char *class, char *head,
240 char *rev, char *path); 241 char *rev, char *path);
241extern void cgit_snapshot_link(char *name, char *title, char *class, 242extern void cgit_snapshot_link(char *name, char *title, char *class,
242 char *head, char *rev, char *archivename); 243 char *head, char *rev, char *archivename);
243extern void cgit_diff_link(char *name, char *title, char *class, char *head, 244extern void cgit_diff_link(char *name, char *title, char *class, char *head,
244 char *new_rev, char *old_rev, char *path); 245 char *new_rev, char *old_rev, char *path);
245 246
246extern void cgit_object_link(struct object *obj); 247extern void cgit_object_link(struct object *obj);
247 248
248extern void cgit_print_error(char *msg); 249extern void cgit_print_error(char *msg);
249extern void cgit_print_date(time_t secs, char *format); 250extern void cgit_print_date(time_t secs, char *format);
250extern void cgit_print_age(time_t t, time_t max_relative, char *format); 251extern void cgit_print_age(time_t t, time_t max_relative, char *format);
251extern void cgit_print_docstart(char *title, struct cacheitem *item); 252extern void cgit_print_docstart(char *title, struct cacheitem *item);
252extern void cgit_print_docend(); 253extern void cgit_print_docend();
253extern void cgit_print_pageheader(char *title, int show_search); 254extern void cgit_print_pageheader(char *title, int show_search);
254extern void cgit_print_snapshot_start(const char *mimetype, 255extern void cgit_print_snapshot_start(const char *mimetype,
255 const char *filename, 256 const char *filename,
256 struct cacheitem *item); 257 struct cacheitem *item);
257extern void cgit_print_branches(int maxcount); 258extern void cgit_print_branches(int maxcount);
258extern void cgit_print_tags(int maxcount); 259extern void cgit_print_tags(int maxcount);
259 260
260extern void cgit_print_repolist(struct cacheitem *item); 261extern void cgit_print_repolist(struct cacheitem *item);
261extern void cgit_print_summary(); 262extern void cgit_print_summary();
262extern void cgit_print_log(const char *tip, int ofs, int cnt, char *grep, char *path, int pager); 263extern void cgit_print_log(const char *tip, int ofs, int cnt, char *grep, char *path, int pager);
263extern void cgit_print_blob(struct cacheitem *item, const char *hex, char *path); 264extern void cgit_print_blob(struct cacheitem *item, const char *hex, char *path);
264extern void cgit_print_tree(const char *rev, char *path); 265extern void cgit_print_tree(const char *rev, char *path);
265extern void cgit_print_commit(char *hex); 266extern void cgit_print_commit(char *hex);
266extern void cgit_print_refs(); 267extern void cgit_print_refs();
267extern void cgit_print_tag(char *revname); 268extern void cgit_print_tag(char *revname);
268extern void cgit_print_diff(const char *new_hex, const char *old_hex, const char *prefix); 269extern void cgit_print_diff(const char *new_hex, const char *old_hex, const char *prefix);
269extern void cgit_print_snapshot(struct cacheitem *item, const char *head, 270extern void cgit_print_snapshot(struct cacheitem *item, const char *head,
270 const char *hex, const char *prefix, 271 const char *hex, const char *prefix,
271 const char *filename, int snapshot); 272 const char *filename, int snapshot);
272extern void cgit_print_snapshot_links(const char *repo, const char *head, 273extern void cgit_print_snapshot_links(const char *repo, const char *head,
273 const char *hex, int snapshots); 274 const char *hex, int snapshots);
274extern int cgit_parse_snapshots_mask(const char *str); 275extern int cgit_parse_snapshots_mask(const char *str);
275 276
276#endif /* CGIT_H */ 277#endif /* CGIT_H */
diff --git a/html.c b/html.c
index 76fa6c4..6c9cc8b 100644
--- a/html.c
+++ b/html.c
@@ -33,150 +33,162 @@ void html(const char *txt)
33 33
34void htmlf(const char *format, ...) 34void htmlf(const char *format, ...)
35{ 35{
36 static char buf[65536]; 36 static char buf[65536];
37 va_list args; 37 va_list args;
38 38
39 va_start(args, format); 39 va_start(args, format);
40 vsnprintf(buf, sizeof(buf), format, args); 40 vsnprintf(buf, sizeof(buf), format, args);
41 va_end(args); 41 va_end(args);
42 html(buf); 42 html(buf);
43} 43}
44 44
45void html_txt(char *txt) 45void html_txt(char *txt)
46{ 46{
47 char *t = txt; 47 char *t = txt;
48 while(t && *t){ 48 while(t && *t){
49 int c = *t; 49 int c = *t;
50 if (c=='<' || c=='>' || c=='&') { 50 if (c=='<' || c=='>' || c=='&') {
51 *t = '\0'; 51 *t = '\0';
52 html(txt); 52 html(txt);
53 *t = c; 53 *t = c;
54 if (c=='>') 54 if (c=='>')
55 html("&gt;"); 55 html("&gt;");
56 else if (c=='<') 56 else if (c=='<')
57 html("&lt;"); 57 html("&lt;");
58 else if (c=='&') 58 else if (c=='&')
59 html("&amp;"); 59 html("&amp;");
60 txt = t+1; 60 txt = t+1;
61 } 61 }
62 t++; 62 t++;
63 } 63 }
64 if (t!=txt) 64 if (t!=txt)
65 html(txt); 65 html(txt);
66} 66}
67 67
68void html_ntxt(int len, char *txt) 68void html_ntxt(int len, char *txt)
69{ 69{
70 char *t = txt; 70 char *t = txt;
71 while(t && *t && len--){ 71 while(t && *t && len--){
72 int c = *t; 72 int c = *t;
73 if (c=='<' || c=='>' || c=='&') { 73 if (c=='<' || c=='>' || c=='&') {
74 *t = '\0'; 74 *t = '\0';
75 html(txt); 75 html(txt);
76 *t = c; 76 *t = c;
77 if (c=='>') 77 if (c=='>')
78 html("&gt;"); 78 html("&gt;");
79 else if (c=='<') 79 else if (c=='<')
80 html("&lt;"); 80 html("&lt;");
81 else if (c=='&') 81 else if (c=='&')
82 html("&amp;"); 82 html("&amp;");
83 txt = t+1; 83 txt = t+1;
84 } 84 }
85 t++; 85 t++;
86 } 86 }
87 if (t!=txt) { 87 if (t!=txt) {
88 char c = *t; 88 char c = *t;
89 *t = '\0'; 89 *t = '\0';
90 html(txt); 90 html(txt);
91 *t = c; 91 *t = c;
92 } 92 }
93 if (len<0) 93 if (len<0)
94 html("..."); 94 html("...");
95} 95}
96 96
97void html_attr(char *txt) 97void html_attr(char *txt)
98{ 98{
99 char *t = txt; 99 char *t = txt;
100 while(t && *t){ 100 while(t && *t){
101 int c = *t; 101 int c = *t;
102 if (c=='<' || c=='>' || c=='\'') { 102 if (c=='<' || c=='>' || c=='\'') {
103 *t = '\0'; 103 *t = '\0';
104 html(txt); 104 html(txt);
105 *t = c; 105 *t = c;
106 if (c=='>') 106 if (c=='>')
107 html("&gt;"); 107 html("&gt;");
108 else if (c=='<') 108 else if (c=='<')
109 html("&lt;"); 109 html("&lt;");
110 else if (c=='\'') 110 else if (c=='\'')
111 html("&quote;"); 111 html("&quote;");
112 txt = t+1; 112 txt = t+1;
113 } 113 }
114 t++; 114 t++;
115 } 115 }
116 if (t!=txt) 116 if (t!=txt)
117 html(txt); 117 html(txt);
118} 118}
119 119
120void html_hidden(char *name, char *value) 120void html_hidden(char *name, char *value)
121{ 121{
122 html("<input type='hidden' name='"); 122 html("<input type='hidden' name='");
123 html_attr(name); 123 html_attr(name);
124 html("' value='"); 124 html("' value='");
125 html_attr(value); 125 html_attr(value);
126 html("'/>"); 126 html("'/>");
127} 127}
128 128
129void html_option(char *value, char *text, char *selected_value)
130{
131 html("<option value='");
132 html_attr(value);
133 html("'");
134 if (selected_value && !strcmp(selected_value, value))
135 html(" selected");
136 html(">");
137 html_txt(text);
138 html("</option>\n");
139}
140
129void html_link_open(char *url, char *title, char *class) 141void html_link_open(char *url, char *title, char *class)
130{ 142{
131 html("<a href='"); 143 html("<a href='");
132 html_attr(url); 144 html_attr(url);
133 if (title) { 145 if (title) {
134 html("' title='"); 146 html("' title='");
135 html_attr(title); 147 html_attr(title);
136 } 148 }
137 if (class) { 149 if (class) {
138 html("' class='"); 150 html("' class='");
139 html_attr(class); 151 html_attr(class);
140 } 152 }
141 html("'>"); 153 html("'>");
142} 154}
143 155
144void html_link_close(void) 156void html_link_close(void)
145{ 157{
146 html("</a>"); 158 html("</a>");
147} 159}
148 160
149void html_fileperm(unsigned short mode) 161void html_fileperm(unsigned short mode)
150{ 162{
151 htmlf("%c%c%c", (mode & 4 ? 'r' : '-'), 163 htmlf("%c%c%c", (mode & 4 ? 'r' : '-'),
152 (mode & 2 ? 'w' : '-'), (mode & 1 ? 'x' : '-')); 164 (mode & 2 ? 'w' : '-'), (mode & 1 ? 'x' : '-'));
153} 165}
154 166
155void html_filemode(unsigned short mode) 167void html_filemode(unsigned short mode)
156{ 168{
157 if (S_ISDIR(mode)) 169 if (S_ISDIR(mode))
158 html("d"); 170 html("d");
159 else if (S_ISLNK(mode)) 171 else if (S_ISLNK(mode))
160 html("l"); 172 html("l");
161 else if (S_ISGITLINK(mode)) 173 else if (S_ISGITLINK(mode))
162 html("m"); 174 html("m");
163 else 175 else
164 html("-"); 176 html("-");
165 html_fileperm(mode >> 6); 177 html_fileperm(mode >> 6);
166 html_fileperm(mode >> 3); 178 html_fileperm(mode >> 3);
167 html_fileperm(mode); 179 html_fileperm(mode);
168} 180}
169 181
170int html_include(const char *filename) 182int html_include(const char *filename)
171{ 183{
172 FILE *f; 184 FILE *f;
173 char buf[4096]; 185 char buf[4096];
174 size_t len; 186 size_t len;
175 187
176 if (!(f = fopen(filename, "r"))) 188 if (!(f = fopen(filename, "r")))
177 return -1; 189 return -1;
178 while((len = fread(buf, 1, 4096, f)) > 0) 190 while((len = fread(buf, 1, 4096, f)) > 0)
179 write(htmlfd, buf, len); 191 write(htmlfd, buf, len);
180 fclose(f); 192 fclose(f);
181 return 0; 193 return 0;
182} 194}