diff options
author | Shawn O. Pearce <spearce@spearce.org> | 2010-09-01 12:29:40 -0700 |
---|---|---|
committer | Shawn O. Pearce <spearce@spearce.org> | 2010-09-02 11:38:39 -0700 |
commit | fed508d55b8dcc3b9a3318b289e3eaaadd3ecb29 (patch) | |
tree | 3cff0a0c958beddae85115954412c09e14983405 /org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Diff.java | |
parent | 59a262d5d27136fa87795feffc7ca029877a2bca (diff) | |
download | jgit-fed508d55b8dcc3b9a3318b289e3eaaadd3ecb29.tar.gz jgit-fed508d55b8dcc3b9a3318b289e3eaaadd3ecb29.zip |
diff: Default arguments to HEAD, working directory
Similar to C Git, default our difference when no trees are given
to us to something that makes a tiny bit of sense to the human.
We also now support the --cached flag, and have its meaning work the
same way as C Git.
Change-Id: I2f19dad4e018404e280ea3e95ebd448a4b667f59
Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
Diffstat (limited to 'org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Diff.java')
-rw-r--r-- | org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Diff.java | 40 |
1 files changed, 36 insertions, 4 deletions
diff --git a/org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Diff.java b/org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Diff.java index ec939b37e4..7a4aed71ea 100644 --- a/org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Diff.java +++ b/org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Diff.java @@ -45,8 +45,12 @@ package org.eclipse.jgit.pgm; +import static org.eclipse.jgit.lib.Constants.HEAD; +import static org.eclipse.jgit.lib.Constants.OBJECT_ID_STRING_LENGTH; + import java.io.BufferedOutputStream; import java.io.PrintWriter; +import java.text.MessageFormat; import java.util.List; import org.eclipse.jgit.diff.DiffEntry; @@ -56,10 +60,14 @@ import org.eclipse.jgit.diff.RawTextIgnoreLeadingWhitespace; import org.eclipse.jgit.diff.RawTextIgnoreTrailingWhitespace; import org.eclipse.jgit.diff.RawTextIgnoreWhitespaceChange; import org.eclipse.jgit.diff.RenameDetector; -import org.eclipse.jgit.lib.Constants; +import org.eclipse.jgit.dircache.DirCacheIterator; +import org.eclipse.jgit.lib.ObjectId; +import org.eclipse.jgit.lib.ObjectReader; import org.eclipse.jgit.lib.TextProgressMonitor; import org.eclipse.jgit.pgm.opt.PathTreeFilterHandler; import org.eclipse.jgit.treewalk.AbstractTreeIterator; +import org.eclipse.jgit.treewalk.CanonicalTreeParser; +import org.eclipse.jgit.treewalk.FileTreeIterator; import org.eclipse.jgit.treewalk.filter.TreeFilter; import org.kohsuke.args4j.Argument; import org.kohsuke.args4j.Option; @@ -69,12 +77,15 @@ class Diff extends TextBuiltin { private final DiffFormatter diffFmt = new DiffFormatter( // new BufferedOutputStream(System.out)); - @Argument(index = 0, metaVar = "metaVar_treeish", required = true) + @Argument(index = 0, metaVar = "metaVar_treeish") private AbstractTreeIterator oldTree; - @Argument(index = 1, metaVar = "metaVar_treeish", required = true) + @Argument(index = 1, metaVar = "metaVar_treeish") private AbstractTreeIterator newTree; + @Option(name = "--cached", usage = "usage_cached") + private boolean cached; + @Option(name = "--", metaVar = "metaVar_paths", multiValued = true, handler = PathTreeFilterHandler.class) private TreeFilter pathFilter = TreeFilter.ALL; @@ -128,7 +139,7 @@ class Diff extends TextBuiltin { @Option(name = "--full-index") void abbrev(@SuppressWarnings("unused") boolean on) { - diffFmt.setAbbreviationLength(Constants.OBJECT_ID_STRING_LENGTH); + diffFmt.setAbbreviationLength(OBJECT_ID_STRING_LENGTH); } @Option(name = "--src-prefix", usage = "usage_srcPrefix") @@ -153,6 +164,27 @@ class Diff extends TextBuiltin { protected void run() throws Exception { diffFmt.setRepository(db); try { + if (cached) { + if (oldTree == null) { + ObjectId head = db.resolve(HEAD + "^{tree}"); + if (head == null) + die(MessageFormat.format(CLIText.get().notATree, HEAD)); + CanonicalTreeParser p = new CanonicalTreeParser(); + ObjectReader reader = db.newObjectReader(); + try { + p.reset(reader, head); + } finally { + reader.release(); + } + oldTree = p; + } + newTree = new DirCacheIterator(db.readDirCache()); + } else if (oldTree == null) { + oldTree = new DirCacheIterator(db.readDirCache()); + newTree = new FileTreeIterator(db); + } else if (newTree == null) + newTree = new FileTreeIterator(db); + diffFmt.setProgressMonitor(new TextProgressMonitor()); diffFmt.setPathFilter(pathFilter); if (detectRenames != null) |