aboutsummaryrefslogtreecommitdiff
path: root/tools/cru-py/cru/util/_cru.py
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2024-11-11 01:12:29 +0800
committerYuqian Yang <crupest@crupest.life>2024-12-18 18:31:27 +0800
commitaaa855e3839130a79193f38969f07763f2773c5d (patch)
treee4cb238df4588f4633d9c1190136895865d51a98 /tools/cru-py/cru/util/_cru.py
parent95da3ade5bfa6ef39923cd3fc2a551ad983c1537 (diff)
downloadcrupest-aaa855e3839130a79193f38969f07763f2773c5d.tar.gz
crupest-aaa855e3839130a79193f38969f07763f2773c5d.tar.bz2
crupest-aaa855e3839130a79193f38969f07763f2773c5d.zip
HALF WORK: 2024.11.27
Diffstat (limited to 'tools/cru-py/cru/util/_cru.py')
-rw-r--r--tools/cru-py/cru/util/_cru.py90
1 files changed, 0 insertions, 90 deletions
diff --git a/tools/cru-py/cru/util/_cru.py b/tools/cru-py/cru/util/_cru.py
deleted file mode 100644
index 61a0ee1..0000000
--- a/tools/cru-py/cru/util/_cru.py
+++ /dev/null
@@ -1,90 +0,0 @@
-from typing import Any
-
-
-class _Cru:
- NAME_PREFIXES = ("CRU_", "Cru", "cru_")
-
- def __init__(self):
- self._d: dict[str, Any] = {}
-
- def all_names(self) -> list[str]:
- return list(self._d.keys())
-
- def get(self, name: str) -> Any:
- return self._d[name]
-
- def has_name(self, name: str) -> bool:
- return name in self._d
-
- @staticmethod
- def _maybe_remove_prefix(name: str) -> str | None:
- for prefix in _Cru.NAME_PREFIXES:
- if name.startswith(prefix):
- return name[len(prefix):]
- return None
-
- def _check_name_exist(self, *names: str) -> None:
- for name in names:
- if name is None: continue
- if self.has_name(name):
- raise ValueError(f"Name {name} exists in CRU.")
-
- @staticmethod
- def check_name_format(name: str) -> tuple[str, str]:
- no_prefix_name = _Cru._maybe_remove_prefix(name)
- if no_prefix_name is None:
- raise ValueError(f"Name {name} is not prefixed with {_Cru.NAME_PREFIXES}.")
- return name, no_prefix_name
-
- @staticmethod
- def _check_object_name(o) -> tuple[str, str]:
- return _Cru.check_name_format(o.__name__)
-
- def _do_add(self, o, *names: str | None) -> list[str]:
- names = set(names)
- names.remove(None)
- for name in names:
- self._d[name] = o
- return list(names)
-
- def add(self, o, name: str | None) -> tuple[str, str | None]:
- if name is None:
- name, no_prefix_name = self._check_object_name(o)
- else:
- no_prefix_name = self._maybe_remove_prefix(name)
-
- self._check_name_exist(name, no_prefix_name)
- self._do_add(o, name, no_prefix_name)
- return name, no_prefix_name
-
- def add_with_alias(self, o, name: str | None = None, *aliases: str) -> list[str]:
- final_names = []
- if name is None:
- name, no_prefix_name = self._check_object_name(o)
- self._check_name_exist(name, no_prefix_name)
- final_names.extend([name, no_prefix_name])
- for alias in aliases:
- no_prefix_name = self._maybe_remove_prefix(alias)
- self._check_name_exist(alias, no_prefix_name)
- final_names.extend([alias, no_prefix_name])
-
- return self._do_add(o, *final_names)
-
- def add_objects(self, *objects):
- final_list = []
- for o in objects:
- name, no_prefix_name = self._check_object_name(o)
- self._check_name_exist(name, no_prefix_name)
- final_list.append((o, name, no_prefix_name))
- for o, name, no_prefix_name in final_list:
- self._do_add(o, name, no_prefix_name)
-
- def __getitem__(self, item):
- return self.get(item)
-
- def __getattr__(self, item):
- return self.get(item)
-
-
-CRU_NAME_PREFIXES = _Cru.NAME_PREFIXES
-CRU = _Cru()