James Moger
2011-12-22 e6935876b97a63bae2ec087b4fc390c832aef155
src/com/gitblit/utils/JGitUtils.java
@@ -37,6 +37,8 @@
import org.eclipse.jgit.api.CloneCommand;
import org.eclipse.jgit.api.FetchCommand;
import org.eclipse.jgit.api.Git;
import org.eclipse.jgit.api.ResetCommand;
import org.eclipse.jgit.api.ResetCommand.ResetType;
import org.eclipse.jgit.diff.DiffEntry;
import org.eclipse.jgit.diff.DiffEntry.ChangeType;
import org.eclipse.jgit.diff.DiffFormatter;
@@ -60,6 +62,7 @@
import org.eclipse.jgit.revwalk.RevSort;
import org.eclipse.jgit.revwalk.RevTree;
import org.eclipse.jgit.revwalk.RevWalk;
import org.eclipse.jgit.revwalk.filter.CommitTimeRevFilter;
import org.eclipse.jgit.revwalk.filter.RevFilter;
import org.eclipse.jgit.storage.file.FileRepository;
import org.eclipse.jgit.transport.CredentialsProvider;
@@ -138,6 +141,7 @@
    * Encapsulates the result of cloning or pulling from a repository.
    */
   public static class CloneResult {
      public String name;
      public FetchResult fetchResult;
      public boolean createdRepository;
   }
@@ -155,7 +159,7 @@
    */
   public static CloneResult cloneRepository(File repositoriesFolder, String name, String fromUrl)
         throws Exception {
      return cloneRepository(repositoriesFolder, name, fromUrl, null);
      return cloneRepository(repositoriesFolder, name, fromUrl, true, null);
   }
   /**
@@ -166,16 +170,27 @@
    * @param repositoriesFolder
    * @param name
    * @param fromUrl
    * @param bare
    * @param credentialsProvider
    * @return CloneResult
    * @throws Exception
    */
   public static CloneResult cloneRepository(File repositoriesFolder, String name, String fromUrl,
         CredentialsProvider credentialsProvider) throws Exception {
         boolean bare, CredentialsProvider credentialsProvider) throws Exception {
      CloneResult result = new CloneResult();
      if (!name.toLowerCase().endsWith(Constants.DOT_GIT_EXT)) {
         name += Constants.DOT_GIT_EXT;
      if (bare) {
         // bare repository, ensure .git suffix
         if (!name.toLowerCase().endsWith(Constants.DOT_GIT_EXT)) {
            name += Constants.DOT_GIT_EXT;
         }
      } else {
         // normal repository, strip .git suffix
         if (name.toLowerCase().endsWith(Constants.DOT_GIT_EXT)) {
            name = name.substring(0, name.indexOf(Constants.DOT_GIT_EXT));
         }
      }
      result.name = name;
      File folder = new File(repositoriesFolder, name);
      if (folder.exists()) {
         File gitDir = FileKey.resolve(new File(repositoriesFolder, name), FS.DETECTED);
@@ -184,7 +199,7 @@
         repository.close();
      } else {
         CloneCommand clone = new CloneCommand();
         clone.setBare(true);
         clone.setBare(bare);
         clone.setCloneAllBranches(true);
         clone.setURI(fromUrl);
         clone.setDirectory(folder);
@@ -229,7 +244,28 @@
         fetch.setCredentialsProvider(credentialsProvider);
      }
      fetch.setRefSpecs(specs);
      FetchResult result = fetch.call();
      FetchResult fetchRes = fetch.call();
      return fetchRes;
   }
   /**
    * Reset HEAD to the latest remote tracking commit.
    *
    * @param repository
    * @param remoteRef
    *            the remote tracking reference (e.g. origin/master)
    * @return Ref
    * @throws Exception
    */
   public static Ref resetHEAD(Repository repository, String remoteRef) throws Exception {
      if (!remoteRef.startsWith(Constants.R_REMOTES)) {
         remoteRef = Constants.R_REMOTES + remoteRef;
      }
      Git git = new Git(repository);
      ResetCommand reset = git.reset();
      reset.setMode(ResetType.SOFT);
      reset.setRef(remoteRef);
      Ref result = reset.call();
      return result;
   }
@@ -264,7 +300,7 @@
      }
      list.addAll(getRepositoryList(repositoriesFolder.getAbsolutePath(), repositoriesFolder,
            exportAll, searchSubfolders));
      Collections.sort(list);
      StringUtils.sortRepositorynames(list);
      return list;
   }
@@ -432,6 +468,19 @@
         return new Date(0);
      }
      return new Date(commit.getCommitTime() * 1000L);
   }
   /**
    * Retrieves a Java Date from a Git commit.
    *
    * @param commit
    * @return date of the commit or Date(0) if the commit is null
    */
   public static Date getAuthorDate(RevCommit commit) {
      if (commit == null) {
         return new Date(0);
      }
      return commit.getAuthorIdent().getWhen();
   }
   /**
@@ -789,6 +838,45 @@
   }
   /**
    * Returns a list of commits since the minimum date starting from the
    * specified object id.
    *
    * @param repository
    * @param objectId
    *            if unspecified, HEAD is assumed.
    * @param minimumDate
    * @return list of commits
    */
   public static List<RevCommit> getRevLog(Repository repository, String objectId, Date minimumDate) {
      List<RevCommit> list = new ArrayList<RevCommit>();
      if (!hasCommits(repository)) {
         return list;
      }
      try {
         // resolve branch
         ObjectId branchObject;
         if (StringUtils.isEmpty(objectId)) {
            branchObject = getDefaultBranch(repository);
         } else {
            branchObject = repository.resolve(objectId);
         }
         RevWalk rw = new RevWalk(repository);
         rw.markStart(rw.parseCommit(branchObject));
         rw.setRevFilter(CommitTimeRevFilter.after(minimumDate));
         Iterable<RevCommit> revlog = rw;
         for (RevCommit rev : revlog) {
            list.add(rev);
         }
         rw.dispose();
      } catch (Throwable t) {
         error(t, repository, "{0} failed to get {1} revlog for minimum date {2}", objectId,
               minimumDate);
      }
      return list;
   }
   /**
    * Returns a list of commits starting from HEAD and working backwards.
    * 
    * @param repository
@@ -890,24 +978,40 @@
   }
   /**
    * Enumeration of the search types.
    * Returns a list of commits for the repository within the range specified
    * by startRangeId and endRangeId. If the repository does not exist or is
    * empty, an empty list is returned.
    *
    * @param repository
    * @param startRangeId
    *            the first commit (not included in results)
    * @param endRangeId
    *            the end commit (included in results)
    * @return a list of commits
    */
   public static enum SearchType {
      AUTHOR, COMMITTER, COMMIT;
   public static List<RevCommit> getRevLog(Repository repository, String startRangeId,
         String endRangeId) {
      List<RevCommit> list = new ArrayList<RevCommit>();
      if (!hasCommits(repository)) {
         return list;
      }
      try {
         ObjectId endRange = repository.resolve(endRangeId);
         ObjectId startRange = repository.resolve(startRangeId);
      public static SearchType forName(String name) {
         for (SearchType type : values()) {
            if (type.name().equalsIgnoreCase(name)) {
               return type;
            }
         RevWalk rw = new RevWalk(repository);
         rw.markStart(rw.parseCommit(endRange));
         rw.markUninteresting(rw.parseCommit(startRange));
         Iterable<RevCommit> revlog = rw;
         for (RevCommit rev : revlog) {
            list.add(rev);
         }
         return COMMIT;
         rw.dispose();
      } catch (Throwable t) {
         error(t, repository, "{0} failed to get revlog for {1}..{2}", startRangeId, endRangeId);
      }
      @Override
      public String toString() {
         return name().toLowerCase();
      }
      return list;
   }
   /**
@@ -928,7 +1032,7 @@
    * @return matching list of commits
    */
   public static List<RevCommit> searchRevlogs(Repository repository, String objectId,
         String value, final SearchType type, int offset, int maxCount) {
         String value, final com.gitblit.Constants.SearchType type, int offset, int maxCount) {
      final String lcValue = value.toLowerCase();
      List<RevCommit> list = new ArrayList<RevCommit>();
      if (maxCount == 0) {