summaryrefslogtreecommitdiffabout
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--cgit.h12
-rw-r--r--shared.c12
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
@@ -19,4 +19,15 @@
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
21typedef void (*configfn)(const char *name, const char *value); 32typedef void (*configfn)(const char *name, const char *value);
22typedef void (*filepair_fn)(struct diff_filepair *pair); 33typedef void (*filepair_fn)(struct diff_filepair *pair);
@@ -113,4 +124,5 @@ extern int cgit_query_ofs;
113extern int htmlfd; 124extern int htmlfd;
114 125
126extern int cgit_get_cmd_index(const char *cmd);
115extern struct repoinfo *cgit_get_repoinfo(const char *url); 127extern struct repoinfo *cgit_get_repoinfo(const char *url);
116extern void cgit_global_config_cb(const char *name, const char *value); 128extern void cgit_global_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
@@ -52,4 +52,16 @@ int cgit_query_ofs = 0;
52int htmlfd = 0; 52int htmlfd = 0;
53 53
54
55int 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
54int chk_zero(int result, char *msg) 66int chk_zero(int result, char *msg)
55{ 67{