Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]
Groups > comp.lang.python > #20478
| From | Terry Reedy <tjreedy@udel.edu> |
|---|---|
| Subject | Re: atexit.register in case of errors |
| Date | 2012-02-15 16:31 -0500 |
| References | <4F3BAF26.2060505@gmail.com> |
| Newsgroups | comp.lang.python |
| Message-ID | <mailman.5856.1329341500.27778.python-list@python.org> (permalink) |
On 2/15/2012 8:12 AM, Andrea Crotti wrote:
> I have the following very simplified situation
>
> from atexit import register
>
> def goodbye(): print("saying goodbye")
>
> def main():
> while True: var = raw_input("read something")
>
> if __name__ == '__main__':
> register(goodbye)
> main()
>
> But in my case the "goodbye" function is deleting the logging file
> which was created during the application execution. Now the problem
> is that it *always* executes, even when the applications quits for
> some bad errors.
>
> Is there a way to have an exit hook, which doesn't execute in case of
> errors?
Have a single no-error normal exit point.
if __name__ == '__main__':
main()
cleanup()
if you really want to exit by exceptions rather than by returns,
if __name__ == '__main__':
try: main()
except SystemExit: normal_exit_cleanup()
--
Terry Jan Reedy
Back to comp.lang.python | Previous | Next | Find similar | Unroll thread
Re: atexit.register in case of errors Terry Reedy <tjreedy@udel.edu> - 2012-02-15 16:31 -0500
csiph-web