From 169f8e06cb738e1c22b384a50cdd5a76e3f75e08 Mon Sep 17 00:00:00 2001
From: Michael Pailloncy <mpapo.dev@gmail.com>
Date: Thu, 30 May 2013 16:23:34 -0400
Subject: [PATCH] add --all-local-branches to add all local branches of the repo to index

---
 src/main/java/com/gitblit/AddIndexedBranch.java |   23 ++++++++++++++++++++---
 1 files changed, 20 insertions(+), 3 deletions(-)

diff --git a/src/main/java/com/gitblit/AddIndexedBranch.java b/src/main/java/com/gitblit/AddIndexedBranch.java
index 6ae424e..7a16bbd 100644
--- a/src/main/java/com/gitblit/AddIndexedBranch.java
+++ b/src/main/java/com/gitblit/AddIndexedBranch.java
@@ -33,6 +33,7 @@
 import com.beust.jcommander.Parameter;
 import com.beust.jcommander.ParameterException;
 import com.beust.jcommander.Parameters;
+import com.gitblit.models.RefModel;
 import com.gitblit.utils.ArrayUtils;
 import com.gitblit.utils.JGitUtils;
 import com.gitblit.utils.StringUtils;
@@ -83,7 +84,7 @@
 				continue;
 			}
 
-			System.out.println(MessageFormat.format("adding [gitblit] indexBranch={0} for {1}", params.branch, repo));
+			
 			try {
 				// load repository config
 				File gitDir = FileKey.resolve(new File(folder, repo), FS.DETECTED);
@@ -92,7 +93,20 @@
 				config.load();
 				
 				Set<String> indexedBranches = new LinkedHashSet<String>();
-				indexedBranches.add(params.branch);
+				
+				// add all local branches to index
+				if(params.addAllLocalBranches) {
+					List<RefModel> list = JGitUtils.getLocalBranches(repository, true, -1);
+					for (RefModel refModel : list) {
+						System.out.println(MessageFormat.format("adding [gitblit] indexBranch={0} for {1}", refModel.getName(), repo));
+						indexedBranches.add(refModel.getName());
+					}
+				}
+				else {
+					// add only one branch to index ('default' if not specified)
+					System.out.println(MessageFormat.format("adding [gitblit] indexBranch={0} for {1}", params.branch, repo));
+					indexedBranches.add(params.branch);
+				}
 				
 				String [] branches = config.getStringList("gitblit", null, "indexBranch");
 				if (!ArrayUtils.isEmpty(branches)) {
@@ -123,10 +137,13 @@
 		@Parameter(names = { "--repositoriesFolder" }, description = "The root repositories folder ", required = true)
 		public String folder;
 
-		@Parameter(names = { "--branch" }, description = "The branch to index", required = true)
+		@Parameter(names = { "--branch" }, description = "The branch to index", required = false)
 		public String branch = "default";
 
 		@Parameter(names = { "--skip" }, description = "Skip the named repository (simple fizzy matching is supported)", required = false)
 		public List<String> exclusions = new ArrayList<String>();
+		
+		@Parameter(names = { "--all-local-branches" }, description = "Add all local branches to index. If specified, the --branch parameter is not considered.", required = false)
+		public boolean addAllLocalBranches = false;
 	}
 }

--
Gitblit v1.9.1