]> granicus.if.org Git - cgit/commitdiff
Improve initialization of git directory
authorLars Hjemli <hjemli@gmail.com>
Sat, 16 Feb 2008 20:16:53 +0000 (21:16 +0100)
committerLars Hjemli <hjemli@gmail.com>
Sat, 16 Feb 2008 20:48:19 +0000 (21:48 +0100)
Using the functions offered by libgit feels like the right thing to do. Also,
make sure that config errors gets properly reported.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
cgit.c
ui-shared.c

diff --git a/cgit.c b/cgit.c
index b270fdca2d401da1813e0d085231e1562664f91b..2c933dcdf7daff3e36009ff44733031a062b4fd8 100644 (file)
--- a/cgit.c
+++ b/cgit.c
@@ -83,20 +83,23 @@ static void cgit_print_repo_page(struct cacheitem *item)
        char *title, *tmp;
        int show_search;
        unsigned char sha1[20];
+       int nongit = 0;
 
-       if (chdir(ctx.repo->path)) {
-               title = fmt("%s - %s", ctx.cfg.root_title, "Bad request");
+       setenv("GIT_DIR", ctx.repo->path, 1);
+       setup_git_directory_gently(&nongit);
+       if (nongit) {
+               title = fmt("%s - %s", ctx.cfg.root_title, "config error");
+               tmp = fmt("Not a git repository: '%s'", ctx.repo->path);
+               ctx.repo = NULL;
                cgit_print_docstart(title, item);
                cgit_print_pageheader(title, 0);
-               cgit_print_error(fmt("Unable to scan repository: %s",
-                                    strerror(errno)));
+               cgit_print_error(tmp);
                cgit_print_docend();
                return;
        }
 
        title = fmt("%s - %s", ctx.repo->name, ctx.repo->desc);
        show_search = 0;
-       setenv("GIT_DIR", ctx.repo->path, 1);
 
        if (!ctx.qry.head) {
                ctx.qry.head = xstrdup(find_default_branch(ctx.repo));
@@ -179,10 +182,8 @@ static void cgit_print_repo_page(struct cacheitem *item)
 
 static void cgit_fill_cache(struct cacheitem *item, int use_cache)
 {
-       static char buf[PATH_MAX];
        int stdout2;
 
-       getcwd(buf, sizeof(buf));
        item->st.st_mtime = time(NULL);
 
        if (use_cache) {
@@ -203,8 +204,6 @@ static void cgit_fill_cache(struct cacheitem *item, int use_cache)
                             "Restoring original STDOUT");
                chk_zero(close(stdout2), "Closing temporary STDOUT");
        }
-
-       chdir(buf);
 }
 
 static void cgit_check_cache(struct cacheitem *item)
index b9f487a6c388c2e9634396c9bddd9ea42ec38de4..cc1ab8bb50a36cec0403fc1215d50e1d6128d5cd 100644 (file)
@@ -476,7 +476,7 @@ void cgit_print_pageheader(char *title, int show_search)
        htmlf("'><img src='%s' alt='cgit'/></a>\n",
              ctx.cfg.logo);
        html("</td></tr>\n<tr><td class='sidebar'>\n");
-       if (ctx.qry.repo) {
+       if (ctx.repo) {
                html("<h1 class='first'>");
                html_txt(strrpart(ctx.repo->name, 20));
                html("</h1>\n");