]> gitweb.ps.run Git - ps-cgit/blobdiff - cgit.c
Add commitdiff between commit and each of it's parent
[ps-cgit] / cgit.c
diff --git a/cgit.c b/cgit.c
index fedf3553a8b2db860bb2b2750a6f3bb82dd9b7b3..3d85a08766c99d536d290e0621e85f71a2fd579e 100644 (file)
--- a/cgit.c
+++ b/cgit.c
@@ -79,11 +79,16 @@ static void cgit_print_repo_page(struct cacheitem *item)
        show_search = 0;
        setenv("GIT_DIR", cgit_repo->path, 1);
 
-       if (cgit_repo->snapshots && cgit_query_page && 
-           !strcmp(cgit_query_page, "snapshot")) {
+       if (cgit_query_page) {
+           if (cgit_repo->snapshots && !strcmp(cgit_query_page, "snapshot")) {
                cgit_print_snapshot(item, cgit_query_sha1, "zip", 
                                    cgit_repo->url, cgit_query_name);
                return;
+           }
+           if (!strcmp(cgit_query_page, "blob")) {
+                   cgit_print_blob(item, cgit_query_sha1, cgit_query_path);
+                   return;
+           }
        }
 
        if (cgit_query_page && !strcmp(cgit_query_page, "log"))
@@ -102,16 +107,16 @@ static void cgit_print_repo_page(struct cacheitem *item)
        cgit_print_pageheader(cgit_query_page, show_search);
 
        if (!strcmp(cgit_query_page, "log")) {
-               cgit_print_log(cgit_query_head, cgit_query_ofs, 100, 
-                              cgit_query_search);
+               cgit_print_log(cgit_query_head, cgit_query_ofs,
+                              cgit_max_commit_count, cgit_query_search);
        } else if (!strcmp(cgit_query_page, "tree")) {
                cgit_print_tree(cgit_query_sha1, cgit_query_path);
        } else if (!strcmp(cgit_query_page, "commit")) {
                cgit_print_commit(cgit_query_sha1);
        } else if (!strcmp(cgit_query_page, "view")) {
-               cgit_print_view(cgit_query_sha1);
+               cgit_print_view(cgit_query_sha1, cgit_query_path);
        } else if (!strcmp(cgit_query_page, "diff")) {
-               cgit_print_diff(cgit_query_sha1, cgit_query_sha2);
+               cgit_print_diff(cgit_query_sha1, cgit_query_sha2, cgit_query_path);
        } else {
                cgit_print_error("Invalid request");
        }