]> source.dussan.org Git - jgit.git/commitdiff
IndexDiff: Always use TreeWalk.getPathString() 69/2069/2
authorShawn O. Pearce <spearce@spearce.org>
Wed, 8 Dec 2010 02:42:10 +0000 (18:42 -0800)
committerShawn O. Pearce <spearce@spearce.org>
Wed, 8 Dec 2010 18:03:20 +0000 (10:03 -0800)
Instead of asking the individual iterators for their path string, use
the TreeWalk's generic getPathString() method.  Its just as fast
because it uses the path of the current matching iterator.

Change-Id: I9b827fbbafce1c78f09d5527cdc64fbe9022a16e
Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
org.eclipse.jgit/src/org/eclipse/jgit/lib/IndexDiff.java

index a65753d1c9e44ea4799e9e0ebc68cc7bfad5d3b9..489e5c0cee90bf733df3ba4ad715a94a4f07d0f5 100644 (file)
@@ -195,7 +195,7 @@ public class IndexDiff {
 
                        if (dirCacheIterator != null) {
                                if (dirCacheIterator.getDirCacheEntry().isAssumeValid())
-                                       assumeUnchanged.add(dirCacheIterator.getEntryPathString());
+                                       assumeUnchanged.add(treeWalk.getPathString());
                        }
 
                        if (treeIterator != null) {
@@ -203,29 +203,28 @@ public class IndexDiff {
                                        if (!treeIterator.getEntryObjectId().equals(
                                                        dirCacheIterator.getEntryObjectId())) {
                                                // in repo, in index, content diff => changed
-                                               changed.add(dirCacheIterator.getEntryPathString());
+                                               changed.add(treeWalk.getPathString());
                                                changesExist = true;
                                        }
                                } else {
                                        // in repo, not in index => removed
                                        if (!fileModeTree.equals(FileMode.TYPE_TREE)) {
-                                               removed.add(treeIterator.getEntryPathString());
+                                               removed.add(treeWalk.getPathString());
                                                changesExist = true;
                                                if (workingTreeIterator != null)
-                                                       untracked.add(workingTreeIterator
-                                                                       .getEntryPathString());
+                                                       untracked.add(treeWalk.getPathString());
                                        }
                                }
                        } else {
                                if (dirCacheIterator != null) {
                                        // not in repo, in index => added
-                                       added.add(dirCacheIterator.getEntryPathString());
+                                       added.add(treeWalk.getPathString());
                                        changesExist = true;
                                } else {
                                        // not in repo, not in index => untracked
                                        if (workingTreeIterator != null
                                                        && !workingTreeIterator.isEntryIgnored()) {
-                                               untracked.add(workingTreeIterator.getEntryPathString());
+                                               untracked.add(treeWalk.getPathString());
                                                changesExist = true;
                                        }
                                }
@@ -234,12 +233,12 @@ public class IndexDiff {
                        if (dirCacheIterator != null) {
                                if (workingTreeIterator == null) {
                                        // in index, not in workdir => missing
-                                       missing.add(dirCacheIterator.getEntryPathString());
+                                       missing.add(treeWalk.getPathString());
                                        changesExist = true;
                                } else {
                                        if (!dirCacheIterator.idEqual(workingTreeIterator)) {
                                                // in index, in workdir, content differs => modified
-                                               modified.add(dirCacheIterator.getEntryPathString());
+                                               modified.add(treeWalk.getPathString());
                                                changesExist = true;
                                        }
                                }