Signed-off-by: Charles O'Farrell <charleso@xxxxxxxxxxxx> --- .../src/org/spearce/jgit/pgm/Branch.java | 34 +++++++++++++++---- 1 files changed, 27 insertions(+), 7 deletions(-) diff --git a/org.spearce.jgit.pgm/src/org/spearce/jgit/pgm/Branch.java b/org.spearce.jgit.pgm/src/org/spearce/jgit/pgm/Branch.java index 9141be0..ba8ffde 100644 --- a/org.spearce.jgit.pgm/src/org/spearce/jgit/pgm/Branch.java +++ b/org.spearce.jgit.pgm/src/org/spearce/jgit/pgm/Branch.java @@ -52,6 +52,7 @@ import org.spearce.jgit.lib.RefComparator; import org.spearce.jgit.lib.RefUpdate; import org.spearce.jgit.lib.RefUpdate.Result; +import org.spearce.jgit.revwalk.RevWalk; @Command(common = true, usage = "List, create, or delete branches") class Branch extends TextBuiltin { @@ -76,15 +77,23 @@ private Map<String, Ref> printRefs = new LinkedHashMap<String, Ref>(); + /** Only set for verbose branch listing at-the-moment */ + private RevWalk rw; + + private int maxNameLength; + @Override protected void run() throws Exception { if (delete || deleteForce) delete(deleteForce); - else + else { + if (verbose) + rw = new RevWalk(db); list(); + } } - private void list() { + private void list() throws Exception { Map<String, Ref> refs = db.getAllRefs(); Ref head = refs.get(Constants.HEAD); // This can happen if HEAD is stillborn @@ -95,7 +104,8 @@ private void list() { addRefs(refs, Constants.HEADS_PREFIX, !remote); addRefs(refs, Constants.REMOTES_PREFIX, remote); for (Entry<String, Ref> e : printRefs.entrySet()) { - printHead(e.getKey(), current.equals(e.getValue().getName())); + Ref ref = e.getValue(); + printHead(e.getKey(), current.equals(ref.getName()), ref); } } } @@ -105,20 +115,30 @@ private void addRefs(Map<String, Ref> allRefs, String prefix, boolean add) { for (Ref ref : RefComparator.sort(allRefs.values())) { String name = ref.getName(); if (name.startsWith(prefix)) - addRef(name, ref); + addRef(name.substring(name.indexOf('/', 5) + 1), ref); } } } private void addRef(String name, Ref ref) { printRefs.put(name, ref); + maxNameLength = Math.max(maxNameLength, name.length()); } - private void printHead(String ref, boolean isCurrent) { + private void printHead(String ref, boolean isCurrent, Ref refObj) + throws Exception { out.print(isCurrent ? '*' : ' '); out.print(' '); - ref = ref.substring(ref.indexOf('/', 5) + 1); - out.println(ref); + out.print(ref); + if (verbose) { + int spaces = maxNameLength - ref.length() + 1; + out.print(String.format("%" + spaces + "s", "")); + ObjectId objectId = refObj.getObjectId(); + out.print(objectId.toString().substring(0, 7)); + out.print(' '); + out.print(rw.parseCommit(objectId).getShortMessage()); + } + out.println(); } private void delete(boolean force) throws IOException { -- 1.6.0.2.g2ebc0 -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html