diff --git a/src/gitflow/DefaultOptions.java b/src/gitflow/DefaultOptions.java new file mode 100644 index 0000000..0e75c54 --- /dev/null +++ b/src/gitflow/DefaultOptions.java @@ -0,0 +1,18 @@ +package gitflow; + +import java.util.HashMap; +import java.util.Map; + +public class DefaultOptions { + private static final Map options; + static + { + options = new HashMap(); + options.put("RELEASE_customTagCommitMessage", "Tagging version %name%"); + options.put("HOTFIX_customHotfixCommitMessage", "Tagging hotfix %name%"); + } + + public static String getOption(String optionId){ + return options.get(optionId); + } +} diff --git a/src/gitflow/GitflowConfigurable.java b/src/gitflow/GitflowConfigurable.java index f04dfe0..cd8176c 100644 --- a/src/gitflow/GitflowConfigurable.java +++ b/src/gitflow/GitflowConfigurable.java @@ -9,6 +9,7 @@ import javax.swing.*; import java.util.ArrayList; +import java.util.HashMap; import java.util.Map; /** @@ -21,12 +22,14 @@ public class GitflowConfigurable implements Configurable { GitflowOptionsForm gitflowOptionsForm; PropertiesComponent propertiesComponent; Map, ArrayList>> gitflowOptions; + Map optionDefaults; static GitflowConfigurable instance; public GitflowConfigurable(Project project) { gitflowOptions = GitflowOptionsFactory.getOptions(); propertiesComponent = PropertiesComponent.getInstance(project); + optionDefaults = new HashMap(); this.project = project; instance = this; } @@ -58,7 +61,11 @@ public static boolean isOptionActive(Project project, String optionId){ } public static String getOptionTextString (Project project, String optionId){ - return PropertiesComponent.getInstance(project).getValue(optionId+"_text"); + String retValue = PropertiesComponent.getInstance(project).getValue(optionId+"_text"); + if (retValue == null){ + retValue = DefaultOptions.getOption(optionId); + } + return retValue; } @Override diff --git a/src/gitflow/GitflowOptionsFactory.java b/src/gitflow/GitflowOptionsFactory.java index ef25a7c..108c365 100644 --- a/src/gitflow/GitflowOptionsFactory.java +++ b/src/gitflow/GitflowOptionsFactory.java @@ -36,13 +36,13 @@ private GitflowOptionsFactory(){ addOption(TYPE.RELEASE, "Keep branch after performing finish", "keepBranch" , "-k"); // addOption(TYPE.RELEASE, "Squash release during merge", "squash" , "-S"); addOption(TYPE.RELEASE, "Don't tag release", "dontTag" , "-n"); - addOption(TYPE.RELEASE, "Use custom tag commit message", "customTagCommitMessage" , null, "Tagging version %name%" ,"Use %name% for the branch name"); + addOption(TYPE.RELEASE, "Use custom tag commit message", "customTagCommitMessage" , null, DefaultOptions.getOption("RELEASE_customTagCommitMessage") ,"Use %name% for the branch name"); addBranchType(TYPE.HOTFIX); addOption(TYPE.HOTFIX, "Fetch from Origin", "fetchFromOrigin" , "-F"); addOption(TYPE.HOTFIX, "Push on finish Hotfix", "pushOnFinish" , "-p"); addOption(TYPE.HOTFIX, "Don't tag Hotfix", "dontTag" , "-n"); - addOption(TYPE.HOTFIX, "Use custom hotfix commit message", "customHotfixCommitMessage" , null, "Tagging hotfix %name%" ,"Use %name% for the branch name"); + addOption(TYPE.HOTFIX, "Use custom hotfix commit message", "customHotfixCommitMessage" , null, DefaultOptions.getOption("HOTFIX_customHotfixCommitMessage") ,"Use %name% for the branch name"); } private void addBranchType(Enum branchType){ diff --git a/src/gitflow/actions/FinishHotfixAction.java b/src/gitflow/actions/FinishHotfixAction.java index 3da7bb1..b6a05a2 100644 --- a/src/gitflow/actions/FinishHotfixAction.java +++ b/src/gitflow/actions/FinishHotfixAction.java @@ -29,26 +29,16 @@ public void actionPerformed(AnActionEvent e) { String currentBranchName = GitBranchUtil.getBranchNameOrRev(myRepo); - if (currentBranchName.isEmpty()==false){ + if (currentBranchName.isEmpty() == false){ //TODO HOTFIX NAME final String hotfixName = GitflowConfigUtil.getHotfixNameFromBranch(myProject, myRepo, currentBranchName); final String tagMessage; - String tagMessageTemplate; - - String defaultTagMessage = "Tagging hotfix %name%"; - String customTagMessage = GitflowConfigurable.getOptionTextString(myProject, "HOTFIX_customHotfixCommitMessage"); - - if (customTagMessage != null) { - tagMessageTemplate = customTagMessage.replace("%name%", hotfixName); - } - else{ - tagMessageTemplate = defaultTagMessage.replace("%name%", hotfixName); - } + String tagMessageTemplate = GitflowConfigurable.getOptionTextString(myProject, "HOTFIX_customHotfixCommitMessage").replace("%name%", hotfixName); if (GitflowConfigurable.isOptionActive(myProject, "HOTFIX_dontTag")) { - tagMessage=""; + tagMessage = ""; } else { tagMessage = Messages.showInputDialog(myProject, "Enter the tag message:", "Finish Hotfix", Messages.getQuestionIcon(), tagMessageTemplate, null); diff --git a/src/gitflow/actions/FinishReleaseAction.java b/src/gitflow/actions/FinishReleaseAction.java index 0901c5b..7166b88 100644 --- a/src/gitflow/actions/FinishReleaseAction.java +++ b/src/gitflow/actions/FinishReleaseAction.java @@ -47,21 +47,10 @@ public void actionPerformed(AnActionEvent e) { releaseName = customReleaseName!=null ? customReleaseName:GitflowConfigUtil.getReleaseNameFromBranch(myProject, myRepo, currentBranchName); final GitflowErrorsListener errorLineHandler = new GitflowErrorsListener(myProject); - - String tagMessageTemplate; - - String defaultTagMessage = "Tagging version %name%"; - String customTagMessage = GitflowConfigurable.getOptionTextString(myProject, "RELEASE_customTagCommitMessage"); - if (customTagMessage != null) { - tagMessageTemplate = customTagMessage.replace("%name%", releaseName); - } - else{ - tagMessageTemplate = defaultTagMessage.replace("%name%", releaseName); - } - + + String tagMessageTemplate = GitflowConfigurable.getOptionTextString(myProject, "RELEASE_customTagCommitMessage").replace("%name%", releaseName); String tagMessageDraft; - boolean cancelAction=false; if (GitflowConfigurable.isOptionActive(myProject, "RELEASE_dontTag")) { diff --git a/src/gitflow/ui/GitflowCloseTaskPanel.java b/src/gitflow/ui/GitflowCloseTaskPanel.java index 8b3eb80..f3d3bd8 100644 --- a/src/gitflow/ui/GitflowCloseTaskPanel.java +++ b/src/gitflow/ui/GitflowCloseTaskPanel.java @@ -51,9 +51,7 @@ public class GitflowCloseTaskPanel extends TaskDialogPanel { String branchName = myVcsTaskHandler != null ? myVcsTaskHandler.cleanUpBranchName(myTaskManager.constructDefaultBranchName(task)) : myTaskManager.suggestBranchName(task); - - //TODO same code exists in FinishHotfixAction, make DRYer - + if (GitflowConfigurable.isOptionActive(project, "HOTFIX_dontTag")) { tagMessage=""; tagMessageTextField.setEnabled(false);