diff options
author | Lars Hjemli | 2007-05-18 00:50:46 +0200 |
---|---|---|
committer | Lars Hjemli | 2007-05-18 22:51:01 +0200 |
commit | 43d40f2b704151d145a1383b2b964210915ecae4 (patch) | |
tree | 2ce8d71a143aef998f6f97291b5792367db82b8a | |
parent | Move cgit_get_repoinfo into shared.c (diff) | |
download | cgit-43d40f2b704151d145a1383b2b964210915ecae4.tar.gz cgit-43d40f2b704151d145a1383b2b964210915ecae4.zip |
Add lookup-function for valid repo commands
This will be usefull when parsing url arguments. Signed-off-by: Lars Hjemli <hjemli@gmail.com>
-rw-r--r-- | cgit.h | 12 | ||||
-rw-r--r-- | shared.c | 12 |
2 files changed, 24 insertions, 0 deletions
diff --git a/cgit.h b/cgit.h index a38981d..f402466 100644 --- a/cgit.h +++ b/cgit.h | |||
@@ -18,6 +18,17 @@ | |||
18 | #include <xdiff/xdiff.h> | 18 | #include <xdiff/xdiff.h> |
19 | 19 | ||
20 | 20 | ||
21 | /* | ||
22 | * The valid cgit repo-commands | ||
23 | */ | ||
24 | #define CMD_LOG = 1; | ||
25 | #define CMD_COMMIT = 1; | ||
26 | #define CMD_DIFF = 1; | ||
27 | #define CMD_TREE = 1; | ||
28 | #define CMD_VIEW = 1; | ||
29 | #define CMD_BLOB = 1; | ||
30 | #define CMD_SNAPSHOT = 1; | ||
31 | |||
21 | typedef void (*configfn)(const char *name, const char *value); | 32 | typedef void (*configfn)(const char *name, const char *value); |
22 | typedef void (*filepair_fn)(struct diff_filepair *pair); | 33 | typedef void (*filepair_fn)(struct diff_filepair *pair); |
23 | typedef void (*linediff_fn)(char *line, int len); | 34 | typedef void (*linediff_fn)(char *line, int len); |
@@ -112,6 +123,7 @@ extern int cgit_query_ofs; | |||
112 | 123 | ||
113 | extern int htmlfd; | 124 | extern int htmlfd; |
114 | 125 | ||
126 | extern int cgit_get_cmd_index(const char *cmd); | ||
115 | extern struct repoinfo *cgit_get_repoinfo(const char *url); | 127 | extern struct repoinfo *cgit_get_repoinfo(const char *url); |
116 | extern void cgit_global_config_cb(const char *name, const char *value); | 128 | extern void cgit_global_config_cb(const char *name, const char *value); |
117 | extern void cgit_repo_config_cb(const char *name, const char *value); | 129 | extern void cgit_repo_config_cb(const char *name, const char *value); |
diff --git a/shared.c b/shared.c index b164d81..fb05427 100644 --- a/shared.c +++ b/shared.c | |||
@@ -51,6 +51,18 @@ int cgit_query_ofs = 0; | |||
51 | 51 | ||
52 | int htmlfd = 0; | 52 | int htmlfd = 0; |
53 | 53 | ||
54 | |||
55 | int cgit_get_cmd_index(const char *cmd) | ||
56 | { | ||
57 | static char *cmds[] = {"log", "commit", "diff", "tree", "view", "blob", "snapshot", NULL}; | ||
58 | int i; | ||
59 | |||
60 | for(i = 0; cmds[i]; i++) | ||
61 | if (!strcmp(cmd, cmds[i])) | ||
62 | return i + 1; | ||
63 | return 0; | ||
64 | } | ||
65 | |||
54 | int chk_zero(int result, char *msg) | 66 | int chk_zero(int result, char *msg) |
55 | { | 67 | { |
56 | if (result != 0) | 68 | if (result != 0) |