PluginManager/PluginRepositoryDialog.py

changeset 580
45c38566b001
parent 553
5af61623ae3c
child 595
7d2c8346021c
--- a/PluginManager/PluginRepositoryDialog.py	Fri Sep 10 08:45:26 2010 +0200
+++ b/PluginManager/PluginRepositoryDialog.py	Fri Sep 10 08:54:33 2010 +0200
@@ -11,7 +11,6 @@
 import sys
 import os
 import zipfile
-import io
 
 from PyQt4.QtGui import *
 from PyQt4.QtCore import *
@@ -21,10 +20,7 @@
 
 from E5Gui import E5MessageBox
 
-from E5XML.XMLUtilities import make_parser
-from E5XML.XMLErrorHandler import XMLErrorHandler, XMLFatalParseError
-from E5XML.XMLEntityResolver import XMLEntityResolver
-from E5XML.PluginRepositoryHandler import PluginRepositoryHandler
+from E5XML.PluginRepositoryReader import PluginRepositoryReader
 
 from E5Network.E5NetworkProxyFactory import proxyAuthenticationRequired
 
@@ -259,53 +255,10 @@
         
         if os.path.exists(self.pluginRepositoryFile):
             self.__repositoryMissing = False
-            try:
-                f = open(self.pluginRepositoryFile, "r", encoding = "utf-8")
-                line = f.readline()
-                dtdLine = f.readline()
-                f.close()
-            except IOError:
-                E5MessageBox.critical(self,
-                    self.trUtf8("Read plugins repository file"),
-                    self.trUtf8("<p>The plugins repository file <b>{0}</b> "
-                                "could not be read. Select Update</p>")\
-                        .format(self.pluginRepositoryFile))
-                return
-            
-            # now read the file
-            if line.startswith('<?xml'):
-                parser = make_parser(dtdLine.startswith("<!DOCTYPE"))
-                handler = PluginRepositoryHandler(self)
-                er = XMLEntityResolver()
-                eh = XMLErrorHandler()
-                
-                parser.setContentHandler(handler)
-                parser.setEntityResolver(er)
-                parser.setErrorHandler(eh)
-                
-                try:
-                    f = open(self.pluginRepositoryFile, "r", encoding = "utf-8")
-                    try:
-                        try:
-                            parser.parse(f)
-                        except UnicodeEncodeError:
-                            f.seek(0)
-                            buf = io.StringIO(f.read())
-                            parser.parse(buf)
-                    finally:
-                        f.close()
-                except IOError:
-                    E5MessageBox.critical(self,
-                        self.trUtf8("Read plugins repository file"),
-                        self.trUtf8("<p>The plugins repository file <b>{0}</b> "
-                                    "could not be read. Select Update</p>")\
-                            .format(self.pluginRepositoryFile))
-                    return
-                except XMLFatalParseError:
-                    pass
-                
-                eh.showParseMessages()
-                
+            f = QFile(self.pluginRepositoryFile)
+            if f.open(QIODevice.ReadOnly):
+                reader = PluginRepositoryReader(f, self)
+                reader.readXML()
                 self.repositoryList.resizeColumnToContents(0)
                 self.repositoryList.resizeColumnToContents(1)
                 self.repositoryList.resizeColumnToContents(2)
@@ -314,8 +267,9 @@
                 E5MessageBox.critical(self,
                     self.trUtf8("Read plugins repository file"),
                     self.trUtf8("<p>The plugins repository file <b>{0}</b> "
-                                "has an unsupported format.</p>")\
+                                "could not be read. Select Update</p>")\
                         .format(self.pluginRepositoryFile))
+                return
         else:
             self.__repositoryMissing = True
             QTreeWidgetItem(self.repositoryList, 
@@ -600,4 +554,4 @@
                 ).format(applPath),
                 self.trUtf8('OK'))
         
-        self.close()
\ No newline at end of file
+        self.close()

eric ide

mercurial