blob: 302c889ac16fbd8a7b18b87167de17be8748cde2 [file] [log] [blame]
/*
* Copyright 2000-2012 JetBrains s.r.o.
*
* 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 git4idea.merge;
import com.intellij.openapi.components.ServiceManager;
import com.intellij.openapi.project.Project;
import com.intellij.openapi.vcs.VcsException;
import com.intellij.openapi.vfs.VirtualFile;
import git4idea.GitPlatformFacade;
import git4idea.commands.Git;
import org.jetbrains.annotations.NotNull;
import java.util.Collection;
/**
* Conflict resolver that makes a merge commit after all conflicts are resolved.
*
* @author Kirill Likhodedov
*/
public class GitMergeCommittingConflictResolver extends GitConflictResolver {
private final Collection<VirtualFile> myMergingRoots;
private final boolean myRefreshAfterCommit;
private final GitMerger myMerger;
public GitMergeCommittingConflictResolver(Project project, @NotNull Git git, GitMerger merger, Collection<VirtualFile> mergingRoots,
Params params, boolean refreshAfterCommit) {
super(project, git, ServiceManager.getService(GitPlatformFacade.class), mergingRoots, params);
myMerger = merger;
myMergingRoots = mergingRoots;
myRefreshAfterCommit = refreshAfterCommit;
}
@Override protected boolean proceedAfterAllMerged() throws VcsException {
myMerger.mergeCommit(myMergingRoots);
if (myRefreshAfterCommit) {
for (VirtualFile root : myMergingRoots) {
root.refresh(true, true);
}
}
return true;
}
}