You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

64 lines
2.1 KiB

6 years ago
  1. """SCons.exitfuncs
  2. Register functions which are executed when SCons exits for any reason.
  3. """
  4. #
  5. # Copyright (c) 2001 - 2017 The SCons Foundation
  6. #
  7. # Permission is hereby granted, free of charge, to any person obtaining
  8. # a copy of this software and associated documentation files (the
  9. # "Software"), to deal in the Software without restriction, including
  10. # without limitation the rights to use, copy, modify, merge, publish,
  11. # distribute, sublicense, and/or sell copies of the Software, and to
  12. # permit persons to whom the Software is furnished to do so, subject to
  13. # the following conditions:
  14. #
  15. # The above copyright notice and this permission notice shall be included
  16. # in all copies or substantial portions of the Software.
  17. #
  18. # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
  19. # KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
  20. # WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  21. # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
  22. # LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
  23. # OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
  24. # WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  25. #
  26. __revision__ = "src/engine/SCons/exitfuncs.py rel_3.0.0:4395:8972f6a2f699 2017/09/18 12:59:24 bdbaddog"
  27. import atexit
  28. _exithandlers = []
  29. def _run_exitfuncs():
  30. """run any registered exit functions
  31. _exithandlers is traversed in reverse order so functions are executed
  32. last in, first out.
  33. """
  34. while _exithandlers:
  35. func, targs, kargs = _exithandlers.pop()
  36. func(*targs, **kargs)
  37. def register(func, *targs, **kargs):
  38. """register a function to be executed upon normal program termination
  39. func - function to be called at exit
  40. targs - optional arguments to pass to func
  41. kargs - optional keyword arguments to pass to func
  42. """
  43. _exithandlers.append((func, targs, kargs))
  44. # make our exit function get run by python when it exits
  45. atexit.register(_run_exitfuncs)
  46. # Local Variables:
  47. # tab-width:4
  48. # indent-tabs-mode:nil
  49. # End:
  50. # vim: set expandtab tabstop=4 shiftwidth=4: