List<CommittedChangeList> showRecentListsForSelection(@NotNull List<CommittedChangeList> list,
@NotNull MergeChecker mergeChecker,
boolean allListsLoaded);
-
- interface SelectMergeItemsResult {
- @NotNull
- QuickMergeContentsVariants getResultCode();
-
- @NotNull
- List<CommittedChangeList> getSelectedLists();
- }
}
import com.intellij.openapi.project.Project;
import com.intellij.openapi.ui.DialogBuilder;
-import com.intellij.openapi.ui.DialogWrapper;
import com.intellij.openapi.ui.MessageType;
import com.intellij.openapi.vcs.AbstractVcsHelper;
import com.intellij.openapi.vcs.FilePath;
import java.util.List;
+import static com.intellij.openapi.ui.DialogWrapper.OK_EXIT_CODE;
import static com.intellij.openapi.ui.Messages.*;
import static com.intellij.util.Functions.TO_STRING;
import static com.intellij.util.containers.ContainerUtil.emptyList;
import static com.intellij.util.containers.ContainerUtil.map2Array;
import static org.jetbrains.idea.svn.integrate.LocalChangesAction.*;
+import static org.jetbrains.idea.svn.integrate.ToBeMergedDialog.MERGE_ALL_CODE;
public class QuickMergeInteractionImpl implements QuickMergeInteraction {
ToBeMergedDialog dialog = new ToBeMergedDialog(myMergeContext, lists, mergeTitle, mergeChecker, true, true);
dialog.show();
- return new SelectMergeItemsResult() {
- @NotNull
- @Override
- public QuickMergeContentsVariants getResultCode() {
- switch (dialog.getExitCode()) {
- case ToBeMergedDialog.MERGE_ALL_CODE:
- return QuickMergeContentsVariants.all;
- case DialogWrapper.OK_EXIT_CODE:
- return QuickMergeContentsVariants.select;
- default:
- return QuickMergeContentsVariants.cancel;
- }
- }
-
- @NotNull
- @Override
- public List<CommittedChangeList> getSelectedLists() {
- return dialog.getSelected();
- }
- };
+ QuickMergeContentsVariants resultCode = toMergeVariant(dialog.getExitCode());
+ List<CommittedChangeList> selectedLists = resultCode == QuickMergeContentsVariants.select ? dialog.getSelected() : emptyList();
+
+ return new SelectMergeItemsResult(resultCode, selectedLists);
}
@NotNull
private boolean prompt(@NotNull String question) {
return showOkCancelDialog(myProject, question, myTitle, getQuestionIcon()) == OK;
}
+
+ @NotNull
+ private static QuickMergeContentsVariants toMergeVariant(int exitCode) {
+ switch (exitCode) {
+ case MERGE_ALL_CODE:
+ return QuickMergeContentsVariants.all;
+ case OK_EXIT_CODE:
+ return QuickMergeContentsVariants.select;
+ default:
+ return QuickMergeContentsVariants.cancel;
+ }
+ }
}
--- /dev/null
+/*
+ * Copyright 2000-2016 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 org.jetbrains.idea.svn.integrate;
+
+import com.intellij.openapi.vcs.versionBrowser.CommittedChangeList;
+import org.jetbrains.annotations.NotNull;
+
+import java.util.List;
+
+public class SelectMergeItemsResult {
+ @NotNull private final QuickMergeContentsVariants myResultCode;
+ @NotNull private final List<CommittedChangeList> myLists;
+
+ public SelectMergeItemsResult(@NotNull QuickMergeContentsVariants resultCode, @NotNull List<CommittedChangeList> lists) {
+ myResultCode = resultCode;
+ myLists = lists;
+ }
+
+ @NotNull
+ public QuickMergeContentsVariants getResultCode() {
+ return myResultCode;
+ }
+
+ @NotNull
+ public List<CommittedChangeList> getSelectedLists() {
+ return myLists;
+ }
+}
@Override
public void run() {
- QuickMergeInteraction.SelectMergeItemsResult result =
- myInteraction.selectMergeItems(myChangeLists, myMergeContext.getTitle(), myMergeChecker);
+ SelectMergeItemsResult result = myInteraction.selectMergeItems(myChangeLists, myMergeContext.getTitle(), myMergeChecker);
switch (result.getResultCode()) {
case cancel:
import org.jetbrains.idea.svn.integrate.LocalChangesAction;
import org.jetbrains.idea.svn.integrate.QuickMergeContentsVariants;
import org.jetbrains.idea.svn.integrate.QuickMergeInteraction;
+import org.jetbrains.idea.svn.integrate.SelectMergeItemsResult;
import org.jetbrains.idea.svn.mergeinfo.MergeChecker;
import java.util.List;
public SelectMergeItemsResult selectMergeItems(@NotNull List<CommittedChangeList> lists,
@NotNull String mergeTitle,
@NotNull MergeChecker mergeChecker) {
- return new SelectMergeItemsResult() {
- @NotNull
- @Override
- public QuickMergeContentsVariants getResultCode() {
- return mySelectedListsProvider != null ? QuickMergeContentsVariants.select : QuickMergeContentsVariants.all;
- }
-
- @NotNull
- @Override
- public List<CommittedChangeList> getSelectedLists() {
- return mySelectedListsProvider != null ? mySelectedListsProvider.fun(lists) : emptyList();
- }
- };
+ return new SelectMergeItemsResult(
+ mySelectedListsProvider != null ? QuickMergeContentsVariants.select : QuickMergeContentsVariants.all,
+ mySelectedListsProvider != null ? mySelectedListsProvider.fun(lists) : emptyList()
+ );
}
@NotNull