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
@@ -1,44 +1,55 @@
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
@@ -91,48 +102,49 @@ extern 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
diff --git a/shared.c b/shared.c
index b164d81..fb05427 100644
--- a/shared.c
+++ b/shared.c
@@ -30,48 +30,60 @@ int 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,