- if (chdir(cgit_query_repo) ||
- cgit_read_config(".git/info/cgit", cgit_repo_config_cb)) {
- char *title = fmt("%s - %s", cgit_root_title, "Bad request");
- cgit_print_docstart(title);
- cgit_print_pageheader(title);
- htmlf(cgit_lib_error, "Unable to scan repository",
- strerror(errno));
- cgit_print_docend();
- return;
- }
-
- char *title = fmt("%s - %s", cgit_repo_name, cgit_repo_desc);
- cgit_print_docstart(title);
- cgit_print_pageheader(title);
- if (!cgit_query_page)
- cgit_print_repo_summary();
- else if (!strcmp(cgit_query_page, "log")) {
- cgit_print_log(cgit_query_head, 0, 100);
- } else if (!strcmp(cgit_query_page, "view")) {
- cgit_print_object(cgit_query_head);
+ int i;
+
+ for (i = 1; i < argc; i++) {
+ if (!strncmp(argv[i], "--cache=", 8)) {
+ cgit_cache_root = xstrdup(argv[i]+8);
+ }
+ if (!strcmp(argv[i], "--nocache")) {
+ cgit_nocache = 1;
+ }
+ if (!strncmp(argv[i], "--query=", 8)) {
+ cgit_querystring = xstrdup(argv[i]+8);
+ }
+ if (!strncmp(argv[i], "--repo=", 7)) {
+ cgit_query_repo = xstrdup(argv[i]+7);
+ }
+ if (!strncmp(argv[i], "--page=", 7)) {
+ cgit_query_page = xstrdup(argv[i]+7);
+ }
+ if (!strncmp(argv[i], "--head=", 7)) {
+ cgit_query_head = xstrdup(argv[i]+7);
+ cgit_query_has_symref = 1;
+ }
+ if (!strncmp(argv[i], "--sha1=", 7)) {
+ cgit_query_sha1 = xstrdup(argv[i]+7);
+ cgit_query_has_sha1 = 1;
+ }
+ if (!strncmp(argv[i], "--ofs=", 6)) {
+ cgit_query_ofs = atoi(argv[i]+6);
+ }