From a6c73ef108f9b91d907f4504924a2683dc277131 Mon Sep 17 00:00:00 2001 From: janezd Date: Thu, 6 Oct 2016 18:26:41 +0200 Subject: [PATCH] OWFile: Catch errors in get_reader --- Orange/widgets/data/owfile.py | 47 ++++++++++++++++++++--------------- 1 file changed, 27 insertions(+), 20 deletions(-) diff --git a/Orange/widgets/data/owfile.py b/Orange/widgets/data/owfile.py index 5f79e3fc3cd..9a6abd9836f 100644 --- a/Orange/widgets/data/owfile.py +++ b/Orange/widgets/data/owfile.py @@ -257,29 +257,36 @@ def browse_file(self, in_demos=False): # Open a file, create data from it and send it over the data channel def load_data(self): + # We need to catch any exception type since anything can happen in + # file readers + # pylint: disable=broad-except self.editor_model.set_domain(None) - self.reader = self._get_reader() - if not self.reader: - self.data = None - self.send("Data", None) - self.info.setText("No data.") - return - self._update_sheet_combo() - errors = [] - with catch_warnings(record=True) as warnings: - try: - data = self.reader.read() - except Exception as ex: - errors.append("An error occurred:") - errors.append(str(ex)) - data = None - self.editor_model.reset() - self.warning(warnings[-1].message.args[0] if warnings else '') - - if data is None: + error = None + try: + self.reader = self._get_reader() + if self.reader is None: + self.send("Data", None) + self.info.setText("No data.") + self.sheet_box.hide() + return + except Exception as ex: + error = ex + + if not error: + self._update_sheet_combo() + with catch_warnings(record=True) as warnings: + try: + data = self.reader.read() + except Exception as ex: + error = ex + self.warning(warnings[-1].message.args[0] if warnings else '') + + if error: self.send("Data", None) - self.info.setText("\n".join(errors)) + self.info.setText("An error occurred:\n{}".format(error)) + self.editor_model.reset() + self.sheet_box.hide() return self.info.setText(self._describe(data))