aboutsummaryrefslogtreecommitdiffstats
path: root/org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Diff.java
diff options
context:
space:
mode:
authorShawn O. Pearce <spearce@spearce.org>2010-09-01 12:29:40 -0700
committerShawn O. Pearce <spearce@spearce.org>2010-09-02 11:38:39 -0700
commitfed508d55b8dcc3b9a3318b289e3eaaadd3ecb29 (patch)
tree3cff0a0c958beddae85115954412c09e14983405 /org.eclipse.jgit.pgm/src/org/eclipse/jgit/pgm/Diff.java
parent59a262d5d27136fa87795feffc7ca029877a2bca (diff)
downloadjgit-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.java40
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)