author | Lars Hjemli <hjemli@gmail.com> | 2010-09-19 17:00:05 (UTC) |
---|---|---|
committer | Lars Hjemli <hjemli@gmail.com> | 2010-09-19 17:00:05 (UTC) |
commit | a9d6e6e695da6c6ed7f4bb32630ab2f3d9314806 (patch) (unidiff) | |
tree | de8271ebfabd244437cd68021c8af86391afb9bd /cgit.c | |
parent | 536c7a1eb201b44b9266babe087cb6f2b75e4a7f (diff) | |
parent | d187b98557d91b874836f286b955ba76ab26fb02 (diff) | |
download | cgit-a9d6e6e695da6c6ed7f4bb32630ab2f3d9314806.zip cgit-a9d6e6e695da6c6ed7f4bb32630ab2f3d9314806.tar.gz cgit-a9d6e6e695da6c6ed7f4bb32630ab2f3d9314806.tar.bz2 |
Merge branch 'ml/bugfix'
-rw-r--r-- | cgit.c | 2 |
1 files changed, 1 insertions, 1 deletions
@@ -589,49 +589,49 @@ static int generate_cached_repolist(const char *path, const char *cached_rc) | |||
589 | } | 589 | } |
590 | idx = cgit_repolist.count; | 590 | idx = cgit_repolist.count; |
591 | if (ctx.cfg.project_list) | 591 | if (ctx.cfg.project_list) |
592 | scan_projects(path, ctx.cfg.project_list, repo_config); | 592 | scan_projects(path, ctx.cfg.project_list, repo_config); |
593 | else | 593 | else |
594 | scan_tree(path, repo_config); | 594 | scan_tree(path, repo_config); |
595 | print_repolist(f, &cgit_repolist, idx); | 595 | print_repolist(f, &cgit_repolist, idx); |
596 | if (rename(locked_rc, cached_rc)) | 596 | if (rename(locked_rc, cached_rc)) |
597 | fprintf(stderr, "[cgit] Error renaming %s to %s: %s (%d)\n", | 597 | fprintf(stderr, "[cgit] Error renaming %s to %s: %s (%d)\n", |
598 | locked_rc, cached_rc, strerror(errno), errno); | 598 | locked_rc, cached_rc, strerror(errno), errno); |
599 | fclose(f); | 599 | fclose(f); |
600 | return 0; | 600 | return 0; |
601 | } | 601 | } |
602 | 602 | ||
603 | static void process_cached_repolist(const char *path) | 603 | static void process_cached_repolist(const char *path) |
604 | { | 604 | { |
605 | struct stat st; | 605 | struct stat st; |
606 | char *cached_rc; | 606 | char *cached_rc; |
607 | time_t age; | 607 | time_t age; |
608 | unsigned long hash; | 608 | unsigned long hash; |
609 | 609 | ||
610 | hash = hash_str(path); | 610 | hash = hash_str(path); |
611 | if (ctx.cfg.project_list) | 611 | if (ctx.cfg.project_list) |
612 | hash += hash_str(ctx.cfg.project_list); | 612 | hash += hash_str(ctx.cfg.project_list); |
613 | cached_rc = xstrdup(fmt("%s/rc-%8x", ctx.cfg.cache_root, hash)); | 613 | cached_rc = xstrdup(fmt("%s/rc-%8lx", ctx.cfg.cache_root, hash)); |
614 | 614 | ||
615 | if (stat(cached_rc, &st)) { | 615 | if (stat(cached_rc, &st)) { |
616 | /* Nothing is cached, we need to scan without forking. And | 616 | /* Nothing is cached, we need to scan without forking. And |
617 | * if we fail to generate a cached repolist, we need to | 617 | * if we fail to generate a cached repolist, we need to |
618 | * invoke scan_tree manually. | 618 | * invoke scan_tree manually. |
619 | */ | 619 | */ |
620 | if (generate_cached_repolist(path, cached_rc)) { | 620 | if (generate_cached_repolist(path, cached_rc)) { |
621 | if (ctx.cfg.project_list) | 621 | if (ctx.cfg.project_list) |
622 | scan_projects(path, ctx.cfg.project_list, | 622 | scan_projects(path, ctx.cfg.project_list, |
623 | repo_config); | 623 | repo_config); |
624 | else | 624 | else |
625 | scan_tree(path, repo_config); | 625 | scan_tree(path, repo_config); |
626 | } | 626 | } |
627 | return; | 627 | return; |
628 | } | 628 | } |
629 | 629 | ||
630 | parse_configfile(cached_rc, config_cb); | 630 | parse_configfile(cached_rc, config_cb); |
631 | 631 | ||
632 | /* If the cached configfile hasn't expired, lets exit now */ | 632 | /* If the cached configfile hasn't expired, lets exit now */ |
633 | age = time(NULL) - st.st_mtime; | 633 | age = time(NULL) - st.st_mtime; |
634 | if (age <= (ctx.cfg.cache_scanrc_ttl * 60)) | 634 | if (age <= (ctx.cfg.cache_scanrc_ttl * 60)) |
635 | return; | 635 | return; |
636 | 636 | ||
637 | /* The cached repolist has been parsed, but it was old. So lets | 637 | /* The cached repolist has been parsed, but it was old. So lets |