From 5cc48016caf4de3ecce6fbf2f2a34d3bde99edb6 Mon Sep 17 00:00:00 2001 From: James Moger <james.moger@gitblit.com> Date: Thu, 10 Apr 2014 18:58:10 -0400 Subject: [PATCH] Support regex filtering the projects, repositories, and users list --- src/main/java/com/gitblit/transport/ssh/gitblit/RepositoriesDispatcher.java | 26 +++++++++++++++++++++++--- 1 files changed, 23 insertions(+), 3 deletions(-) diff --git a/src/main/java/com/gitblit/transport/ssh/gitblit/RepositoriesDispatcher.java b/src/main/java/com/gitblit/transport/ssh/gitblit/RepositoriesDispatcher.java index 329e95e..ab974dc 100644 --- a/src/main/java/com/gitblit/transport/ssh/gitblit/RepositoriesDispatcher.java +++ b/src/main/java/com/gitblit/transport/ssh/gitblit/RepositoriesDispatcher.java @@ -16,9 +16,12 @@ package com.gitblit.transport.ssh.gitblit; import java.text.SimpleDateFormat; +import java.util.ArrayList; import java.util.List; +import org.kohsuke.args4j.Argument; import org.kohsuke.args4j.Option; +import org.parboiled.common.StringUtils; import com.gitblit.manager.IGitblit; import com.gitblit.models.RepositoryModel; @@ -49,16 +52,33 @@ @Option(name = "--tabbed", aliases = { "-t" }, usage = "as tabbed output") private boolean tabbed; + @Argument(index = 0, metaVar = "REGEX", usage = "regex filter expression") + protected String regexFilter; + @Override public void run() { IGitblit gitblit = getContext().getGitblit(); UserModel user = getContext().getClient().getUser(); List<RepositoryModel> repositories = gitblit.getRepositoryModels(user); - if (tabbed) { - asTabbed(repositories); + List<RepositoryModel> filtered; + if (StringUtils.isEmpty(regexFilter)) { + // no regex filter + filtered = repositories; } else { - asTable(repositories); + // regex filter the list + filtered = new ArrayList<RepositoryModel>(); + for (RepositoryModel r : repositories) { + if (r.name.matches(regexFilter)) { + filtered.add(r); + } + } + } + + if (tabbed) { + asTabbed(filtered); + } else { + asTable(filtered); } } -- Gitblit v1.9.1