Plugins/VcsPlugins/vcsPySvn/SvnOptionsDialog.py

changeset 0
de9c2efb9d02
child 12
1d8dd9706f46
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Plugins/VcsPlugins/vcsPySvn/SvnOptionsDialog.py	Mon Dec 28 16:03:33 2009 +0000
@@ -0,0 +1,111 @@
+# -*- coding: utf-8 -*-
+
+# Copyright (c) 2002 - 2009 Detlev Offenbach <detlev@die-offenbachs.de>
+#
+
+"""
+Module implementing a dialog to enter options used to start a project in the VCS.
+"""
+
+import os
+
+from PyQt4.QtCore import *
+from PyQt4.QtGui import *
+
+from E4Gui.E4Completers import E4DirCompleter
+
+from SvnRepoBrowserDialog import SvnRepoBrowserDialog
+from Ui_SvnOptionsDialog import Ui_SvnOptionsDialog
+from Config import ConfigSvnProtocols
+
+import Utilities
+
+class SvnOptionsDialog(QDialog, Ui_SvnOptionsDialog):
+    """
+    Class implementing a dialog to enter options used to start a project in the
+    repository.
+    """
+    def __init__(self, vcs, project, parent = None):
+        """
+        Constructor
+        
+        @param vcs reference to the version control object
+        @param project reference to the project object
+        @param parent parent widget (QWidget)
+        """
+        QDialog.__init__(self, parent)
+        self.setupUi(self)
+        
+        self.vcsDirectoryCompleter = E4DirCompleter(self.vcsUrlEdit)
+        
+        self.project = project
+        
+        self.protocolCombo.addItems(ConfigSvnProtocols)
+        
+        hd = Utilities.toNativeSeparators(QDir.homePath())
+        hd = os.path.join(hd, 'subversionroot')
+        self.vcsUrlEdit.setText(hd)
+        
+        self.vcs = vcs
+        
+        self.localPath = hd
+        self.networkPath = "localhost/"
+        self.localProtocol = True
+        
+    @pyqtSlot()
+    def on_vcsUrlButton_clicked(self):
+        """
+        Private slot to display a selection dialog.
+        """
+        if self.protocolCombo.currentText() == "file://":
+            directory = QFileDialog.getExistingDirectory(\
+                self,
+                self.trUtf8("Select Repository-Directory"),
+                self.vcsUrlEdit.text(),
+                QFileDialog.Options(QFileDialog.ShowDirsOnly))
+            
+            if directory:
+                self.vcsUrlEdit.setText(Utilities.toNativeSeparators(directory))
+        else:
+            dlg = SvnRepoBrowserDialog(self.vcs, mode = "select", parent = self)
+            dlg.start(self.protocolCombo.currentText() + self.vcsUrlEdit.text())
+            if dlg.exec_() == QDialog.Accepted:
+                url = dlg.getSelectedUrl()
+                if url:
+                    protocol = url.split("://")[0]
+                    path = url.split("://")[1]
+                    self.protocolCombo.setCurrentIndex(\
+                        self.protocolCombo.findText(protocol + "://"))
+                    self.vcsUrlEdit.setText(path)
+        
+    @pyqtSlot(str)
+    def on_protocolCombo_activated(self, protocol):
+        """
+        Private slot to switch the status of the directory selection button.
+        """
+        if protocol == "file://":
+            self.networkPath = self.vcsUrlEdit.text()
+            self.vcsUrlEdit.setText(self.localPath)
+            self.localProtocol = True
+        else:
+            if self.localProtocol:
+                self.localPath = self.vcsUrlEdit.text()
+                self.vcsUrlEdit.setText(self.networkPath)
+                self.localProtocol = False
+        
+    def getData(self):
+        """
+        Public slot to retrieve the data entered into the dialog.
+        
+        @return a dictionary containing the data entered
+        """
+        scheme = self.protocolCombo.currentText()
+        url = self.vcsUrlEdit.text()
+        if scheme == "file://" and url[0] not in ["\\", "/"]:
+            url = "/%s" % url
+        vcsdatadict = {
+            "url" : '%s%s' % (scheme, url),
+            "message" : self.vcsLogEdit.text(),
+            "standardLayout" : self.layoutCheckBox.isChecked(),
+        }
+        return vcsdatadict

eric ide

mercurial