summaryrefslogtreecommitdiffabout
path: root/cmd.c
Unidiff
Diffstat (limited to 'cmd.c') (more/less context) (ignore whitespace changes)
-rw-r--r--cmd.c19
1 files changed, 19 insertions, 0 deletions
diff --git a/cmd.c b/cmd.c
index fe0ea8f..03e165c 100644
--- a/cmd.c
+++ b/cmd.c
@@ -8,23 +8,29 @@
8 8
9#include "cgit.h" 9#include "cgit.h"
10#include "cmd.h" 10#include "cmd.h"
11#include "cache.h" 11#include "cache.h"
12#include "ui-shared.h" 12#include "ui-shared.h"
13#include "ui-blob.h" 13#include "ui-blob.h"
14#include "ui-clone.h"
14#include "ui-commit.h" 15#include "ui-commit.h"
15#include "ui-diff.h" 16#include "ui-diff.h"
16#include "ui-log.h" 17#include "ui-log.h"
17#include "ui-patch.h" 18#include "ui-patch.h"
18#include "ui-refs.h" 19#include "ui-refs.h"
19#include "ui-repolist.h" 20#include "ui-repolist.h"
20#include "ui-snapshot.h" 21#include "ui-snapshot.h"
21#include "ui-summary.h" 22#include "ui-summary.h"
22#include "ui-tag.h" 23#include "ui-tag.h"
23#include "ui-tree.h" 24#include "ui-tree.h"
24 25
26static void HEAD_fn(struct cgit_context *ctx)
27{
28 cgit_clone_head(ctx);
29}
30
25static void about_fn(struct cgit_context *ctx) 31static void about_fn(struct cgit_context *ctx)
26{ 32{
27 if (ctx->repo) 33 if (ctx->repo)
28 cgit_print_repo_readme(); 34 cgit_print_repo_readme();
29 else 35 else
30 cgit_print_site_readme(); 36 cgit_print_site_readme();
@@ -42,12 +48,17 @@ static void commit_fn(struct cgit_context *ctx)
42 48
43static void diff_fn(struct cgit_context *ctx) 49static void diff_fn(struct cgit_context *ctx)
44{ 50{
45 cgit_print_diff(ctx->qry.sha1, ctx->qry.sha2, ctx->qry.path); 51 cgit_print_diff(ctx->qry.sha1, ctx->qry.sha2, ctx->qry.path);
46} 52}
47 53
54static void info_fn(struct cgit_context *ctx)
55{
56 cgit_clone_info(ctx);
57}
58
48static void log_fn(struct cgit_context *ctx) 59static void log_fn(struct cgit_context *ctx)
49{ 60{
50 cgit_print_log(ctx->qry.sha1, ctx->qry.ofs, ctx->cfg.max_commit_count, 61 cgit_print_log(ctx->qry.sha1, ctx->qry.ofs, ctx->cfg.max_commit_count,
51 ctx->qry.grep, ctx->qry.search, ctx->qry.path, 1); 62 ctx->qry.grep, ctx->qry.search, ctx->qry.path, 1);
52} 63}
53 64
@@ -56,12 +67,17 @@ static void ls_cache_fn(struct cgit_context *ctx)
56 ctx->page.mimetype = "text/plain"; 67 ctx->page.mimetype = "text/plain";
57 ctx->page.filename = "ls-cache.txt"; 68 ctx->page.filename = "ls-cache.txt";
58 cgit_print_http_headers(ctx); 69 cgit_print_http_headers(ctx);
59 cache_ls(ctx->cfg.cache_root); 70 cache_ls(ctx->cfg.cache_root);
60} 71}
61 72
73static void objects_fn(struct cgit_context *ctx)
74{
75 cgit_clone_objects(ctx);
76}
77
62static void repolist_fn(struct cgit_context *ctx) 78static void repolist_fn(struct cgit_context *ctx)
63{ 79{
64 cgit_print_repolist(); 80 cgit_print_repolist();
65} 81}
66 82
67static void patch_fn(struct cgit_context *ctx) 83static void patch_fn(struct cgit_context *ctx)
@@ -99,18 +115,21 @@ static void tree_fn(struct cgit_context *ctx)
99#define def_cmd(name, want_repo, want_layout) \ 115#define def_cmd(name, want_repo, want_layout) \
100 {#name, name##_fn, want_repo, want_layout} 116 {#name, name##_fn, want_repo, want_layout}
101 117
102struct cgit_cmd *cgit_get_cmd(struct cgit_context *ctx) 118struct cgit_cmd *cgit_get_cmd(struct cgit_context *ctx)
103{ 119{
104 static struct cgit_cmd cmds[] = { 120 static struct cgit_cmd cmds[] = {
121 def_cmd(HEAD, 1, 0),
105 def_cmd(about, 0, 1), 122 def_cmd(about, 0, 1),
106 def_cmd(blob, 1, 0), 123 def_cmd(blob, 1, 0),
107 def_cmd(commit, 1, 1), 124 def_cmd(commit, 1, 1),
108 def_cmd(diff, 1, 1), 125 def_cmd(diff, 1, 1),
126 def_cmd(info, 1, 0),
109 def_cmd(log, 1, 1), 127 def_cmd(log, 1, 1),
110 def_cmd(ls_cache, 0, 0), 128 def_cmd(ls_cache, 0, 0),
129 def_cmd(objects, 1, 0),
111 def_cmd(patch, 1, 0), 130 def_cmd(patch, 1, 0),
112 def_cmd(refs, 1, 1), 131 def_cmd(refs, 1, 1),
113 def_cmd(repolist, 0, 0), 132 def_cmd(repolist, 0, 0),
114 def_cmd(snapshot, 1, 0), 133 def_cmd(snapshot, 1, 0),
115 def_cmd(summary, 1, 1), 134 def_cmd(summary, 1, 1),
116 def_cmd(tag, 1, 1), 135 def_cmd(tag, 1, 1),