Factor GetCommit#toCommitInfo to a utility class
Ideally this would go in CommitInfo itself, but we can't use JGit from the extension API POJOs. Change-Id: I290ed0a0af876068a86c90a87c91c3ba00f9307d
This commit is contained in:
		
							
								
								
									
										43
									
								
								java/com/google/gerrit/server/git/CommitUtil.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								java/com/google/gerrit/server/git/CommitUtil.java
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,43 @@
 | 
			
		||||
// Copyright (C) 2017 The Android Open Source Project
 | 
			
		||||
//
 | 
			
		||||
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
// you may not use this file except in compliance with the License.
 | 
			
		||||
// You may obtain a copy of the License at
 | 
			
		||||
//
 | 
			
		||||
// http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
//
 | 
			
		||||
// Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
// See the License for the specific language governing permissions and
 | 
			
		||||
// limitations under the License.
 | 
			
		||||
 | 
			
		||||
package com.google.gerrit.server.git;
 | 
			
		||||
 | 
			
		||||
import com.google.gerrit.extensions.common.CommitInfo;
 | 
			
		||||
import com.google.gerrit.server.CommonConverters;
 | 
			
		||||
import java.util.ArrayList;
 | 
			
		||||
import org.eclipse.jgit.revwalk.RevCommit;
 | 
			
		||||
 | 
			
		||||
/** Static utilities for working with {@link RevCommit}s. */
 | 
			
		||||
public class CommitUtil {
 | 
			
		||||
  public static CommitInfo toCommitInfo(RevCommit commit) {
 | 
			
		||||
    CommitInfo info = new CommitInfo();
 | 
			
		||||
    info.commit = commit.getName();
 | 
			
		||||
    info.author = CommonConverters.toGitPerson(commit.getAuthorIdent());
 | 
			
		||||
    info.committer = CommonConverters.toGitPerson(commit.getCommitterIdent());
 | 
			
		||||
    info.subject = commit.getShortMessage();
 | 
			
		||||
    info.message = commit.getFullMessage();
 | 
			
		||||
    info.parents = new ArrayList<>(commit.getParentCount());
 | 
			
		||||
    for (int i = 0; i < commit.getParentCount(); i++) {
 | 
			
		||||
      RevCommit p = commit.getParent(i);
 | 
			
		||||
      CommitInfo parentInfo = new CommitInfo();
 | 
			
		||||
      parentInfo.commit = p.getName();
 | 
			
		||||
      parentInfo.subject = p.getShortMessage();
 | 
			
		||||
      info.parents.add(parentInfo);
 | 
			
		||||
    }
 | 
			
		||||
    return info;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  private CommitUtil() {}
 | 
			
		||||
}
 | 
			
		||||
@@ -16,34 +16,14 @@ package com.google.gerrit.server.project;
 | 
			
		||||
 | 
			
		||||
import com.google.gerrit.extensions.common.CommitInfo;
 | 
			
		||||
import com.google.gerrit.extensions.restapi.RestReadView;
 | 
			
		||||
import com.google.gerrit.server.CommonConverters;
 | 
			
		||||
import com.google.gerrit.server.git.CommitUtil;
 | 
			
		||||
import com.google.inject.Singleton;
 | 
			
		||||
import java.util.ArrayList;
 | 
			
		||||
import org.eclipse.jgit.revwalk.RevCommit;
 | 
			
		||||
 | 
			
		||||
@Singleton
 | 
			
		||||
public class GetCommit implements RestReadView<CommitResource> {
 | 
			
		||||
 | 
			
		||||
  @Override
 | 
			
		||||
  public CommitInfo apply(CommitResource rsrc) {
 | 
			
		||||
    return toCommitInfo(rsrc.getCommit());
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  private static CommitInfo toCommitInfo(RevCommit commit) {
 | 
			
		||||
    CommitInfo info = new CommitInfo();
 | 
			
		||||
    info.commit = commit.getName();
 | 
			
		||||
    info.author = CommonConverters.toGitPerson(commit.getAuthorIdent());
 | 
			
		||||
    info.committer = CommonConverters.toGitPerson(commit.getCommitterIdent());
 | 
			
		||||
    info.subject = commit.getShortMessage();
 | 
			
		||||
    info.message = commit.getFullMessage();
 | 
			
		||||
    info.parents = new ArrayList<>(commit.getParentCount());
 | 
			
		||||
    for (int i = 0; i < commit.getParentCount(); i++) {
 | 
			
		||||
      RevCommit p = commit.getParent(i);
 | 
			
		||||
      CommitInfo parentInfo = new CommitInfo();
 | 
			
		||||
      parentInfo.commit = p.getName();
 | 
			
		||||
      parentInfo.subject = p.getShortMessage();
 | 
			
		||||
      info.parents.add(parentInfo);
 | 
			
		||||
    }
 | 
			
		||||
    return info;
 | 
			
		||||
    return CommitUtil.toCommitInfo(rsrc.getCommit());
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user