From e7bcf87788588c3a38ce18c9a8d69bbe156860e9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?S=C5=82awomir=20Nizio?= <slawomir.nizio@sabayon.org> Date: Mon, 3 Mar 2014 08:31:47 +0100 Subject: [PATCH] Fix crash when no log in supported location can be found This can happen for example on systems that use Journal from systemd. In this case, ufw-gtk exits with a traceback containing: IOError: [Errno 2] No such file or directory: '/var/log/messages.log' (this is the last log file tried). The patch works around the issue by handling the error and disabling the widget in the "Events" tab. --- gfw/frontend_gtk.py | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) diff --git a/gfw/frontend_gtk.py b/gfw/frontend_gtk.py index 75ebb33..75dfde0 100644 --- a/gfw/frontend_gtk.py +++ b/gfw/frontend_gtk.py @@ -33,14 +33,21 @@ from gfw.frontend import Frontend class Notifier(gfw.event.Notifier): - def __init__(self, callback): - gfw.event.Notifier.__init__(self, callback) + def __init__(self, callback, inactive_handler): + self._active = False + try: + gfw.event.Notifier.__init__(self, callback) + except IOError: + inactive_handler() + return + self._active = True self._w = gobject.io_add_watch(self._fd, gobject.IO_IN | gobject.IO_PRI, self._trigger) def __del__(self): - gfw.event.Notifier.__del__(self) - gobject.source_remove(self._w) + if self._active: + gfw.event.Notifier.__del__(self) + gobject.source_remove(self._w) class Builder(gtk.Builder): @@ -90,7 +97,8 @@ class GtkFrontend(Frontend): data = (timestamp, event, conn['IN'], conn['OUT'], conn['PROTO'], conn['SRC'], spt, conn['DST'], dpt) self.ui.events_model.append(data) - self._notifier = Notifier(callback) + self._notifier = Notifier(callback, + lambda: self.ui.events_view.set_sensitive(False)) self.ui.main_window.show_all() ## FIXME: for the 0.3.0 release, hide the tab for the connections view page = self.ui.view.get_nth_page(2) -- 1.9.0