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.

62 lines
2.0 KiB

  1. ###################################################################################
  2. #
  3. # Copyright (c) 2017-2019 MuK IT GmbH.
  4. #
  5. # This file is part of MuK Utils
  6. # (see https://mukit.at).
  7. #
  8. # This program is free software: you can redistribute it and/or modify
  9. # it under the terms of the GNU Lesser General Public License as published by
  10. # the Free Software Foundation, either version 3 of the License, or
  11. # (at your option) any later version.
  12. #
  13. # This program is distributed in the hope that it will be useful,
  14. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. # GNU Lesser General Public License for more details.
  17. #
  18. # You should have received a copy of the GNU Lesser General Public License
  19. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  20. #
  21. ###################################################################################
  22. import time
  23. import logging
  24. import datetime
  25. import functools
  26. _logger = logging.getLogger(__name__)
  27. #----------------------------------------------------------
  28. # Properties
  29. #----------------------------------------------------------
  30. class cached_property(object):
  31. def __init__(self, timeout=None):
  32. self.timeout = timeout
  33. def __call__(self, func):
  34. return functools.update_wrapper(self, func)
  35. def __get__(self, obj, cls):
  36. if obj is None:
  37. return self
  38. try:
  39. value, last_updated = obj.__dict__[self.__name__]
  40. except KeyError:
  41. pass
  42. else:
  43. if self.timeout is None:
  44. return value
  45. elif self.timeout >= time.time() - last_updated:
  46. return value
  47. value = self.__wrapped__(obj)
  48. obj.__dict__[self.__name__] = (value, time.time())
  49. return value
  50. def __delete__(self, obj):
  51. obj.__dict__.pop(self.__name__, None)
  52. def __set__(self, obj, value):
  53. obj.__dict__[self.__name__] = (value, time())