diff options
author | James Moger <james.moger@gitblit.com> | 2012-11-27 17:08:53 -0500 |
---|---|---|
committer | James Moger <james.moger@gitblit.com> | 2012-11-27 17:08:53 -0500 |
commit | d83bd6d3acfc88a991a08a15dfa3ac36770bb0b8 (patch) | |
tree | f542b82324e142dbbdff9830b091a69fa56771a9 /src/com/gitblit | |
parent | 44f6238fd5fe7675e7de43f4a42d1f7dabcfee4e (diff) | |
download | gitblit-d83bd6d3acfc88a991a08a15dfa3ac36770bb0b8.tar.gz gitblit-d83bd6d3acfc88a991a08a15dfa3ac36770bb0b8.zip |
Fixed history page links for files not in the current/active commit (issue 166)
Diffstat (limited to 'src/com/gitblit')
-rw-r--r-- | src/com/gitblit/wicket/panels/HistoryPanel.java | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/src/com/gitblit/wicket/panels/HistoryPanel.java b/src/com/gitblit/wicket/panels/HistoryPanel.java index 14aed912..dee5c25c 100644 --- a/src/com/gitblit/wicket/panels/HistoryPanel.java +++ b/src/com/gitblit/wicket/panels/HistoryPanel.java @@ -15,6 +15,7 @@ */
package com.gitblit.wicket.panels;
+import java.util.Collections;
import java.util.Date;
import java.util.List;
import java.util.Map;
@@ -26,9 +27,12 @@ import org.apache.wicket.markup.repeater.Item; import org.apache.wicket.markup.repeater.data.DataView;
import org.apache.wicket.markup.repeater.data.ListDataProvider;
import org.apache.wicket.model.StringResourceModel;
+import org.eclipse.jgit.diff.DiffEntry.ChangeType;
import org.eclipse.jgit.lib.ObjectId;
import org.eclipse.jgit.lib.Repository;
import org.eclipse.jgit.revwalk.RevCommit;
+import org.eclipse.jgit.treewalk.TreeWalk;
+import org.eclipse.jgit.treewalk.filter.PathFilterGroup;
import com.gitblit.Constants;
import com.gitblit.GitBlit;
@@ -72,6 +76,26 @@ public class HistoryPanel extends BasePanel { break;
}
}
+ if (matchingPath == null) {
+ // path not in commit
+ // manually locate path in tree
+ TreeWalk tw = new TreeWalk(r);
+ tw.reset();
+ tw.setRecursive(true);
+ try {
+ tw.addTree(commit.getTree());
+ tw.setFilter(PathFilterGroup.createFromStrings(Collections.singleton(path)));
+ while (tw.next()) {
+ matchingPath = new PathChangeModel(tw.getPathString(), tw.getPathString(), 0, tw
+ .getRawMode(0), tw.getObjectId(0).getName(), commit.getId().getName(),
+ ChangeType.MODIFY);
+ }
+ } catch (Exception e) {
+ } finally {
+ tw.release();
+ }
+ }
+
final boolean isTree = matchingPath == null ? true : matchingPath.isTree();
final Map<ObjectId, List<RefModel>> allRefs = JGitUtils.getAllRefs(r, showRemoteRefs);
|