diff options
author | Robin Stocker <robin@nibor.org> | 2014-01-14 17:46:26 +0100 |
---|---|---|
committer | Matthias Sohn <matthias.sohn@sap.com> | 2014-03-07 18:24:42 -0500 |
commit | 31fec678d858bc6fa6456ac7e6ec2d77bf1f6f99 (patch) | |
tree | 332b44732477f70fcce42ffe194b23320f64f995 /org.eclipse.jgit.pgm/src | |
parent | f6f3fe46fcdc0f76bc5b50efa18176510ccb5503 (diff) | |
download | jgit-31fec678d858bc6fa6456ac7e6ec2d77bf1f6f99.tar.gz jgit-31fec678d858bc6fa6456ac7e6ec2d77bf1f6f99.zip |
Implement "git branch --contains" in pgm
Bug: 425678
Change-Id: Ib59e05a0bde58562cc61e6e3000df761660b468e
Signed-off-by: Robin Stocker <robin@nibor.org>
Diffstat (limited to 'org.eclipse.jgit.pgm/src')
-rw-r--r-- | org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Branch.java | 48 |
1 files changed, 31 insertions, 17 deletions
diff --git a/org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Branch.java b/org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Branch.java index 0307a6073e..7147544d1b 100644 --- a/org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Branch.java +++ b/org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Branch.java @@ -43,16 +43,18 @@ package org.eclipse.jgit.pgm; -import static org.eclipse.jgit.lib.RefDatabase.ALL; - import java.io.IOException; import java.text.MessageFormat; import java.util.ArrayList; +import java.util.Collection; import java.util.LinkedHashMap; import java.util.List; import java.util.Map; import java.util.Map.Entry; +import org.eclipse.jgit.api.Git; +import org.eclipse.jgit.api.ListBranchCommand; +import org.eclipse.jgit.api.ListBranchCommand.ListMode; import org.eclipse.jgit.lib.Constants; import org.eclipse.jgit.lib.ObjectId; import org.eclipse.jgit.lib.ObjectReader; @@ -60,8 +62,8 @@ import org.eclipse.jgit.lib.Ref; import org.eclipse.jgit.lib.RefComparator; import org.eclipse.jgit.lib.RefRename; import org.eclipse.jgit.lib.RefUpdate; -import org.eclipse.jgit.lib.Repository; import org.eclipse.jgit.lib.RefUpdate.Result; +import org.eclipse.jgit.lib.Repository; import org.eclipse.jgit.pgm.internal.CLIText; import org.eclipse.jgit.pgm.opt.CmdLineParser; import org.eclipse.jgit.revwalk.RevWalk; @@ -78,6 +80,9 @@ class Branch extends TextBuiltin { @Option(name = "--all", aliases = { "-a" }, usage = "usage_listBothRemoteTrackingAndLocalBranches") private boolean all = false; + @Option(name = "--contains", metaVar = "metaVar_commitish", usage = "usage_printOnlyBranchesThatContainTheCommit") + private String containsCommitish; + @Option(name = "--delete", aliases = { "-d" }, usage = "usage_deleteFullyMergedBranch") private boolean delete = false; @@ -177,15 +182,27 @@ class Branch extends TextBuiltin { } private void list() throws Exception { - Map<String, Ref> refs = db.getRefDatabase().getRefs(ALL); - Ref head = refs.get(Constants.HEAD); + Ref head = db.getRef(Constants.HEAD); // This can happen if HEAD is stillborn if (head != null) { String current = head.getLeaf().getName(); - if (current.equals(Constants.HEAD)) - addRef("(no branch)", head); //$NON-NLS-1$ - addRefs(refs, Constants.R_HEADS, !remote); - addRefs(refs, Constants.R_REMOTES, remote); + ListBranchCommand command = new Git(db).branchList(); + if (all) + command.setListMode(ListMode.ALL); + else if (remote) + command.setListMode(ListMode.REMOTE); + + if (containsCommitish != null) + command.setContains(containsCommitish); + + List<Ref> refs = command.call(); + for (Ref ref : refs) { + if (ref.getName().equals(Constants.HEAD)) + addRef("(no branch)", head); //$NON-NLS-1$ + } + + addRefs(refs, Constants.R_HEADS); + addRefs(refs, Constants.R_REMOTES); ObjectReader reader = db.newObjectReader(); try { @@ -200,14 +217,11 @@ class Branch extends TextBuiltin { } } - private void addRefs(final Map<String, Ref> allRefs, final String prefix, - final boolean add) { - if (all || add) { - for (final Ref ref : RefComparator.sort(allRefs.values())) { - final String name = ref.getName(); - if (name.startsWith(prefix)) - addRef(name.substring(name.indexOf('/', 5) + 1), ref); - } + private void addRefs(final Collection<Ref> refs, final String prefix) { + for (final Ref ref : RefComparator.sort(refs)) { + final String name = ref.getName(); + if (name.startsWith(prefix)) + addRef(name.substring(name.indexOf('/', 5) + 1), ref); } } |