James Moger
2012-11-27 73f1adb2e84b8b9cd4045bcdd7d9afa72d3875b5
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.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 @@
            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);
@@ -94,6 +118,7 @@
      // breadcrumbs
      add(new PathBreadcrumbsPanel("breadcrumbs", repositoryName, path, objectId));
      final int hashLen = GitBlit.getInteger(Keys.web.shortCommitIdLength, 6);
      ListDataProvider<RevCommit> dp = new ListDataProvider<RevCommit>(commits);
      DataView<RevCommit> logView = new DataView<RevCommit>("commit", dp) {
         private static final long serialVersionUID = 1L;
@@ -114,6 +139,14 @@
            setPersonSearchTooltip(authorLink, author, Constants.SearchType.AUTHOR);
            item.add(authorLink);
            // commit hash link
            LinkPanel commitHash = new LinkPanel("commitHash", null, entry.getName().substring(0, hashLen),
                  CommitPage.class, WicketUtils.newObjectParameter(
                        repositoryName, entry.getName()));
            WicketUtils.setCssClass(commitHash, "sha1");
            WicketUtils.setHtmlTooltip(commitHash, entry.getName());
            item.add(commitHash);
            // merge icon
            if (entry.getParentCount() > 1) {
               item.add(WicketUtils.newImage("commitIcon", "commit_merge_16x16.png"));