summaryrefslogtreecommitdiffabout
authorLars Hjemli <hjemli@gmail.com>2007-05-17 22:50:46 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2007-05-18 20:51:01 (UTC)
commit43d40f2b704151d145a1383b2b964210915ecae4 (patch) (unidiff)
tree2ce8d71a143aef998f6f97291b5792367db82b8a
parent305414df1246531baf0f2c959c2c61df4e93c526 (diff)
downloadcgit-43d40f2b704151d145a1383b2b964210915ecae4.zip
cgit-43d40f2b704151d145a1383b2b964210915ecae4.tar.gz
cgit-43d40f2b704151d145a1383b2b964210915ecae4.tar.bz2
Add lookup-function for valid repo commands
This will be usefull when parsing url arguments. Signed-off-by: Lars Hjemli <hjemli@gmail.com>
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
@@ -1,52 +1,63 @@
1#ifndef CGIT_H 1#ifndef CGIT_H
2#define CGIT_H 2#define CGIT_H
3 3
4 4
5#include <git-compat-util.h> 5#include <git-compat-util.h>
6#include <cache.h> 6#include <cache.h>
7#include <grep.h> 7#include <grep.h>
8#include <object.h> 8#include <object.h>
9#include <tree.h> 9#include <tree.h>
10#include <commit.h> 10#include <commit.h>
11#include <tag.h> 11#include <tag.h>
12#include <diff.h> 12#include <diff.h>
13#include <diffcore.h> 13#include <diffcore.h>
14#include <refs.h> 14#include <refs.h>
15#include <revision.h> 15#include <revision.h>
16#include <log-tree.h> 16#include <log-tree.h>
17#include <archive.h> 17#include <archive.h>
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
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);
23typedef void (*linediff_fn)(char *line, int len); 34typedef void (*linediff_fn)(char *line, int len);
24 35
25struct cacheitem { 36struct cacheitem {
26 char *name; 37 char *name;
27 struct stat st; 38 struct stat st;
28 int ttl; 39 int ttl;
29 int fd; 40 int fd;
30}; 41};
31 42
32struct repoinfo { 43struct repoinfo {
33 char *url; 44 char *url;
34 char *name; 45 char *name;
35 char *path; 46 char *path;
36 char *desc; 47 char *desc;
37 char *owner; 48 char *owner;
38 char *defbranch; 49 char *defbranch;
39 char *module_link; 50 char *module_link;
40 int snapshots; 51 int snapshots;
41 int enable_log_filecount; 52 int enable_log_filecount;
42 int enable_log_linecount; 53 int enable_log_linecount;
43}; 54};
44 55
45struct repolist { 56struct repolist {
46 int length; 57 int length;
47 int count; 58 int count;
48 struct repoinfo *repos; 59 struct repoinfo *repos;
49}; 60};
50 61
51struct commitinfo { 62struct commitinfo {
52 struct commit *commit; 63 struct commit *commit;
@@ -83,64 +94,65 @@ extern char *cgit_cache_root;
83 94
84extern int cgit_nocache; 95extern int cgit_nocache;
85extern int cgit_snapshots; 96extern int cgit_snapshots;
86extern int cgit_enable_log_filecount; 97extern int cgit_enable_log_filecount;
87extern int cgit_enable_log_linecount; 98extern int cgit_enable_log_linecount;
88extern int cgit_max_lock_attempts; 99extern int cgit_max_lock_attempts;
89extern int cgit_cache_root_ttl; 100extern int cgit_cache_root_ttl;
90extern int cgit_cache_repo_ttl; 101extern int cgit_cache_repo_ttl;
91extern int cgit_cache_dynamic_ttl; 102extern int cgit_cache_dynamic_ttl;
92extern int cgit_cache_static_ttl; 103extern int cgit_cache_static_ttl;
93extern int cgit_cache_max_create_time; 104extern int cgit_cache_max_create_time;
94 105
95extern int cgit_max_msg_len; 106extern int cgit_max_msg_len;
96extern int cgit_max_repodesc_len; 107extern int cgit_max_repodesc_len;
97extern int cgit_max_commit_count; 108extern int cgit_max_commit_count;
98 109
99extern int cgit_query_has_symref; 110extern int cgit_query_has_symref;
100extern int cgit_query_has_sha1; 111extern int cgit_query_has_sha1;
101 112
102extern char *cgit_querystring; 113extern char *cgit_querystring;
103extern char *cgit_query_repo; 114extern char *cgit_query_repo;
104extern char *cgit_query_page; 115extern char *cgit_query_page;
105extern char *cgit_query_search; 116extern char *cgit_query_search;
106extern char *cgit_query_head; 117extern char *cgit_query_head;
107extern char *cgit_query_sha1; 118extern char *cgit_query_sha1;
108extern char *cgit_query_sha2; 119extern char *cgit_query_sha2;
109extern char *cgit_query_path; 120extern char *cgit_query_path;
110extern char *cgit_query_name; 121extern char *cgit_query_name;
111extern int cgit_query_ofs; 122extern int cgit_query_ofs;
112 123
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);
117extern void cgit_repo_config_cb(const char *name, const char *value); 129extern void cgit_repo_config_cb(const char *name, const char *value);
118extern void cgit_querystring_cb(const char *name, const char *value); 130extern void cgit_querystring_cb(const char *name, const char *value);
119 131
120extern int chk_zero(int result, char *msg); 132extern int chk_zero(int result, char *msg);
121extern int chk_positive(int result, char *msg); 133extern int chk_positive(int result, char *msg);
122 134
123extern int hextoint(char c); 135extern int hextoint(char c);
124 136
125extern void *cgit_free_commitinfo(struct commitinfo *info); 137extern void *cgit_free_commitinfo(struct commitinfo *info);
126 138
127extern int cgit_diff_files(const unsigned char *old_sha1, 139extern int cgit_diff_files(const unsigned char *old_sha1,
128 const unsigned char *new_sha1, 140 const unsigned char *new_sha1,
129 linediff_fn fn); 141 linediff_fn fn);
130 142
131extern void cgit_diff_tree(const unsigned char *old_sha1, 143extern void cgit_diff_tree(const unsigned char *old_sha1,
132 const unsigned char *new_sha1, 144 const unsigned char *new_sha1,
133 filepair_fn fn); 145 filepair_fn fn);
134 146
135extern void cgit_diff_commit(struct commit *commit, filepair_fn fn); 147extern void cgit_diff_commit(struct commit *commit, filepair_fn fn);
136 148
137extern char *fmt(const char *format,...); 149extern char *fmt(const char *format,...);
138 150
139extern void html(const char *txt); 151extern void html(const char *txt);
140extern void htmlf(const char *format,...); 152extern void htmlf(const char *format,...);
141extern void html_txt(char *txt); 153extern void html_txt(char *txt);
142extern void html_ntxt(int len, char *txt); 154extern void html_ntxt(int len, char *txt);
143extern void html_attr(char *txt); 155extern void html_attr(char *txt);
144extern void html_hidden(char *name, char *value); 156extern void html_hidden(char *name, char *value);
145extern void html_link_open(char *url, char *title, char *class); 157extern void html_link_open(char *url, char *title, char *class);
146extern void html_link_close(void); 158extern void html_link_close(void);
diff --git a/shared.c b/shared.c
index b164d81..fb05427 100644
--- a/shared.c
+++ b/shared.c
@@ -22,64 +22,76 @@ char *cgit_cache_root = "/var/cache/cgit";
22 22
23int cgit_nocache = 0; 23int cgit_nocache = 0;
24int cgit_snapshots = 0; 24int cgit_snapshots = 0;
25int cgit_enable_log_filecount = 0; 25int cgit_enable_log_filecount = 0;
26int cgit_enable_log_linecount = 0; 26int cgit_enable_log_linecount = 0;
27int cgit_max_lock_attempts = 5; 27int cgit_max_lock_attempts = 5;
28int cgit_cache_root_ttl = 5; 28int cgit_cache_root_ttl = 5;
29int cgit_cache_repo_ttl = 5; 29int cgit_cache_repo_ttl = 5;
30int cgit_cache_dynamic_ttl = 5; 30int cgit_cache_dynamic_ttl = 5;
31int cgit_cache_static_ttl = -1; 31int cgit_cache_static_ttl = -1;
32int cgit_cache_max_create_time = 5; 32int cgit_cache_max_create_time = 5;
33 33
34int cgit_max_msg_len = 60; 34int cgit_max_msg_len = 60;
35int cgit_max_repodesc_len = 60; 35int cgit_max_repodesc_len = 60;
36int cgit_max_commit_count = 50; 36int cgit_max_commit_count = 50;
37 37
38int cgit_query_has_symref = 0; 38int cgit_query_has_symref = 0;
39int cgit_query_has_sha1 = 0; 39int cgit_query_has_sha1 = 0;
40 40
41char *cgit_querystring = NULL; 41char *cgit_querystring = NULL;
42char *cgit_query_repo = NULL; 42char *cgit_query_repo = NULL;
43char *cgit_query_page = NULL; 43char *cgit_query_page = NULL;
44char *cgit_query_head = NULL; 44char *cgit_query_head = NULL;
45char *cgit_query_search = NULL; 45char *cgit_query_search = NULL;
46char *cgit_query_sha1 = NULL; 46char *cgit_query_sha1 = NULL;
47char *cgit_query_sha2 = NULL; 47char *cgit_query_sha2 = NULL;
48char *cgit_query_path = NULL; 48char *cgit_query_path = NULL;
49char *cgit_query_name = NULL; 49char *cgit_query_name = NULL;
50int cgit_query_ofs = 0; 50int cgit_query_ofs = 0;
51 51
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{
56 if (result != 0) 68 if (result != 0)
57 die("%s: %s", msg, strerror(errno)); 69 die("%s: %s", msg, strerror(errno));
58 return result; 70 return result;
59} 71}
60 72
61int chk_positive(int result, char *msg) 73int chk_positive(int result, char *msg)
62{ 74{
63 if (result <= 0) 75 if (result <= 0)
64 die("%s: %s", msg, strerror(errno)); 76 die("%s: %s", msg, strerror(errno));
65 return result; 77 return result;
66} 78}
67 79
68struct repoinfo *add_repo(const char *url) 80struct repoinfo *add_repo(const char *url)
69{ 81{
70 struct repoinfo *ret; 82 struct repoinfo *ret;
71 83
72 if (++cgit_repolist.count > cgit_repolist.length) { 84 if (++cgit_repolist.count > cgit_repolist.length) {
73 if (cgit_repolist.length == 0) 85 if (cgit_repolist.length == 0)
74 cgit_repolist.length = 8; 86 cgit_repolist.length = 8;
75 else 87 else
76 cgit_repolist.length *= 2; 88 cgit_repolist.length *= 2;
77 cgit_repolist.repos = xrealloc(cgit_repolist.repos, 89 cgit_repolist.repos = xrealloc(cgit_repolist.repos,
78 cgit_repolist.length * 90 cgit_repolist.length *
79 sizeof(struct repoinfo)); 91 sizeof(struct repoinfo));
80 } 92 }
81 93
82 ret = &cgit_repolist.repos[cgit_repolist.count-1]; 94 ret = &cgit_repolist.repos[cgit_repolist.count-1];
83 ret->url = xstrdup(url); 95 ret->url = xstrdup(url);
84 ret->name = ret->url; 96 ret->name = ret->url;
85 ret->path = NULL; 97 ret->path = NULL;