diff options
author | Reinier Heeres <reinier@heeres.eu> | 2008-01-10 16:55:57 (GMT) |
---|---|---|
committer | Reinier Heeres <rwh@rwh.(none)> | 2008-01-10 16:56:55 (GMT) |
commit | b18ed7698660ad6c11da708c30b9ceb745d726b0 (patch) | |
tree | e44782f4f584a096f7ab6da05c63bd18d77da37c /lib/sugar | |
parent | 88aca68be0b95117770cb71b642eb3e53bcd9635 (diff) |
Implement Activity.can_close(), #5493
Diffstat (limited to 'lib/sugar')
-rw-r--r-- | lib/sugar/activity/activity.py | 16 |
1 files changed, 14 insertions, 2 deletions
diff --git a/lib/sugar/activity/activity.py b/lib/sugar/activity/activity.py index d9886f9..f6dbd37 100644 --- a/lib/sugar/activity/activity.py +++ b/lib/sugar/activity/activity.py @@ -838,12 +838,24 @@ class Activity(Window, gtk.Container): if response_id == gtk.RESPONSE_OK: self.close(skip_save=True) - def close(self, skip_save=False): + def can_close(self): + """Activities should override this function if they want to perform + extra checks before actually closing.""" + + return True + + def close(self, force=False, skip_save=False): """Request that the activity be stopped and saved to the Journal Activities should not override this method, but should implement write_file() to - do any state saving instead. + do any state saving instead. If the application wants to control wether it can + close, it should override can_close(). """ + + if not force: + if not self.can_close(): + return + try: if not skip_save: self.save() |