eric6/E5XML/UserProjectReader.py

changeset 6942
2602857055c5
parent 6645
ad476851d7e0
child 7229
53054eb5b15a
diff -r f99d60d6b59b -r 2602857055c5 eric6/E5XML/UserProjectReader.py
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/eric6/E5XML/UserProjectReader.py	Sun Apr 14 15:09:21 2019 +0200
@@ -0,0 +1,60 @@
+# -*- coding: utf-8 -*-
+
+# Copyright (c) 2010 - 2019 Detlev Offenbach <detlev@die-offenbachs.de>
+#
+
+"""
+Module implementing a class for reading an XML user project properties file.
+"""
+
+from __future__ import unicode_literals
+
+from .Config import userProjectFileFormatVersion
+from .XMLStreamReaderBase import XMLStreamReaderBase
+
+import Preferences
+
+
+class UserProjectReader(XMLStreamReaderBase):
+    """
+    Class for reading an XML user project properties file.
+    """
+    supportedVersions = ["4.0"]
+    
+    def __init__(self, device, project):
+        """
+        Constructor
+        
+        @param device reference to the I/O device to read from (QIODevice)
+        @param project Reference to the project object to store the
+                information into.
+        """
+        XMLStreamReaderBase.__init__(self, device)
+    
+        self.project = project
+        
+        self.version = ""
+    
+    def readXML(self):
+        """
+        Public method to read and parse the XML document.
+        """
+        while not self.atEnd():
+            self.readNext()
+            if self.isStartElement():
+                if self.name() == "UserProject":
+                    self.version = self.attribute(
+                        "version", userProjectFileFormatVersion)
+                    if self.version not in self.supportedVersions:
+                        self.raiseUnsupportedFormatVersion(self.version)
+                elif self.name() == "VcsType":
+                    self.project.pudata["VCSOVERRIDE"] = self.readElementText()
+                elif self.name() == "VcsStatusMonitorInterval":
+                    interval = int(self.attribute(
+                        "value",
+                        Preferences.getVCS("StatusMonitorInterval")))
+                    self.project.pudata["VCSSTATUSMONITORINTERVAL"] = interval
+                else:
+                    self.raiseUnexpectedStartTag(self.name())
+        
+        self.showErrorMessage()

eric ide

mercurial