From 301e344365aed28428f655ceb2d05a1e1e35fb8c Mon Sep 17 00:00:00 2001 From: Stefaan Lippens Date: Wed, 20 Sep 2023 11:06:59 +0200 Subject: [PATCH] deprecate dict_item --- openeo_driver/utils.py | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/openeo_driver/utils.py b/openeo_driver/utils.py index c6ef1044..5184c525 100644 --- a/openeo_driver/utils.py +++ b/openeo_driver/utils.py @@ -213,6 +213,9 @@ class dict_item: "Descriptor" trick to easily add attribute-style access to standard dictionary items (with optional default values). + Note: instead of this simple trick, consider using any of the more standard, widely used solutions + like dataclasses from Python stdlib, or something like attrs (https://www.attrs.org). + Create an attribute in a custom dict subclass that accesses the dict value keyed by the attribute's name: @@ -250,6 +253,9 @@ class dict_item: This class implements the descriptor protocol. """ + + # TODO: deprecate usage of this descriptor trick and migrate to dataclasses or attrs + _DEFAULT_UNSET = object() def __init__(self, default=_DEFAULT_UNSET):