Skip to content

Commit

Permalink
sorted out #16. Finish release now invokes the merge dialog as well
Browse files Browse the repository at this point in the history
  • Loading branch information
OpherV committed Apr 10, 2014
1 parent f7bf5e9 commit ca9df4b
Show file tree
Hide file tree
Showing 3 changed files with 84 additions and 39 deletions.
43 changes: 8 additions & 35 deletions src/gitflow/actions/FinishFeatureAction.java
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ public void run(@NotNull ProgressIndicator indicator) {
NotifyUtil.notifySuccess(myProject, featureName, finishedFeatureMessage);
}
else if(errorLineHandler.hasMergeError){

// (merge errors are handled in the onSuccess handler)
}
else {
NotifyUtil.notifyError(myProject, "Error", "Please have a look at the Version Control console for more details");
Expand All @@ -66,42 +66,15 @@ else if(errorLineHandler.hasMergeError){
public void onSuccess() {
super.onSuccess();

//merge conflicts if necessary
if (errorLineHandler.hasMergeError){
if (handleMerge()){
FinishFeatureAction completeFinishFeatureAction = new FinishFeatureAction(featureName);
completeFinishFeatureAction.actionPerformed(event);
}

//ugly, but required for intellij to catch up with the external changes made by
//the CLI before being able to run the merge tool
virtualFileMananger.syncRefresh();
try {
Thread.sleep(500);
}
catch (InterruptedException ignored) {
}


//TODO: refactor this logic to work in case of finishRelease as well
if (errorLineHandler.hasMergeError){
GitflowActions.runMergeTool();
repo.update();

//if merge was completed successfully, finish the action
//note that if it wasn't intellij is left in the "merging state", and git4idea provides no UI way to resolve it
int answer = Messages.showYesNoDialog(myProject, "Was the merge completed succesfully?", "Merge", Messages.getQuestionIcon());
if (answer==0){
GitMerger gitMerger=new GitMerger(myProject);
}

try {
gitMerger.mergeCommit(gitMerger.getMergingRoots());
} catch (VcsException e1) {
NotifyUtil.notifyError(myProject, "Error", "Error committing merge result");
e1.printStackTrace();
}

FinishFeatureAction completeFinishFeatureAction = new FinishFeatureAction(featureName);
completeFinishFeatureAction.actionPerformed(event);

}


}
}
}.queue();
}
Expand Down
35 changes: 31 additions & 4 deletions src/gitflow/actions/FinishReleaseAction.java
Original file line number Diff line number Diff line change
Expand Up @@ -13,30 +13,49 @@

public class FinishReleaseAction extends GitflowAction {

String customReleaseName=null;
String customtagMessage=null;

FinishReleaseAction() {
super("Finish Release");
}

FinishReleaseAction(String name, String tagMessage) {
super("Finish Release");
customReleaseName=name;
customtagMessage=tagMessage;
}

@Override
public void actionPerformed(AnActionEvent e) {
super.actionPerformed(e);

String currentBranchName = GitBranchUtil.getBranchNameOrRev(repo);
if (currentBranchName.isEmpty()==false){

final String releaseName = GitflowConfigUtil.getReleaseNameFromBranch(myProject, currentBranchName);
final AnActionEvent event=e;

final String tagMessage;
final String releaseName;

// Check if a release name was specified, otherwise take name from current branch
releaseName = customReleaseName!=null ? customReleaseName:GitflowConfigUtil.getReleaseNameFromBranch(myProject, currentBranchName);

final GitflowErrorsListener errorLineHandler = new GitflowErrorsListener(myProject);
String defaultTagMessage= GitflowConfigurable.getCustomTagCommitMessage(myProject);
defaultTagMessage=defaultTagMessage.replace("%name%", releaseName);

String tagMessageDraft;
final String tagMessage;

boolean cancelAction=false;

if (GitflowConfigurable.dontTagRelease(myProject)) {
tagMessage="";
}
else if (customtagMessage!=null){
//probably repeating the release finish after a merge
tagMessage=customtagMessage;
}
else{
tagMessageDraft= Messages.showInputDialog(myProject, "Enter the tag message:", "Finish Release", Messages.getQuestionIcon(), defaultTagMessage, null);
if (tagMessageDraft==null){
Expand All @@ -61,6 +80,9 @@ public void run(@NotNull ProgressIndicator indicator) {
String finishedReleaseMessage = String.format("The release branch '%s%s' was merged into '%s' and '%s'", featurePrefix, releaseName, developBranch, masterBranch);
NotifyUtil.notifySuccess(myProject, releaseName, finishedReleaseMessage);
}
else if(errorLineHandler.hasMergeError){
// (merge errors are handled in the onSuccess handler)
}
else {
NotifyUtil.notifyError(myProject, "Error", "Please have a look at the Version Control console for more details");
}
Expand All @@ -73,8 +95,13 @@ public void run(@NotNull ProgressIndicator indicator) {
public void onSuccess() {
super.onSuccess();

virtualFileMananger.syncRefresh();
repo.update();
//merge conflicts if necessary
if (errorLineHandler.hasMergeError){
if (handleMerge()) {
FinishReleaseAction completeFinisReleaseAction = new FinishReleaseAction(releaseName,tagMessage);
completeFinisReleaseAction.actionPerformed(event);
}
}
}

}.queue();
Expand Down
45 changes: 45 additions & 0 deletions src/gitflow/actions/GitflowAction.java
Original file line number Diff line number Diff line change
Expand Up @@ -4,12 +4,16 @@
import com.intellij.openapi.components.ServiceManager;
import com.intellij.openapi.project.DumbAwareAction;
import com.intellij.openapi.project.Project;
import com.intellij.openapi.ui.Messages;
import com.intellij.openapi.vcs.VcsException;
import com.intellij.openapi.vfs.VirtualFileManager;
import git4idea.branch.GitBranchUtil;
import git4idea.merge.GitMerger;
import git4idea.repo.GitRepository;
import gitflow.Gitflow;
import gitflow.GitflowBranchUtil;
import gitflow.GitflowConfigUtil;
import gitflow.ui.NotifyUtil;

import java.util.ArrayList;

Expand Down Expand Up @@ -53,4 +57,45 @@ public void actionPerformed(AnActionEvent e) {
masterBranch= GitflowConfigUtil.getMasterBranch(myProject);
developBranch= GitflowConfigUtil.getDevelopBranch(myProject);
}

//returns true if merge successful, false otherwise
public boolean handleMerge(){
//ugly, but required for intellij to catch up with the external changes made by
//the CLI before being able to run the merge tool
virtualFileMananger.syncRefresh();
try {
Thread.sleep(500);
}
catch (InterruptedException ignored) {
}


GitflowActions.runMergeTool();
repo.update();

//if merge was completed successfully, finish the action
//note that if it wasn't intellij is left in the "merging state", and git4idea provides no UI way to resolve it
//merging can be done via intellij itself or any other util
int answer = Messages.showYesNoDialog(myProject, "Was the merge completed succesfully?", "Merge", Messages.getQuestionIcon());
if (answer==0){
GitMerger gitMerger=new GitMerger(myProject);

try {
gitMerger.mergeCommit(gitMerger.getMergingRoots());
} catch (VcsException e1) {
NotifyUtil.notifyError(myProject, "Error", "Error committing merge result");
e1.printStackTrace();
}

return true;
}
else{

NotifyUtil.notifyInfo(myProject,"Merge incomplete","To manually complete the merge choose VCS > Git > Resolve Conflicts.\n" +
"Once done, commit the merged files.\n");
return false;
}


}
}

0 comments on commit ca9df4b

Please sign in to comment.