item->util = xstrdup(value);
}
+static void add_render_filter(const char *name, const char *cmd)
+{
+ struct string_list_item *item;
+ struct cgit_filter *filter = cgit_new_filter(cmd, RENDER);
+
+ if (!filter)
+ return;
+
+ item = string_list_insert(&ctx.cfg.render_filters, name);
+ item->util = filter;
+}
+
static void process_cached_repolist(const char *path);
static void repo_config(struct cgit_repo *repo, const char *name, const char *value)
ctx.cfg.branch_sort = 1;
if (!strcmp(value, "name"))
ctx.cfg.branch_sort = 0;
- } else if (skip_prefix(name, "mimetype.", &arg))
- add_mimetype(arg, value);
+ } else if (starts_with(name, "mimetype."))
+ add_mimetype(name + 9, value);
+ else if (starts_with(name, "render."))
+ add_render_filter(name + 7, value);
else if (!strcmp(name, "include"))
parse_configfile(expand_macros(value), config_cb);
}
ctx.page.expires = ctx.page.modified;
ctx.page.etag = NULL;
string_list_init(&ctx.cfg.mimetypes, 1);
+ string_list_init(&ctx.cfg.render_filters, 1);
if (ctx.env.script_name)
ctx.cfg.script_name = xstrdup(ctx.env.script_name);
if (ctx.env.query_string)
} diff_type;
typedef enum {
- ABOUT, COMMIT, SOURCE, EMAIL, AUTH, OWNER
+ ABOUT, COMMIT, SOURCE, EMAIL, AUTH, OWNER, RENDER
} filter_type;
struct cgit_filter {
int branch_sort;
int commit_sort;
struct string_list mimetypes;
+ struct string_list render_filters;
struct cgit_filter *about_filter;
struct cgit_filter *commit_filter;
struct cgit_filter *source_filter;
extern char *expand_macros(const char *txt);
extern char *get_mimetype_for_filename(const char *filename);
+extern struct cgit_filter *get_render_for_filename(const char *filename);
#endif /* CGIT_H */
"-1" uses the compiletime value in git (for further info, look at
`man git-diff`). Default value: "-1".
+render.<ext>::
+ Specifies a command which will be invoked to render files with the
+ extension `.<ext>`. The command will get the blob content on its STDIN
+ and the name of the blob as its only command line argument. The STDOUT
+ from the command will be included verbatim in the page content. If no
+ render filter is available for a given file extension but the mimetype
+ is specified then the content will be included as an iframe, otherwise
+ the normal source rendering will be used. Note <ext> may be empty, in
+ which case the render filter is used on files with no suffix.
++
+Default value: none. See also: "FILTER API".
+
repository-sort::
The way in which repositories in each section are sorted. Valid values
are "name" for sorting by the repo name or "age" for sorting by the
standard input and the filter is expected to write to standard
output. The output is included in the Owner column.
+render filter::
+ This filter is given a single parameter: the filename of the source
+ file to render. The filter can use the filename to determine (for
+ example) the syntax highlighting mode. The contents of the file that
+ is to be rendered is available on standard input and the rendered
+ content is expected on standard output.
+
source filter::
This filter is given a single parameter: the filename of the source
file to filter. The filter can use the filename to determine (for
case SOURCE:
case ABOUT:
+ case RENDER:
argument_count = 1;
break;
fclose(file);
return NULL;
}
+
+struct cgit_filter *get_render_for_filename(const char *filename)
+{
+ char *ext;
+ struct string_list_item *item;
+
+ if (!filename)
+ return NULL;
+
+ ext = strrchr(filename, '.');
+ if (!ext)
+ ext = ".";
+ ++ext;
+ item = string_list_lookup(&ctx.cfg.render_filters, ext);
+ if (item)
+ return item->util;
+
+ return NULL;
+}