summaryrefslogtreecommitdiffabout
path: root/cgit.c
authorLars Hjemli <hjemli@gmail.com>2006-12-28 01:01:49 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2006-12-28 01:01:49 (UTC)
commite39d738c39d37cdef115c145027f3eec85a62272 (patch) (unidiff)
treebe60a07674a0d118d42f572a35b62ada9529a6bd /cgit.c
parent27cd3b2a700e1cc46cd0393ddea48c07b62ee3a6 (diff)
downloadcgit-e39d738c39d37cdef115c145027f3eec85a62272.zip
cgit-e39d738c39d37cdef115c145027f3eec85a62272.tar.gz
cgit-e39d738c39d37cdef115c145027f3eec85a62272.tar.bz2
Add generic support for search box in page header
This adds the ability to show a search box in any pageheader with correct href and hidden form data, but does not enable the box on any pages. Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Diffstat (limited to 'cgit.c') (more/less context) (ignore whitespace changes)
-rw-r--r--cgit.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/cgit.c b/cgit.c
index ac43441..277b849 100644
--- a/cgit.c
+++ b/cgit.c
@@ -1,156 +1,156 @@
1/* cgit.c: cgi for the git scm 1/* cgit.c: cgi for the git scm
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 "cgit.h" 9#include "cgit.h"
10 10
11const char cgit_version[] = CGIT_VERSION; 11const char cgit_version[] = CGIT_VERSION;
12 12
13static void cgit_print_repo_page(struct cacheitem *item) 13static void cgit_print_repo_page(struct cacheitem *item)
14{ 14{
15 if (chdir(fmt("%s/%s", cgit_root, cgit_query_repo)) || 15 if (chdir(fmt("%s/%s", cgit_root, cgit_query_repo)) ||
16 cgit_read_config("info/cgit", cgit_repo_config_cb)) { 16 cgit_read_config("info/cgit", cgit_repo_config_cb)) {
17 char *title = fmt("%s - %s", cgit_root_title, "Bad request"); 17 char *title = fmt("%s - %s", cgit_root_title, "Bad request");
18 cgit_print_docstart(title, item); 18 cgit_print_docstart(title, item);
19 cgit_print_pageheader(title); 19 cgit_print_pageheader(title, 0);
20 cgit_print_error(fmt("Unable to scan repository: %s", 20 cgit_print_error(fmt("Unable to scan repository: %s",
21 strerror(errno))); 21 strerror(errno)));
22 cgit_print_docend(); 22 cgit_print_docend();
23 return; 23 return;
24 } 24 }
25 setenv("GIT_DIR", fmt("%s/%s", cgit_root, cgit_query_repo), 1); 25 setenv("GIT_DIR", fmt("%s/%s", cgit_root, cgit_query_repo), 1);
26 char *title = fmt("%s - %s", cgit_repo_name, cgit_repo_desc); 26 char *title = fmt("%s - %s", cgit_repo_name, cgit_repo_desc);
27 cgit_print_docstart(title, item); 27 cgit_print_docstart(title, item);
28 cgit_print_pageheader(title); 28 cgit_print_pageheader(title, 0);
29 if (!cgit_query_page) { 29 if (!cgit_query_page) {
30 cgit_print_summary(); 30 cgit_print_summary();
31 } else if (!strcmp(cgit_query_page, "log")) { 31 } else if (!strcmp(cgit_query_page, "log")) {
32 cgit_print_log(cgit_query_head, cgit_query_ofs, 100); 32 cgit_print_log(cgit_query_head, cgit_query_ofs, 100);
33 } else if (!strcmp(cgit_query_page, "tree")) { 33 } else if (!strcmp(cgit_query_page, "tree")) {
34 cgit_print_tree(cgit_query_sha1); 34 cgit_print_tree(cgit_query_sha1);
35 } else if (!strcmp(cgit_query_page, "commit")) { 35 } else if (!strcmp(cgit_query_page, "commit")) {
36 cgit_print_commit(cgit_query_sha1); 36 cgit_print_commit(cgit_query_sha1);
37 } else if (!strcmp(cgit_query_page, "view")) { 37 } else if (!strcmp(cgit_query_page, "view")) {
38 cgit_print_view(cgit_query_sha1); 38 cgit_print_view(cgit_query_sha1);
39 } else if (!strcmp(cgit_query_page, "diff")) { 39 } else if (!strcmp(cgit_query_page, "diff")) {
40 cgit_print_diff(cgit_query_sha1, cgit_query_sha2); 40 cgit_print_diff(cgit_query_sha1, cgit_query_sha2);
41 } 41 }
42 cgit_print_docend(); 42 cgit_print_docend();
43} 43}
44 44
45static void cgit_fill_cache(struct cacheitem *item) 45static void cgit_fill_cache(struct cacheitem *item)
46{ 46{
47 static char buf[PATH_MAX]; 47 static char buf[PATH_MAX];
48 48
49 getcwd(buf, sizeof(buf)); 49 getcwd(buf, sizeof(buf));
50 htmlfd = item->fd; 50 htmlfd = item->fd;
51 item->st.st_mtime = time(NULL); 51 item->st.st_mtime = time(NULL);
52 if (cgit_query_repo) 52 if (cgit_query_repo)
53 cgit_print_repo_page(item); 53 cgit_print_repo_page(item);
54 else 54 else
55 cgit_print_repolist(item); 55 cgit_print_repolist(item);
56 chdir(buf); 56 chdir(buf);
57} 57}
58 58
59static void cgit_check_cache(struct cacheitem *item) 59static void cgit_check_cache(struct cacheitem *item)
60{ 60{
61 int i = 0; 61 int i = 0;
62 62
63 cache_prepare(item); 63 cache_prepare(item);
64 top: 64 top:
65 if (++i > cgit_max_lock_attempts) { 65 if (++i > cgit_max_lock_attempts) {
66 die("cgit_refresh_cache: unable to lock %s: %s", 66 die("cgit_refresh_cache: unable to lock %s: %s",
67 item->name, strerror(errno)); 67 item->name, strerror(errno));
68 } 68 }
69 if (!cache_exist(item)) { 69 if (!cache_exist(item)) {
70 if (!cache_lock(item)) { 70 if (!cache_lock(item)) {
71 sleep(1); 71 sleep(1);
72 goto top; 72 goto top;
73 } 73 }
74 if (!cache_exist(item)) { 74 if (!cache_exist(item)) {
75 cgit_fill_cache(item); 75 cgit_fill_cache(item);
76 cache_unlock(item); 76 cache_unlock(item);
77 } else { 77 } else {
78 cache_cancel_lock(item); 78 cache_cancel_lock(item);
79 } 79 }
80 } else if (cache_expired(item) && cache_lock(item)) { 80 } else if (cache_expired(item) && cache_lock(item)) {
81 if (cache_expired(item)) { 81 if (cache_expired(item)) {
82 cgit_fill_cache(item); 82 cgit_fill_cache(item);
83 cache_unlock(item); 83 cache_unlock(item);
84 } else { 84 } else {
85 cache_cancel_lock(item); 85 cache_cancel_lock(item);
86 } 86 }
87 } 87 }
88} 88}
89 89
90static void cgit_print_cache(struct cacheitem *item) 90static void cgit_print_cache(struct cacheitem *item)
91{ 91{
92 static char buf[4096]; 92 static char buf[4096];
93 ssize_t i; 93 ssize_t i;
94 94
95 int fd = open(item->name, O_RDONLY); 95 int fd = open(item->name, O_RDONLY);
96 if (fd<0) 96 if (fd<0)
97 die("Unable to open cached file %s", item->name); 97 die("Unable to open cached file %s", item->name);
98 98
99 while((i=read(fd, buf, sizeof(buf))) > 0) 99 while((i=read(fd, buf, sizeof(buf))) > 0)
100 write(STDOUT_FILENO, buf, i); 100 write(STDOUT_FILENO, buf, i);
101 101
102 close(fd); 102 close(fd);
103} 103}
104 104
105static void cgit_parse_args(int argc, const char **argv) 105static void cgit_parse_args(int argc, const char **argv)
106{ 106{
107 int i; 107 int i;
108 108
109 for (i = 1; i < argc; i++) { 109 for (i = 1; i < argc; i++) {
110 if (!strncmp(argv[i], "--root=", 7)) { 110 if (!strncmp(argv[i], "--root=", 7)) {
111 cgit_root = xstrdup(argv[i]+7); 111 cgit_root = xstrdup(argv[i]+7);
112 } 112 }
113 if (!strncmp(argv[i], "--cache=", 8)) { 113 if (!strncmp(argv[i], "--cache=", 8)) {
114 cgit_cache_root = xstrdup(argv[i]+8); 114 cgit_cache_root = xstrdup(argv[i]+8);
115 } 115 }
116 if (!strcmp(argv[i], "--nocache")) { 116 if (!strcmp(argv[i], "--nocache")) {
117 cgit_nocache = 1; 117 cgit_nocache = 1;
118 } 118 }
119 if (!strncmp(argv[i], "--query=", 8)) { 119 if (!strncmp(argv[i], "--query=", 8)) {
120 cgit_querystring = xstrdup(argv[i]+8); 120 cgit_querystring = xstrdup(argv[i]+8);
121 } 121 }
122 if (!strncmp(argv[i], "--repo=", 7)) { 122 if (!strncmp(argv[i], "--repo=", 7)) {
123 cgit_query_repo = xstrdup(argv[i]+7); 123 cgit_query_repo = xstrdup(argv[i]+7);
124 } 124 }
125 if (!strncmp(argv[i], "--page=", 7)) { 125 if (!strncmp(argv[i], "--page=", 7)) {
126 cgit_query_page = xstrdup(argv[i]+7); 126 cgit_query_page = xstrdup(argv[i]+7);
127 } 127 }
128 if (!strncmp(argv[i], "--head=", 7)) { 128 if (!strncmp(argv[i], "--head=", 7)) {
129 cgit_query_head = xstrdup(argv[i]+7); 129 cgit_query_head = xstrdup(argv[i]+7);
130 cgit_query_has_symref = 1; 130 cgit_query_has_symref = 1;
131 } 131 }
132 if (!strncmp(argv[i], "--sha1=", 7)) { 132 if (!strncmp(argv[i], "--sha1=", 7)) {
133 cgit_query_sha1 = xstrdup(argv[i]+7); 133 cgit_query_sha1 = xstrdup(argv[i]+7);
134 cgit_query_has_sha1 = 1; 134 cgit_query_has_sha1 = 1;
135 } 135 }
136 if (!strncmp(argv[i], "--ofs=", 6)) { 136 if (!strncmp(argv[i], "--ofs=", 6)) {
137 cgit_query_ofs = atoi(argv[i]+6); 137 cgit_query_ofs = atoi(argv[i]+6);
138 } 138 }
139 } 139 }
140} 140}
141 141
142int main(int argc, const char **argv) 142int main(int argc, const char **argv)
143{ 143{
144 struct cacheitem item; 144 struct cacheitem item;
145 145
146 cgit_read_config("/etc/cgitrc", cgit_global_config_cb); 146 cgit_read_config("/etc/cgitrc", cgit_global_config_cb);
147 if (getenv("QUERY_STRING")) 147 if (getenv("QUERY_STRING"))
148 cgit_querystring = xstrdup(getenv("QUERY_STRING")); 148 cgit_querystring = xstrdup(getenv("QUERY_STRING"));
149 cgit_parse_args(argc, argv); 149 cgit_parse_args(argc, argv);
150 cgit_parse_query(cgit_querystring, cgit_querystring_cb); 150 cgit_parse_query(cgit_querystring, cgit_querystring_cb);
151 151
152 if (cgit_nocache) { 152 if (cgit_nocache) {
153 item.fd = STDOUT_FILENO; 153 item.fd = STDOUT_FILENO;
154 cgit_fill_cache(&item); 154 cgit_fill_cache(&item);
155 } else { 155 } else {
156 cgit_check_cache(&item); 156 cgit_check_cache(&item);