author | Lars Hjemli <larsh@hal-2004.(none)> | 2007-01-05 17:18:58 (UTC) |
---|---|---|
committer | Lars Hjemli <larsh@hal-2004.(none)> | 2007-01-05 17:18:58 (UTC) |
commit | a6a11125283cd159bbd22e4e3c619bccad1162df (patch) (side-by-side diff) | |
tree | 3976dfc63c5fee196b1d5b595de2cf20bd687e6d | |
parent | 52e605caf573fa20fdd4fbac5e1cc69b7740b1f5 (diff) | |
download | cgit-a6a11125283cd159bbd22e4e3c619bccad1162df.zip cgit-a6a11125283cd159bbd22e4e3c619bccad1162df.tar.gz cgit-a6a11125283cd159bbd22e4e3c619bccad1162df.tar.bz2 |
Use TTL-settings even in nocache mode
In nocace mode an uninitialized ttl-setting was used to generate http-Expires
header. Fix it.
Signed-off-by: Lars Hjemli <larsh@hal-2004.(none)>
-rw-r--r-- | cgit.c | 1 |
1 files changed, 1 insertions, 0 deletions
@@ -92,72 +92,73 @@ static void cgit_check_cache(struct cacheitem *item) static void cgit_print_cache(struct cacheitem *item) { static char buf[4096]; ssize_t i; int fd = open(item->name, O_RDONLY); if (fd<0) die("Unable to open cached file %s", item->name); while((i=read(fd, buf, sizeof(buf))) > 0) write(STDOUT_FILENO, buf, i); close(fd); } static void cgit_parse_args(int argc, const char **argv) { int i; for (i = 1; i < argc; i++) { if (!strncmp(argv[i], "--root=", 7)) { cgit_root = xstrdup(argv[i]+7); } 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); } } } int main(int argc, const char **argv) { struct cacheitem item; cgit_read_config("/etc/cgitrc", cgit_global_config_cb); if (getenv("QUERY_STRING")) cgit_querystring = xstrdup(getenv("QUERY_STRING")); cgit_parse_args(argc, argv); cgit_parse_query(cgit_querystring, cgit_querystring_cb); if (cgit_nocache) { + cache_prepare(&item); item.fd = STDOUT_FILENO; cgit_fill_cache(&item); } else { cgit_check_cache(&item); cgit_print_cache(&item); } return 0; } |