summaryrefslogtreecommitdiffabout
path: root/cgit.c
authorLars Hjemli <hjemli@gmail.com>2009-07-31 14:55:27 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2009-07-31 15:41:21 (UTC)
commit46b7abed99e957008c01c02cf612aa526ba92f04 (patch) (unidiff)
tree2cdbfe5281c2ffa645def488d53db0a8b82842f4 /cgit.c
parent18dfbdc099c1398016427b6fa7f1a1facb363998 (diff)
downloadcgit-46b7abed99e957008c01c02cf612aa526ba92f04.zip
cgit-46b7abed99e957008c01c02cf612aa526ba92f04.tar.gz
cgit-46b7abed99e957008c01c02cf612aa526ba92f04.tar.bz2
ui-tree: add support for source-filter option
This new option is used to specify an external command which will be executed when displaying blob content in the tree view. Blob content will be written to STDIN of the filter and STDOUT from the filter will be included verbatim in the html output from cgit. The file name of the blob will be passed as the only argument to the filter command. Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Diffstat (limited to 'cgit.c') (more/less context) (ignore whitespace changes)
-rw-r--r--cgit.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/cgit.c b/cgit.c
index 779a464..eb7b45d 100644
--- a/cgit.c
+++ b/cgit.c
@@ -55,96 +55,98 @@ void config_cb(const char *name, const char *value)
55 else if (!strcmp(name, "index-header")) 55 else if (!strcmp(name, "index-header"))
56 ctx.cfg.index_header = xstrdup(value); 56 ctx.cfg.index_header = xstrdup(value);
57 else if (!strcmp(name, "index-info")) 57 else if (!strcmp(name, "index-info"))
58 ctx.cfg.index_info = xstrdup(value); 58 ctx.cfg.index_info = xstrdup(value);
59 else if (!strcmp(name, "logo-link")) 59 else if (!strcmp(name, "logo-link"))
60 ctx.cfg.logo_link = xstrdup(value); 60 ctx.cfg.logo_link = xstrdup(value);
61 else if (!strcmp(name, "module-link")) 61 else if (!strcmp(name, "module-link"))
62 ctx.cfg.module_link = xstrdup(value); 62 ctx.cfg.module_link = xstrdup(value);
63 else if (!strcmp(name, "virtual-root")) { 63 else if (!strcmp(name, "virtual-root")) {
64 ctx.cfg.virtual_root = trim_end(value, '/'); 64 ctx.cfg.virtual_root = trim_end(value, '/');
65 if (!ctx.cfg.virtual_root && (!strcmp(value, "/"))) 65 if (!ctx.cfg.virtual_root && (!strcmp(value, "/")))
66 ctx.cfg.virtual_root = ""; 66 ctx.cfg.virtual_root = "";
67 } else if (!strcmp(name, "nocache")) 67 } else if (!strcmp(name, "nocache"))
68 ctx.cfg.nocache = atoi(value); 68 ctx.cfg.nocache = atoi(value);
69 else if (!strcmp(name, "noheader")) 69 else if (!strcmp(name, "noheader"))
70 ctx.cfg.noheader = atoi(value); 70 ctx.cfg.noheader = atoi(value);
71 else if (!strcmp(name, "snapshots")) 71 else if (!strcmp(name, "snapshots"))
72 ctx.cfg.snapshots = cgit_parse_snapshots_mask(value); 72 ctx.cfg.snapshots = cgit_parse_snapshots_mask(value);
73 else if (!strcmp(name, "enable-index-links")) 73 else if (!strcmp(name, "enable-index-links"))
74 ctx.cfg.enable_index_links = atoi(value); 74 ctx.cfg.enable_index_links = atoi(value);
75 else if (!strcmp(name, "enable-log-filecount")) 75 else if (!strcmp(name, "enable-log-filecount"))
76 ctx.cfg.enable_log_filecount = atoi(value); 76 ctx.cfg.enable_log_filecount = atoi(value);
77 else if (!strcmp(name, "enable-log-linecount")) 77 else if (!strcmp(name, "enable-log-linecount"))
78 ctx.cfg.enable_log_linecount = atoi(value); 78 ctx.cfg.enable_log_linecount = atoi(value);
79 else if (!strcmp(name, "max-stats")) 79 else if (!strcmp(name, "max-stats"))
80 ctx.cfg.max_stats = cgit_find_stats_period(value, NULL); 80 ctx.cfg.max_stats = cgit_find_stats_period(value, NULL);
81 else if (!strcmp(name, "cache-size")) 81 else if (!strcmp(name, "cache-size"))
82 ctx.cfg.cache_size = atoi(value); 82 ctx.cfg.cache_size = atoi(value);
83 else if (!strcmp(name, "cache-root")) 83 else if (!strcmp(name, "cache-root"))
84 ctx.cfg.cache_root = xstrdup(value); 84 ctx.cfg.cache_root = xstrdup(value);
85 else if (!strcmp(name, "cache-root-ttl")) 85 else if (!strcmp(name, "cache-root-ttl"))
86 ctx.cfg.cache_root_ttl = atoi(value); 86 ctx.cfg.cache_root_ttl = atoi(value);
87 else if (!strcmp(name, "cache-repo-ttl")) 87 else if (!strcmp(name, "cache-repo-ttl"))
88 ctx.cfg.cache_repo_ttl = atoi(value); 88 ctx.cfg.cache_repo_ttl = atoi(value);
89 else if (!strcmp(name, "cache-static-ttl")) 89 else if (!strcmp(name, "cache-static-ttl"))
90 ctx.cfg.cache_static_ttl = atoi(value); 90 ctx.cfg.cache_static_ttl = atoi(value);
91 else if (!strcmp(name, "cache-dynamic-ttl")) 91 else if (!strcmp(name, "cache-dynamic-ttl"))
92 ctx.cfg.cache_dynamic_ttl = atoi(value); 92 ctx.cfg.cache_dynamic_ttl = atoi(value);
93 else if (!strcmp(name, "embedded")) 93 else if (!strcmp(name, "embedded"))
94 ctx.cfg.embedded = atoi(value); 94 ctx.cfg.embedded = atoi(value);
95 else if (!strcmp(name, "max-message-length")) 95 else if (!strcmp(name, "max-message-length"))
96 ctx.cfg.max_msg_len = atoi(value); 96 ctx.cfg.max_msg_len = atoi(value);
97 else if (!strcmp(name, "max-repodesc-length")) 97 else if (!strcmp(name, "max-repodesc-length"))
98 ctx.cfg.max_repodesc_len = atoi(value); 98 ctx.cfg.max_repodesc_len = atoi(value);
99 else if (!strcmp(name, "max-repo-count")) 99 else if (!strcmp(name, "max-repo-count"))
100 ctx.cfg.max_repo_count = atoi(value); 100 ctx.cfg.max_repo_count = atoi(value);
101 else if (!strcmp(name, "max-commit-count")) 101 else if (!strcmp(name, "max-commit-count"))
102 ctx.cfg.max_commit_count = atoi(value); 102 ctx.cfg.max_commit_count = atoi(value);
103 else if (!strcmp(name, "source-filter"))
104 ctx.cfg.source_filter = new_filter(value, 1);
103 else if (!strcmp(name, "summary-log")) 105 else if (!strcmp(name, "summary-log"))
104 ctx.cfg.summary_log = atoi(value); 106 ctx.cfg.summary_log = atoi(value);
105 else if (!strcmp(name, "summary-branches")) 107 else if (!strcmp(name, "summary-branches"))
106 ctx.cfg.summary_branches = atoi(value); 108 ctx.cfg.summary_branches = atoi(value);
107 else if (!strcmp(name, "summary-tags")) 109 else if (!strcmp(name, "summary-tags"))
108 ctx.cfg.summary_tags = atoi(value); 110 ctx.cfg.summary_tags = atoi(value);
109 else if (!strcmp(name, "agefile")) 111 else if (!strcmp(name, "agefile"))
110 ctx.cfg.agefile = xstrdup(value); 112 ctx.cfg.agefile = xstrdup(value);
111 else if (!strcmp(name, "renamelimit")) 113 else if (!strcmp(name, "renamelimit"))
112 ctx.cfg.renamelimit = atoi(value); 114 ctx.cfg.renamelimit = atoi(value);
113 else if (!strcmp(name, "robots")) 115 else if (!strcmp(name, "robots"))
114 ctx.cfg.robots = xstrdup(value); 116 ctx.cfg.robots = xstrdup(value);
115 else if (!strcmp(name, "clone-prefix")) 117 else if (!strcmp(name, "clone-prefix"))
116 ctx.cfg.clone_prefix = xstrdup(value); 118 ctx.cfg.clone_prefix = xstrdup(value);
117 else if (!strcmp(name, "local-time")) 119 else if (!strcmp(name, "local-time"))
118 ctx.cfg.local_time = atoi(value); 120 ctx.cfg.local_time = atoi(value);
119 else if (!strcmp(name, "repo.group")) 121 else if (!strcmp(name, "repo.group"))
120 ctx.cfg.repo_group = xstrdup(value); 122 ctx.cfg.repo_group = xstrdup(value);
121 else if (!strcmp(name, "repo.url")) 123 else if (!strcmp(name, "repo.url"))
122 ctx.repo = cgit_add_repo(value); 124 ctx.repo = cgit_add_repo(value);
123 else if (!strcmp(name, "repo.name")) 125 else if (!strcmp(name, "repo.name"))
124 ctx.repo->name = xstrdup(value); 126 ctx.repo->name = xstrdup(value);
125 else if (ctx.repo && !strcmp(name, "repo.path")) 127 else if (ctx.repo && !strcmp(name, "repo.path"))
126 ctx.repo->path = trim_end(value, '/'); 128 ctx.repo->path = trim_end(value, '/');
127 else if (ctx.repo && !strcmp(name, "repo.clone-url")) 129 else if (ctx.repo && !strcmp(name, "repo.clone-url"))
128 ctx.repo->clone_url = xstrdup(value); 130 ctx.repo->clone_url = xstrdup(value);
129 else if (ctx.repo && !strcmp(name, "repo.desc")) 131 else if (ctx.repo && !strcmp(name, "repo.desc"))
130 ctx.repo->desc = xstrdup(value); 132 ctx.repo->desc = xstrdup(value);
131 else if (ctx.repo && !strcmp(name, "repo.owner")) 133 else if (ctx.repo && !strcmp(name, "repo.owner"))
132 ctx.repo->owner = xstrdup(value); 134 ctx.repo->owner = xstrdup(value);
133 else if (ctx.repo && !strcmp(name, "repo.defbranch")) 135 else if (ctx.repo && !strcmp(name, "repo.defbranch"))
134 ctx.repo->defbranch = xstrdup(value); 136 ctx.repo->defbranch = xstrdup(value);
135 else if (ctx.repo && !strcmp(name, "repo.snapshots")) 137 else if (ctx.repo && !strcmp(name, "repo.snapshots"))
136 ctx.repo->snapshots = ctx.cfg.snapshots & cgit_parse_snapshots_mask(value); /* XXX: &? */ 138 ctx.repo->snapshots = ctx.cfg.snapshots & cgit_parse_snapshots_mask(value); /* XXX: &? */
137 else if (ctx.repo && !strcmp(name, "repo.enable-log-filecount")) 139 else if (ctx.repo && !strcmp(name, "repo.enable-log-filecount"))
138 ctx.repo->enable_log_filecount = ctx.cfg.enable_log_filecount * atoi(value); 140 ctx.repo->enable_log_filecount = ctx.cfg.enable_log_filecount * atoi(value);
139 else if (ctx.repo && !strcmp(name, "repo.enable-log-linecount")) 141 else if (ctx.repo && !strcmp(name, "repo.enable-log-linecount"))
140 ctx.repo->enable_log_linecount = ctx.cfg.enable_log_linecount * atoi(value); 142 ctx.repo->enable_log_linecount = ctx.cfg.enable_log_linecount * atoi(value);
141 else if (ctx.repo && !strcmp(name, "repo.max-stats")) 143 else if (ctx.repo && !strcmp(name, "repo.max-stats"))
142 ctx.repo->max_stats = cgit_find_stats_period(value, NULL); 144 ctx.repo->max_stats = cgit_find_stats_period(value, NULL);
143 else if (ctx.repo && !strcmp(name, "repo.module-link")) 145 else if (ctx.repo && !strcmp(name, "repo.module-link"))
144 ctx.repo->module_link= xstrdup(value); 146 ctx.repo->module_link= xstrdup(value);
145 else if (ctx.repo && !strcmp(name, "repo.readme") && value != NULL) { 147 else if (ctx.repo && !strcmp(name, "repo.readme") && value != NULL) {
146 if (*value == '/') 148 if (*value == '/')
147 ctx.repo->readme = xstrdup(value); 149 ctx.repo->readme = xstrdup(value);
148 else 150 else
149 ctx.repo->readme = xstrdup(fmt("%s/%s", ctx.repo->path, value)); 151 ctx.repo->readme = xstrdup(fmt("%s/%s", ctx.repo->path, value));
150 } else if (!strcmp(name, "include")) 152 } else if (!strcmp(name, "include"))