#!/usr/bin/env python class Registry: def __init__(self): self._registry = dict() def register(self, name): assert name not in self._registry def _register(callable_): self._registry[name] = callable_ return _register def get_callable(self, name: str): return self._registry[name] def __iter__(self): self._idx = 0 self._len = len(self._registry) self._names = list(self._registry.keys()) return self def __next__(self): if self._idx < self._len: key = self._names[self._idx] callable_ = self._registry[key] self._idx += 1 return callable_ else: raise StopIteration non_distributed_component_funcs = Registry() model_parallel_component_funcs = Registry() __all__ = ["non_distributed_component_funcs", "model_parallel_component_funcs"]