D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
proc
/
self
/
root
/
opt
/
saltstack
/
salt
/
lib
/
python3.10
/
site-packages
/
salt
/
utils
/
Filename :
datastructures.py
back
Copy
""" Utilities for working with ordered dictionary structures. .. versionadded:: 3006.17 """ import copy from collections import OrderedDict from collections.abc import Callable __all__ = ["DefaultOrderedDict", "HashableOrderedDict"] class DefaultOrderedDict(OrderedDict): """ An ordered dictionary with a default factory for missing keys. """ def __init__(self, default_factory=None, *args, **kwargs): if default_factory is not None and not isinstance(default_factory, Callable): raise TypeError("first argument must be callable") super().__init__(*args, **kwargs) self.default_factory = default_factory def __getitem__(self, key): try: return super().__getitem__(key) except KeyError: return self.__missing__(key) def __missing__(self, key): if self.default_factory is None: raise KeyError(key) self[key] = value = self.default_factory() return value def __reduce__(self): if self.default_factory is None: args = tuple() else: args = (self.default_factory,) return type(self), args, None, None, self.items() def copy(self): return copy.copy(self) def __copy__(self): return type(self)(self.default_factory, self) def __deepcopy__(self, memo): return type(self)( self.default_factory, copy.deepcopy(list(self.items()), memo), ) def __repr__(self, _repr_running={}): # pylint: disable=dangerous-default-value return f"DefaultOrderedDict({self.default_factory}, {super().__repr__()})" class HashableOrderedDict(OrderedDict): """ OrderedDict variant with a stable hash based on identity. """ def __hash__(self): return id(self)