[PATCH 2/4] Introduce "dont-display-suffix" option

Julius Plenz plenz at cis.fu-berlin.de
Tue Oct 30 14:07:16 CET 2012


This will make the scan-path run return a repository name without .git
suffix (as remove-suffix would do), but leaves this suffix in the URL
parameter.

Signed-off-by: Julius Plenz <plenz at cis.fu-berlin.de>
---
 cgit.c      |  2 ++
 cgit.h      |  1 +
 scan-tree.c | 11 ++++++++---
 3 files changed, 11 insertions(+), 3 deletions(-)

diff --git a/cgit.c b/cgit.c
index b9b3a66..f1105fb 100644
--- a/cgit.c
+++ b/cgit.c
@@ -247,6 +247,8 @@ void config_cb(const char *name, const char *value)
 		ctx.cfg.renamelimit = atoi(value);
 	else if (!strcmp(name, "remove-suffix"))
 		ctx.cfg.remove_suffix = atoi(value);
+	else if (!strcmp(name, "dont-display-suffix"))
+		ctx.cfg.dont_display_suffix = atoi(value);
 	else if (!strcmp(name, "robots"))
 		ctx.cfg.robots = xstrdup(value);
 	else if (!strcmp(name, "clone-prefix"))
diff --git a/cgit.h b/cgit.h
index 6ee6769..5692224 100644
--- a/cgit.h
+++ b/cgit.h
@@ -221,6 +221,7 @@ struct cgit_config {
 	int noheader;
 	int renamelimit;
 	int remove_suffix;
+	int dont_display_suffix;
 	int scan_hidden_path;
 	int section_from_path;
 	int snapshots;
diff --git a/scan-tree.c b/scan-tree.c
index 378d795..e33927e 100644
--- a/scan-tree.c
+++ b/scan-tree.c
@@ -100,10 +100,15 @@ static void add_repo(const char *base, const char *path, repo_config_fn fn)
 		rel[strlen(rel) - 5] = '\0';
 
 	repo = cgit_add_repo(rel);
-	if (ctx.cfg.remove_suffix)
-		if ((p = strrchr(repo->url, '.')) && !strcmp(p, ".git"))
+	if ((p = strrchr(repo->url, '.')) && !strcmp(p, ".git")) {
+		if (ctx.cfg.remove_suffix)
 			*p = '\0';
-	repo->name = repo->url;
+		else if (ctx.cfg.dont_display_suffix) {
+			repo->name = xstrdup(repo->url);
+			repo->name[strlen(repo->name) - 4] = '\0';
+		}
+	} else
+		repo->name = repo->url;
 	repo->path = xstrdup(path);
 	while (!owner) {
 		if ((pwd = getpwuid(st.st_uid)) == NULL) {
-- 
1.7.12.3-zedat





More information about the CGit mailing list