|
diff --git a/cgit.c b/cgit.c index 37cdb83..9dbc608 100644 --- a/ cgit.c+++ b/ cgit.c |
|
@@ -97,4 +97,41 @@ static void cgit_print_cache(struct cacheitem *item) |
97 | } |
97 | } |
98 | |
98 | |
| |
99 | static void cgit_parse_args(int argc, const char **argv) |
| |
100 | { |
| |
101 | int i; |
| |
102 | |
| |
103 | for (i = 1; i < argc; i++) { |
| |
104 | if (!strncmp(argv[i], "--root=", 7)) { |
| |
105 | cgit_root = xstrdup(argv[i]+7); |
| |
106 | } |
| |
107 | if (!strncmp(argv[i], "--cache=", 8)) { |
| |
108 | cgit_cache_root = xstrdup(argv[i]+8); |
| |
109 | } |
| |
110 | if (!strcmp(argv[i], "--nocache")) { |
| |
111 | cgit_nocache = 1; |
| |
112 | } |
| |
113 | if (!strncmp(argv[i], "--query=", 8)) { |
| |
114 | cgit_querystring = xstrdup(argv[i]+8); |
| |
115 | } |
| |
116 | if (!strncmp(argv[i], "--repo=", 7)) { |
| |
117 | cgit_query_repo = xstrdup(argv[i]+7); |
| |
118 | } |
| |
119 | if (!strncmp(argv[i], "--page=", 7)) { |
| |
120 | cgit_query_page = xstrdup(argv[i]+7); |
| |
121 | } |
| |
122 | if (!strncmp(argv[i], "--head=", 7)) { |
| |
123 | cgit_query_head = xstrdup(argv[i]+7); |
| |
124 | cgit_query_has_symref = 1; |
| |
125 | } |
| |
126 | if (!strncmp(argv[i], "--sha1=", 7)) { |
| |
127 | cgit_query_sha1 = xstrdup(argv[i]+7); |
| |
128 | cgit_query_has_sha1 = 1; |
| |
129 | } |
| |
130 | if (!strncmp(argv[i], "--ofs=", 6)) { |
| |
131 | cgit_query_ofs = atoi(argv[i]+6); |
| |
132 | } |
| |
133 | } |
| |
134 | } |
| |
135 | |
99 | int main(int argc, const char **argv) |
136 | int main(int argc, const char **argv) |
100 | { |
137 | { |
@@ -102,9 +139,16 @@ int main(int argc, const char **argv) |
102 | |
139 | |
103 | cgit_read_config("/etc/cgitrc", cgit_global_config_cb); |
140 | cgit_read_config("/etc/cgitrc", cgit_global_config_cb); |
104 | cgit_querystring = xstrdup(getenv("QUERY_STRING")); |
141 | if (getenv("QUERY_STRING")) |
| |
142 | cgit_querystring = xstrdup(getenv("QUERY_STRING")); |
| |
143 | cgit_parse_args(argc, argv); |
105 | cgit_parse_query(cgit_querystring, cgit_querystring_cb); |
144 | cgit_parse_query(cgit_querystring, cgit_querystring_cb); |
106 | |
145 | |
107 | cgit_check_cache(&item); |
146 | if (cgit_nocache) { |
108 | cgit_print_cache(&item); |
147 | item.fd = STDOUT_FILENO; |
| |
148 | cgit_fill_cache(&item); |
| |
149 | } else { |
| |
150 | cgit_check_cache(&item); |
| |
151 | cgit_print_cache(&item); |
| |
152 | } |
109 | return 0; |
153 | return 0; |
110 | } |
154 | } |
|