Merge branch 'jh/scan-path'
* jh/scan-path: scan_path(): Do not recurse into hidden directories by default scan_path(): Improve handling of inaccessible directories
This commit is contained in:
commit
fb9e6d1594
3
cgit.c
3
cgit.c
@ -199,6 +199,8 @@ void config_cb(const char *name, const char *value)
|
|||||||
ctx.cfg.project_list, repo_config);
|
ctx.cfg.project_list, repo_config);
|
||||||
else
|
else
|
||||||
scan_tree(expand_macros(value), repo_config);
|
scan_tree(expand_macros(value), repo_config);
|
||||||
|
else if (!strcmp(name, "scan-hidden-path"))
|
||||||
|
ctx.cfg.scan_hidden_path = atoi(value);
|
||||||
else if (!strcmp(name, "section-from-path"))
|
else if (!strcmp(name, "section-from-path"))
|
||||||
ctx.cfg.section_from_path = atoi(value);
|
ctx.cfg.section_from_path = atoi(value);
|
||||||
else if (!strcmp(name, "source-filter"))
|
else if (!strcmp(name, "source-filter"))
|
||||||
@ -319,6 +321,7 @@ static void prepare_context(struct cgit_context *ctx)
|
|||||||
ctx->cfg.robots = "index, nofollow";
|
ctx->cfg.robots = "index, nofollow";
|
||||||
ctx->cfg.root_title = "Git repository browser";
|
ctx->cfg.root_title = "Git repository browser";
|
||||||
ctx->cfg.root_desc = "a fast webinterface for the git dscm";
|
ctx->cfg.root_desc = "a fast webinterface for the git dscm";
|
||||||
|
ctx->cfg.scan_hidden_path = 0;
|
||||||
ctx->cfg.script_name = CGIT_SCRIPT_NAME;
|
ctx->cfg.script_name = CGIT_SCRIPT_NAME;
|
||||||
ctx->cfg.section = "";
|
ctx->cfg.section = "";
|
||||||
ctx->cfg.summary_branches = 10;
|
ctx->cfg.summary_branches = 10;
|
||||||
|
1
cgit.h
1
cgit.h
@ -210,6 +210,7 @@ struct cgit_config {
|
|||||||
int noheader;
|
int noheader;
|
||||||
int renamelimit;
|
int renamelimit;
|
||||||
int remove_suffix;
|
int remove_suffix;
|
||||||
|
int scan_hidden_path;
|
||||||
int section_from_path;
|
int section_from_path;
|
||||||
int snapshots;
|
int snapshots;
|
||||||
int summary_branches;
|
int summary_branches;
|
||||||
|
@ -274,6 +274,14 @@ root-title::
|
|||||||
Text printed as heading on the repository index page. Default value:
|
Text printed as heading on the repository index page. Default value:
|
||||||
"Git Repository Browser".
|
"Git Repository Browser".
|
||||||
|
|
||||||
|
scan-hidden-path::
|
||||||
|
If set to "1" and scan-path is enabled, scan-path will recurse into
|
||||||
|
directories whose name starts with a period ('.'). Otherwise,
|
||||||
|
scan-path will stay away from such directories (considered as
|
||||||
|
"hidden"). Note that this does not apply to the ".git" directory in
|
||||||
|
non-bare repos. This must be defined prior to scan-path.
|
||||||
|
Default value: 0. See also: scan-path.
|
||||||
|
|
||||||
scan-path::
|
scan-path::
|
||||||
A path which will be scanned for repositories. If caching is enabled,
|
A path which will be scanned for repositories. If caching is enabled,
|
||||||
the result will be cached as a cgitrc include-file in the cache
|
the result will be cached as a cgitrc include-file in the cache
|
||||||
|
22
scan-tree.c
22
scan-tree.c
@ -159,31 +159,32 @@ static void add_repo(const char *base, const char *path, repo_config_fn fn)
|
|||||||
|
|
||||||
static void scan_path(const char *base, const char *path, repo_config_fn fn)
|
static void scan_path(const char *base, const char *path, repo_config_fn fn)
|
||||||
{
|
{
|
||||||
DIR *dir;
|
DIR *dir = opendir(path);
|
||||||
struct dirent *ent;
|
struct dirent *ent;
|
||||||
char *buf;
|
char *buf;
|
||||||
struct stat st;
|
struct stat st;
|
||||||
|
|
||||||
if (is_git_dir(path)) {
|
|
||||||
add_repo(base, path, fn);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (is_git_dir(fmt("%s/.git", path))) {
|
|
||||||
add_repo(base, fmt("%s/.git", path), fn);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
dir = opendir(path);
|
|
||||||
if (!dir) {
|
if (!dir) {
|
||||||
fprintf(stderr, "Error opening directory %s: %s (%d)\n",
|
fprintf(stderr, "Error opening directory %s: %s (%d)\n",
|
||||||
path, strerror(errno), errno);
|
path, strerror(errno), errno);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
if (is_git_dir(path)) {
|
||||||
|
add_repo(base, path, fn);
|
||||||
|
goto end;
|
||||||
|
}
|
||||||
|
if (is_git_dir(fmt("%s/.git", path))) {
|
||||||
|
add_repo(base, fmt("%s/.git", path), fn);
|
||||||
|
goto end;
|
||||||
|
}
|
||||||
while((ent = readdir(dir)) != NULL) {
|
while((ent = readdir(dir)) != NULL) {
|
||||||
if (ent->d_name[0] == '.') {
|
if (ent->d_name[0] == '.') {
|
||||||
if (ent->d_name[1] == '\0')
|
if (ent->d_name[1] == '\0')
|
||||||
continue;
|
continue;
|
||||||
if (ent->d_name[1] == '.' && ent->d_name[2] == '\0')
|
if (ent->d_name[1] == '.' && ent->d_name[2] == '\0')
|
||||||
continue;
|
continue;
|
||||||
|
if (!ctx.cfg.scan_hidden_path)
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
buf = malloc(strlen(path) + strlen(ent->d_name) + 2);
|
buf = malloc(strlen(path) + strlen(ent->d_name) + 2);
|
||||||
if (!buf) {
|
if (!buf) {
|
||||||
@ -202,6 +203,7 @@ static void scan_path(const char *base, const char *path, repo_config_fn fn)
|
|||||||
scan_path(base, buf, fn);
|
scan_path(base, buf, fn);
|
||||||
free(buf);
|
free(buf);
|
||||||
}
|
}
|
||||||
|
end:
|
||||||
closedir(dir);
|
closedir(dir);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user