author | Lars Hjemli <hjemli@gmail.com> | 2008-09-01 20:40:24 (UTC) |
---|---|---|
committer | Lars Hjemli <hjemli@gmail.com> | 2008-09-01 20:40:24 (UTC) |
commit | 288d502b3d8e7fa916104b486bbb146521e5c716 (patch) (unidiff) | |
tree | afa132f6c973ab30e0b8ed1201fb691fe91103c0 /cmd.c | |
parent | 2cecf839a06ce951db0d5d95abf79004eff33ca7 (diff) | |
parent | 02a545e63454530c1639014d3239c14ced2022c6 (diff) | |
download | cgit-288d502b3d8e7fa916104b486bbb146521e5c716.zip cgit-288d502b3d8e7fa916104b486bbb146521e5c716.tar.gz cgit-288d502b3d8e7fa916104b486bbb146521e5c716.tar.bz2 |
Merge branch 'lh/clone'
* lh/clone:
Add support for cloning over http
Conflicts:
cmd.c
-rw-r--r-- | cmd.c | 19 |
1 files changed, 19 insertions, 0 deletions
@@ -7,27 +7,33 @@ | |||
7 | */ | 7 | */ |
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-atom.h" | 13 | #include "ui-atom.h" |
14 | #include "ui-blob.h" | 14 | #include "ui-blob.h" |
15 | #include "ui-clone.h" | ||
15 | #include "ui-commit.h" | 16 | #include "ui-commit.h" |
16 | #include "ui-diff.h" | 17 | #include "ui-diff.h" |
17 | #include "ui-log.h" | 18 | #include "ui-log.h" |
18 | #include "ui-patch.h" | 19 | #include "ui-patch.h" |
19 | #include "ui-refs.h" | 20 | #include "ui-refs.h" |
20 | #include "ui-repolist.h" | 21 | #include "ui-repolist.h" |
21 | #include "ui-snapshot.h" | 22 | #include "ui-snapshot.h" |
22 | #include "ui-summary.h" | 23 | #include "ui-summary.h" |
23 | #include "ui-tag.h" | 24 | #include "ui-tag.h" |
24 | #include "ui-tree.h" | 25 | #include "ui-tree.h" |
25 | 26 | ||
27 | static void HEAD_fn(struct cgit_context *ctx) | ||
28 | { | ||
29 | cgit_clone_head(ctx); | ||
30 | } | ||
31 | |||
26 | static void atom_fn(struct cgit_context *ctx) | 32 | static void atom_fn(struct cgit_context *ctx) |
27 | { | 33 | { |
28 | cgit_print_atom(ctx->qry.head, ctx->qry.path, 10); | 34 | cgit_print_atom(ctx->qry.head, ctx->qry.path, 10); |
29 | } | 35 | } |
30 | 36 | ||
31 | static void about_fn(struct cgit_context *ctx) | 37 | static void about_fn(struct cgit_context *ctx) |
32 | { | 38 | { |
33 | if (ctx->repo) | 39 | if (ctx->repo) |
@@ -46,30 +52,40 @@ static void commit_fn(struct cgit_context *ctx) | |||
46 | cgit_print_commit(ctx->qry.sha1); | 52 | cgit_print_commit(ctx->qry.sha1); |
47 | } | 53 | } |
48 | 54 | ||
49 | static void diff_fn(struct cgit_context *ctx) | 55 | static void diff_fn(struct cgit_context *ctx) |
50 | { | 56 | { |
51 | cgit_print_diff(ctx->qry.sha1, ctx->qry.sha2, ctx->qry.path); | 57 | cgit_print_diff(ctx->qry.sha1, ctx->qry.sha2, ctx->qry.path); |
52 | } | 58 | } |
53 | 59 | ||
60 | static void info_fn(struct cgit_context *ctx) | ||
61 | { | ||
62 | cgit_clone_info(ctx); | ||
63 | } | ||
64 | |||
54 | static void log_fn(struct cgit_context *ctx) | 65 | static void log_fn(struct cgit_context *ctx) |
55 | { | 66 | { |
56 | cgit_print_log(ctx->qry.sha1, ctx->qry.ofs, ctx->cfg.max_commit_count, | 67 | cgit_print_log(ctx->qry.sha1, ctx->qry.ofs, ctx->cfg.max_commit_count, |
57 | ctx->qry.grep, ctx->qry.search, ctx->qry.path, 1); | 68 | ctx->qry.grep, ctx->qry.search, ctx->qry.path, 1); |
58 | } | 69 | } |
59 | 70 | ||
60 | static void ls_cache_fn(struct cgit_context *ctx) | 71 | static void ls_cache_fn(struct cgit_context *ctx) |
61 | { | 72 | { |
62 | ctx->page.mimetype = "text/plain"; | 73 | ctx->page.mimetype = "text/plain"; |
63 | ctx->page.filename = "ls-cache.txt"; | 74 | ctx->page.filename = "ls-cache.txt"; |
64 | cgit_print_http_headers(ctx); | 75 | cgit_print_http_headers(ctx); |
65 | cache_ls(ctx->cfg.cache_root); | 76 | cache_ls(ctx->cfg.cache_root); |
66 | } | 77 | } |
67 | 78 | ||
79 | static void objects_fn(struct cgit_context *ctx) | ||
80 | { | ||
81 | cgit_clone_objects(ctx); | ||
82 | } | ||
83 | |||
68 | static void repolist_fn(struct cgit_context *ctx) | 84 | static void repolist_fn(struct cgit_context *ctx) |
69 | { | 85 | { |
70 | cgit_print_repolist(); | 86 | cgit_print_repolist(); |
71 | } | 87 | } |
72 | 88 | ||
73 | static void patch_fn(struct cgit_context *ctx) | 89 | static void patch_fn(struct cgit_context *ctx) |
74 | { | 90 | { |
75 | cgit_print_patch(ctx->qry.sha1); | 91 | cgit_print_patch(ctx->qry.sha1); |
@@ -103,23 +119,26 @@ static void tree_fn(struct cgit_context *ctx) | |||
103 | } | 119 | } |
104 | 120 | ||
105 | #define def_cmd(name, want_repo, want_layout) \ | 121 | #define def_cmd(name, want_repo, want_layout) \ |
106 | {#name, name##_fn, want_repo, want_layout} | 122 | {#name, name##_fn, want_repo, want_layout} |
107 | 123 | ||
108 | struct cgit_cmd *cgit_get_cmd(struct cgit_context *ctx) | 124 | struct cgit_cmd *cgit_get_cmd(struct cgit_context *ctx) |
109 | { | 125 | { |
110 | static struct cgit_cmd cmds[] = { | 126 | static struct cgit_cmd cmds[] = { |
127 | def_cmd(HEAD, 1, 0), | ||
111 | def_cmd(atom, 1, 0), | 128 | def_cmd(atom, 1, 0), |
112 | def_cmd(about, 0, 1), | 129 | def_cmd(about, 0, 1), |
113 | def_cmd(blob, 1, 0), | 130 | def_cmd(blob, 1, 0), |
114 | def_cmd(commit, 1, 1), | 131 | def_cmd(commit, 1, 1), |
115 | def_cmd(diff, 1, 1), | 132 | def_cmd(diff, 1, 1), |
133 | def_cmd(info, 1, 0), | ||
116 | def_cmd(log, 1, 1), | 134 | def_cmd(log, 1, 1), |
117 | def_cmd(ls_cache, 0, 0), | 135 | def_cmd(ls_cache, 0, 0), |
136 | def_cmd(objects, 1, 0), | ||
118 | def_cmd(patch, 1, 0), | 137 | def_cmd(patch, 1, 0), |
119 | def_cmd(refs, 1, 1), | 138 | def_cmd(refs, 1, 1), |
120 | def_cmd(repolist, 0, 0), | 139 | def_cmd(repolist, 0, 0), |
121 | def_cmd(snapshot, 1, 0), | 140 | def_cmd(snapshot, 1, 0), |
122 | def_cmd(summary, 1, 1), | 141 | def_cmd(summary, 1, 1), |
123 | def_cmd(tag, 1, 1), | 142 | def_cmd(tag, 1, 1), |
124 | def_cmd(tree, 1, 1), | 143 | def_cmd(tree, 1, 1), |
125 | }; | 144 | }; |