src/eric7/Plugins/VcsPlugins/vcsGit/GitSubmodulesUpdateOptionsDialog.py

branch
eric7
changeset 9209
b99e7fd55fd3
parent 8881
54e42bc2437a
child 9221
bf71ee032bb4
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/eric7/Plugins/VcsPlugins/vcsGit/GitSubmodulesUpdateOptionsDialog.py	Thu Jul 07 11:23:56 2022 +0200
@@ -0,0 +1,68 @@
+# -*- coding: utf-8 -*-
+
+# Copyright (c) 2017 - 2022 Detlev Offenbach <detlev@die-offenbachs.de>
+#
+
+"""
+Module implementing a dialog to enter options for a submodule update command.
+"""
+
+from PyQt6.QtWidgets import QDialog
+
+from .Ui_GitSubmodulesUpdateOptionsDialog import (
+    Ui_GitSubmodulesUpdateOptionsDialog
+)
+
+
+class GitSubmodulesUpdateOptionsDialog(QDialog,
+                                       Ui_GitSubmodulesUpdateOptionsDialog):
+    """
+    Class implementing a dialog to enter options for a submodule update
+    command.
+    """
+    def __init__(self, submodulePaths, parent=None):
+        """
+        Constructor
+        
+        @param submodulePaths list of submodule paths
+        @type list of str
+        @param parent reference to the parent widget
+        @type QWidget
+        """
+        super().__init__(parent)
+        self.setupUi(self)
+        
+        self.submodulesList.addItems(sorted(submodulePaths))
+    
+    def getData(self):
+        """
+        Public method to get the entered data.
+        
+        @return tuple containing the update procedure, a flag indicating an
+            init, a flag indicating an update with remote, a flag indicating
+            not to fetch the remote, a flag indicating an enforced operation
+            and a list of selected submodules.
+        @rtype tuple of (int, bool, bool, bool, bool, list of str)
+        """
+        submodulePaths = []
+        for itm in self.submodulesList.selectedItems():
+            submodulePaths.append(itm.text())
+        
+        if self.checkoutButton.isChecked():
+            procedure = "--checkout"
+        elif self.rebaseButton.isChecked():
+            procedure = "--rebase"
+        else:
+            procedure = "--merge"
+        
+        nofetch = (self.remoteCheckBox.isChecked() and
+                   self.nofetchCheckBox.isChecked())
+        
+        return (
+            procedure,
+            self.initCheckBox.isChecked(),
+            self.remoteCheckBox.isChecked(),
+            nofetch,
+            self.forceCheckBox.isChecked(),
+            submodulePaths,
+        )

eric ide

mercurial