diff options
-rw-r--r-- | org.eclipse.jgit/src/org/eclipse/jgit/dircache/DirCacheCheckout.java | 43 |
1 files changed, 35 insertions, 8 deletions
diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/dircache/DirCacheCheckout.java b/org.eclipse.jgit/src/org/eclipse/jgit/dircache/DirCacheCheckout.java index 25209d982b..da7ea2c9cc 100644 --- a/org.eclipse.jgit/src/org/eclipse/jgit/dircache/DirCacheCheckout.java +++ b/org.eclipse.jgit/src/org/eclipse/jgit/dircache/DirCacheCheckout.java @@ -304,29 +304,56 @@ public class DirCacheCheckout { void processEntry(CanonicalTreeParser m, DirCacheBuildIterator i, WorkingTreeIterator f) { if (m != null) { - if (i == null || f == null || !m.idEqual(i) - || (i.getDirCacheEntry() != null && (f.isModified( - i.getDirCacheEntry(), true) || - i.getDirCacheEntry().getStage() != 0))) { + // There is an entry in the merge commit. Means: we want to update + // what's currently in the index and working-tree to that one + if (i == null) { + // The index entry is missing update(m.getEntryPathString(), m.getEntryObjectId(), m.getEntryFileMode()); + } else if (f == null || !m.idEqual(i)) { + // The working tree file is missing or the merge content differs + // from index content + update(m.getEntryPathString(), m.getEntryObjectId(), + m.getEntryFileMode()); + } else if (i.getDirCacheEntry() != null) { + // The index contains a file (and not a folder) + if (f.isModified(i.getDirCacheEntry(), true) + || i.getDirCacheEntry().getStage() != 0) + // The working tree file is dirty or the index contains a + // conflict + update(m.getEntryPathString(), m.getEntryObjectId(), + m.getEntryFileMode()); + else + keep(i.getDirCacheEntry()); } else + // The index contains a folder keep(i.getDirCacheEntry()); } else { + // There is no entry in the merge commit. Means: we want to delete + // what's currently in the index and working tree if (f != null) { + // There is a file/folder for that path in the working tree if (walk.isDirectoryFileConflict()) { conflicts.add(walk.getPathString()); } else { + // No file/folder conflict exists. All entries are files or + // all entries are folders if (i != null) { - // ... and the working dir contained a file or folder -> - // add it to the removed set and remove it from + // ... and the working tree contained a file or folder + // -> add it to the removed set and remove it from // conflicts set remove(i.getEntryPathString()); conflicts.remove(i.getEntryPathString()); } } - } else if (i.getDirCacheEntry().getStage() == 0) - keep(i.getDirCacheEntry()); + } else { + // There is no file/folder for that path in the working tree. + // The only entry we have is the index entry. If that entry is a + // conflict simply remove it. Otherwise keep that entry in the + // index + if (i.getDirCacheEntry().getStage() == 0) + keep(i.getDirCacheEntry()); + } } } |