| 
									
										
										
										
											2025-07-09 00:01:38 +08:00
										 |  |  |  | from types          import TracebackType | 
					
						
							|  |  |  |  | from typing         import * | 
					
						
							|  |  |  |  | from abc            import * | 
					
						
							|  |  |  |  | import                     sys | 
					
						
							|  |  |  |  | import                     threading | 
					
						
							|  |  |  |  | import                     traceback | 
					
						
							|  |  |  |  | import                     datetime | 
					
						
							| 
									
										
										
										
											2025-09-26 10:34:34 +08:00
										 |  |  |  | try: | 
					
						
							|  |  |  |  |     from colorama       import Fore as ConsoleFrontColor, Back as ConsoleBackgroundColor, Style as ConsoleStyle | 
					
						
							|  |  |  |  | except: | 
					
						
							| 
									
										
										
										
											2025-10-13 15:39:29 +08:00
										 |  |  |  |     print("colorama is not installed") | 
					
						
							| 
									
										
										
										
											2025-09-26 10:34:34 +08:00
										 |  |  |  |     class ConsoleFrontColor: | 
					
						
							|  |  |  |  |         RED = "" | 
					
						
							|  |  |  |  |         GREEN = "" | 
					
						
							|  |  |  |  |         YELLOW = "" | 
					
						
							|  |  |  |  |         BLUE = "" | 
					
						
							|  |  |  |  |         MAGENTA = "" | 
					
						
							|  |  |  |  |         CYAN = "" | 
					
						
							|  |  |  |  |         WHITE = "" | 
					
						
							|  |  |  |  |         RESET = "" | 
					
						
							|  |  |  |  |     class ConsoleBackgroundColor: | 
					
						
							|  |  |  |  |         RED = "" | 
					
						
							|  |  |  |  |         GREEN = "" | 
					
						
							|  |  |  |  |         YELLOW = "" | 
					
						
							|  |  |  |  |         BLUE = "" | 
					
						
							|  |  |  |  |         MAGENTA = "" | 
					
						
							|  |  |  |  |         CYAN = "" | 
					
						
							|  |  |  |  |         WHITE = "" | 
					
						
							|  |  |  |  |         RESET = "" | 
					
						
							|  |  |  |  |     class ConsoleStyle: | 
					
						
							|  |  |  |  |         RESET = "" | 
					
						
							|  |  |  |  |         BOLD = "" | 
					
						
							|  |  |  |  |         DIM = "" | 
					
						
							|  |  |  |  |         UNDERLINE = "" | 
					
						
							|  |  |  |  |         REVERSE = "" | 
					
						
							|  |  |  |  |         HIDDEN = "" | 
					
						
							| 
									
										
										
										
											2025-07-09 00:01:38 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-11 01:36:10 +08:00
										 |  |  |  | class NotImplementedError(Exception): | 
					
						
							|  |  |  |  |     def __init__(self, message:Optional[str]=None) -> None: | 
					
						
							|  |  |  |  |         if message is not None: | 
					
						
							|  |  |  |  |             super().__init__(message) | 
					
						
							|  |  |  |  |         else: | 
					
						
							|  |  |  |  |             super().__init__() | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | class InvalidOperationError(Exception): | 
					
						
							|  |  |  |  |     def __init__(self, message:Optional[str]=None) -> None: | 
					
						
							|  |  |  |  |         if message is not None: | 
					
						
							|  |  |  |  |             super().__init__(message) | 
					
						
							|  |  |  |  |         else: | 
					
						
							|  |  |  |  |             super().__init__() | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-09 00:01:38 +08:00
										 |  |  |  | def format_traceback_info(char:str='\n', back:int=1): | 
					
						
							|  |  |  |  |     return char.join(traceback.format_stack()[:-back]) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | INTERNAL_DEBUG = False | 
					
						
							|  |  |  |  | def SetInternalDebug(mode:bool): | 
					
						
							|  |  |  |  |     global INTERNAL_DEBUG | 
					
						
							|  |  |  |  |     INTERNAL_DEBUG = mode | 
					
						
							|  |  |  |  | def GetInternalDebug() -> bool: | 
					
						
							|  |  |  |  |     global INTERNAL_DEBUG | 
					
						
							|  |  |  |  |     return INTERNAL_DEBUG | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-10-13 15:39:29 +08:00
										 |  |  |  | def PrintColorful(color:str, *args, is_reset:bool=True, **kwargs): | 
					
						
							| 
									
										
										
										
											2025-07-09 00:01:38 +08:00
										 |  |  |  |     with lock_guard(): | 
					
						
							|  |  |  |  |         if is_reset: | 
					
						
							|  |  |  |  |             print(color,*args,ConsoleStyle.RESET_ALL, **kwargs) | 
					
						
							|  |  |  |  |         else: | 
					
						
							|  |  |  |  |             print(color,*args, **kwargs) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | ImportingFailedSet:Set[str] = set() | 
					
						
							|  |  |  |  | def ImportingThrow( | 
					
						
							|  |  |  |  |     ex:             ImportError, | 
					
						
							|  |  |  |  |     moduleName:     str, | 
					
						
							|  |  |  |  |     requierds:      Sequence[str], | 
					
						
							|  |  |  |  |     *, | 
					
						
							|  |  |  |  |     messageBase:    str = ConsoleFrontColor.RED+"{module} Module requires {required} package."+ConsoleFrontColor.RESET, | 
					
						
							|  |  |  |  |     installBase:    str = ConsoleFrontColor.GREEN+"\tpip install {name}"+ConsoleFrontColor.RESET | 
					
						
							|  |  |  |  |     ): | 
					
						
							|  |  |  |  |     with lock_guard(): | 
					
						
							|  |  |  |  |         requierds_str = ",".join([f"<{r}>" for r in requierds]) | 
					
						
							|  |  |  |  |         print(messageBase.format_map(dict(module=moduleName, required=requierds_str))) | 
					
						
							|  |  |  |  |         print('Install it via command:') | 
					
						
							|  |  |  |  |         for i in requierds: | 
					
						
							|  |  |  |  |             global ImportingFailedSet | 
					
						
							|  |  |  |  |             ImportingFailedSet.add(i) | 
					
						
							|  |  |  |  |             install = installBase.format_map({"name":i}) | 
					
						
							|  |  |  |  |             print(install) | 
					
						
							|  |  |  |  |         if ex: | 
					
						
							|  |  |  |  |             print(ConsoleFrontColor.RED, f"Import Error On {moduleName} Module: {ex}, \b{ex.path}\n"\ | 
					
						
							|  |  |  |  |                 f"[{ConsoleFrontColor.RESET}{format_traceback_info(back=2)}{ConsoleFrontColor.RED}]") | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | def InternalImportingThrow( | 
					
						
							|  |  |  |  |     moduleName:     str, | 
					
						
							|  |  |  |  |     requierds:      Sequence[str], | 
					
						
							|  |  |  |  |     *, | 
					
						
							|  |  |  |  |     messageBase:    str = ConsoleFrontColor.RED+"{module} Module requires internal Convention package: {required}."+ConsoleFrontColor.RESET, | 
					
						
							|  |  |  |  |     ): | 
					
						
							|  |  |  |  |     with lock_guard(): | 
					
						
							|  |  |  |  |         requierds_str = ",".join([f"<{r}>" for r in requierds]) | 
					
						
							|  |  |  |  |         print(f"Internal Convention package is not installed.\n{messageBase.format_map({ | 
					
						
							|  |  |  |  |             "module": moduleName, | 
					
						
							|  |  |  |  |             "required": requierds_str | 
					
						
							|  |  |  |  |         })}\n[{ConsoleFrontColor.RESET}{format_traceback_info(back=2)}{ConsoleFrontColor.RED}]") | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | def ReleaseFailed2Requirements(): | 
					
						
							|  |  |  |  |     global ImportingFailedSet | 
					
						
							|  |  |  |  |     if len(ImportingFailedSet) == 0: | 
					
						
							|  |  |  |  |         return | 
					
						
							|  |  |  |  |     with open("requirements.txt", 'w') as f: | 
					
						
							|  |  |  |  |         f.write("\n".join(ImportingFailedSet)) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | try: | 
					
						
							|  |  |  |  |     from pydantic import * | 
					
						
							|  |  |  |  | except ImportError: | 
					
						
							|  |  |  |  |     InternalImportingThrow("Internal", ["pydantic"]) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | type Typen[_T] = type | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-11 01:36:10 +08:00
										 |  |  |  | type Action = Callable[[], None] | 
					
						
							| 
									
										
										
										
											2025-07-09 00:01:38 +08:00
										 |  |  |  | type ClosuresCallable[_T] = Union[Callable[[Optional[None]], _T], Typen[_T]] | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | def AssemblyTypen(obj:Any) -> str: | 
					
						
							|  |  |  |  |     if isinstance(obj, type): | 
					
						
							|  |  |  |  |         return f"{obj.__module__}.{obj.__name__}, "\ | 
					
						
							|  |  |  |  |             f"{obj.Assembly() if hasattr(obj, "Assembly") else "Global"}" | 
					
						
							|  |  |  |  |     else: | 
					
						
							|  |  |  |  |         return f"{obj.__class__.__module__}.{obj.__class__.__name__}, "\ | 
					
						
							|  |  |  |  |             f"{obj.GetAssembly() if hasattr(obj, "GetAssembly") else "Global"}" | 
					
						
							|  |  |  |  | def ReadAssemblyTypen( | 
					
						
							|  |  |  |  |     assembly_typen: str, | 
					
						
							|  |  |  |  |     *, | 
					
						
							|  |  |  |  |     premodule:      Optional[str|Callable[[str], str]] = None | 
					
						
							|  |  |  |  |     ) -> Tuple[type, str]: | 
					
						
							|  |  |  |  |     typen, assembly_name = assembly_typen.split(",") | 
					
						
							|  |  |  |  |     module_name, _, class_name = typen.rpartition(".") | 
					
						
							|  |  |  |  |     if premodule is not None: | 
					
						
							|  |  |  |  |         if isinstance(premodule, str): | 
					
						
							|  |  |  |  |             module_name = premodule | 
					
						
							|  |  |  |  |         else: | 
					
						
							|  |  |  |  |             module_name = premodule(module_name) | 
					
						
							|  |  |  |  |     import importlib | 
					
						
							|  |  |  |  |     target_type = getattr(importlib.import_module(module_name), class_name) | 
					
						
							|  |  |  |  |     return target_type, assembly_name | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | # using as c#: event | 
					
						
							|  |  |  |  | class ActionEvent[_Call:Callable]: | 
					
						
							|  |  |  |  |     def __init__(self, actions:Sequence[_Call]): | 
					
						
							|  |  |  |  |         super().__init__() | 
					
						
							| 
									
										
										
										
											2025-07-21 14:19:27 +08:00
										 |  |  |  |         self._actions:      List[Callable]  = [action for action in actions] | 
					
						
							| 
									
										
										
										
											2025-07-09 00:01:38 +08:00
										 |  |  |  |         self.call_indexs:   List[int]       = [i for i in range(len(actions))] | 
					
						
							|  |  |  |  |         self.last_result:   List[Any]       = [] | 
					
						
							|  |  |  |  |     def CallFuncWithoutCallIndexControl(self, index:int, *args, **kwargs) -> Union[Any, Exception]: | 
					
						
							|  |  |  |  |         try: | 
					
						
							| 
									
										
										
										
											2025-07-21 14:19:27 +08:00
										 |  |  |  |             return self._actions[index](*args, **kwargs) | 
					
						
							| 
									
										
										
										
											2025-07-09 00:01:38 +08:00
										 |  |  |  |         except Exception as ex: | 
					
						
							|  |  |  |  |             return ex | 
					
						
							|  |  |  |  |     def CallFunc(self, index:int, *args, **kwargs) -> Union[Any, Exception]: | 
					
						
							|  |  |  |  |         return self.CallFuncWithoutCallIndexControl(self.call_indexs[index], *args, **kwargs) | 
					
						
							| 
									
										
										
										
											2025-07-09 17:39:50 +08:00
										 |  |  |  |     def _InjectInvoke(self, *args, **kwargs): | 
					
						
							| 
									
										
										
										
											2025-07-09 00:01:38 +08:00
										 |  |  |  |         result:List[Any] = [] | 
					
						
							| 
									
										
										
										
											2025-07-09 17:39:50 +08:00
										 |  |  |  |         for index in range(self.CallMaxCount): | 
					
						
							| 
									
										
										
										
											2025-07-09 00:01:38 +08:00
										 |  |  |  |             result.append(self.CallFunc(index, *args, **kwargs)) | 
					
						
							|  |  |  |  |         return result | 
					
						
							|  |  |  |  |     def Invoke(self, *args, **kwargs) -> Union[Self, bool]: | 
					
						
							| 
									
										
										
										
											2025-07-09 17:39:50 +08:00
										 |  |  |  |         self.last_result = self._InjectInvoke(*args, **kwargs) | 
					
						
							| 
									
										
										
										
											2025-07-09 00:01:38 +08:00
										 |  |  |  |         return self | 
					
						
							|  |  |  |  |     def InitCallIndex(self): | 
					
						
							| 
									
										
										
										
											2025-07-21 14:19:27 +08:00
										 |  |  |  |         self.call_indexs = [i for i in range(len(self._actions))] | 
					
						
							| 
									
										
										
										
											2025-07-09 00:01:38 +08:00
										 |  |  |  |     def AddAction(self, action:_Call): | 
					
						
							| 
									
										
										
										
											2025-07-21 14:19:27 +08:00
										 |  |  |  |         self._actions.append(action) | 
					
						
							|  |  |  |  |         self.call_indexs.append(len(self._actions)-1) | 
					
						
							| 
									
										
										
										
											2025-07-09 00:01:38 +08:00
										 |  |  |  |         return self | 
					
						
							|  |  |  |  |     def AddActions(self, actions:Sequence[_Call]): | 
					
						
							|  |  |  |  |         for action in actions: | 
					
						
							|  |  |  |  |             self.AddAction(action) | 
					
						
							|  |  |  |  |         return self | 
					
						
							|  |  |  |  |     def _InternalRemoveAction(self, action:_Call): | 
					
						
							| 
									
										
										
										
											2025-07-21 14:19:27 +08:00
										 |  |  |  |         if action in self._actions: | 
					
						
							|  |  |  |  |             index = self._actions.index(action) | 
					
						
							|  |  |  |  |             self._actions.remove(action) | 
					
						
							| 
									
										
										
										
											2025-07-09 00:01:38 +08:00
										 |  |  |  |             self.call_indexs.remove(index) | 
					
						
							|  |  |  |  |             for i in range(len(self.call_indexs)): | 
					
						
							|  |  |  |  |                 if self.call_indexs[i] > index: | 
					
						
							|  |  |  |  |                     self.call_indexs[i] -= 1 | 
					
						
							|  |  |  |  |             return True | 
					
						
							|  |  |  |  |         return False | 
					
						
							|  |  |  |  |     def RemoveAction(self, action:_Call): | 
					
						
							|  |  |  |  |         while self._InternalRemoveAction(action): | 
					
						
							|  |  |  |  |             pass | 
					
						
							|  |  |  |  |         return self | 
					
						
							|  |  |  |  |     def IsValid(self): | 
					
						
							|  |  |  |  |         return not any(isinstance(x, Exception) for x in self.last_result) | 
					
						
							|  |  |  |  |     def __bool__(self): | 
					
						
							|  |  |  |  |         return self.IsValid() | 
					
						
							|  |  |  |  |     @property | 
					
						
							|  |  |  |  |     def CallMaxCount(self): | 
					
						
							|  |  |  |  |         return len(self.call_indexs) | 
					
						
							|  |  |  |  |     @property | 
					
						
							|  |  |  |  |     def ActionCount(self): | 
					
						
							| 
									
										
										
										
											2025-07-21 14:19:27 +08:00
										 |  |  |  |         return len(self._actions) | 
					
						
							| 
									
										
										
										
											2025-07-09 00:01:38 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | # region instance | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | # threads | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | class atomic[_T]: | 
					
						
							|  |  |  |  |     def __init__( | 
					
						
							|  |  |  |  |         self, | 
					
						
							|  |  |  |  |         value:  _T, | 
					
						
							|  |  |  |  |         locker: Optional[threading.Lock]    = None, | 
					
						
							|  |  |  |  |         ) -> None: | 
					
						
							|  |  |  |  |         self._value:        _T              = value | 
					
						
							|  |  |  |  |         self._is_in_with:   bool            = False | 
					
						
							|  |  |  |  |         self.locker:        threading.Lock  = locker if locker is not None else threading.Lock() | 
					
						
							|  |  |  |  |     def FetchAdd(self, value:_T): | 
					
						
							|  |  |  |  |         with lock_guard(self.locker): | 
					
						
							|  |  |  |  |             self._value += value | 
					
						
							|  |  |  |  |         return self._value | 
					
						
							|  |  |  |  |     def FetchSub(self, value:_T): | 
					
						
							|  |  |  |  |         with lock_guard(self.locker): | 
					
						
							|  |  |  |  |             self._value -= value | 
					
						
							|  |  |  |  |         return self._value | 
					
						
							|  |  |  |  |     def Load(self) -> _T: | 
					
						
							|  |  |  |  |         with lock_guard(self.locker): | 
					
						
							|  |  |  |  |             return self._value | 
					
						
							|  |  |  |  |     def Store(self, value: _T): | 
					
						
							|  |  |  |  |         with lock_guard(self.locker): | 
					
						
							|  |  |  |  |             self._value = value | 
					
						
							|  |  |  |  |     def __add__(self, value:_T): | 
					
						
							|  |  |  |  |         return self.FetchAdd(value) | 
					
						
							|  |  |  |  |     def __sub__(self, value:_T): | 
					
						
							|  |  |  |  |         return self.FetchSub(value) | 
					
						
							|  |  |  |  |     def __iadd__(self, value:_T) -> Self: | 
					
						
							|  |  |  |  |         self.FetchAdd(value) | 
					
						
							|  |  |  |  |         return self | 
					
						
							|  |  |  |  |     def __isub__(self, value:_T) -> Self: | 
					
						
							|  |  |  |  |         self.FetchSub(value) | 
					
						
							|  |  |  |  |         return self | 
					
						
							|  |  |  |  |     def __enter__(self) -> Self: | 
					
						
							|  |  |  |  |         self._is_in_with = True | 
					
						
							|  |  |  |  |         self.locker.acquire() | 
					
						
							|  |  |  |  |         return self | 
					
						
							|  |  |  |  |     def __exit__( | 
					
						
							|  |  |  |  |         self, | 
					
						
							|  |  |  |  |         exc_type:   Optional[type], | 
					
						
							|  |  |  |  |         exc_val:    Optional[BaseException], | 
					
						
							|  |  |  |  |         exc_tb:     Optional[TracebackType] | 
					
						
							|  |  |  |  |         ) -> bool: | 
					
						
							|  |  |  |  |         self._is_in_with = False | 
					
						
							|  |  |  |  |         self.locker.release() | 
					
						
							|  |  |  |  |         if exc_type is None: | 
					
						
							|  |  |  |  |             return True | 
					
						
							|  |  |  |  |         else: | 
					
						
							|  |  |  |  |             return False | 
					
						
							|  |  |  |  |     @property | 
					
						
							|  |  |  |  |     def Value(self) -> _T: | 
					
						
							|  |  |  |  |         if self._is_in_with: | 
					
						
							|  |  |  |  |             return self._value | 
					
						
							|  |  |  |  |         raise NotImplementedError("This method can only be called within a with statement") | 
					
						
							|  |  |  |  |     @Value.setter | 
					
						
							|  |  |  |  |     def Value(self, value:_T) -> _T: | 
					
						
							|  |  |  |  |         if self._is_in_with: | 
					
						
							|  |  |  |  |             self._value = value | 
					
						
							|  |  |  |  |         raise NotImplementedError("This method can only be called within a with statement") | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     def __str__(self) -> str: | 
					
						
							|  |  |  |  |         return str(self.Load()) | 
					
						
							|  |  |  |  |     def __repr__(self) -> str: | 
					
						
							|  |  |  |  |         return repr(self.Load()) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | InternalGlobalLocker = threading.Lock() | 
					
						
							|  |  |  |  | InternalGlobalLockerCount = atomic[int](0) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | class lock_guard: | 
					
						
							|  |  |  |  |     def __init__( | 
					
						
							|  |  |  |  |         self, | 
					
						
							|  |  |  |  |         lock:   Optional[Union[threading.RLock, threading.Lock]] = None | 
					
						
							|  |  |  |  |         ): | 
					
						
							|  |  |  |  |         if lock is None: | 
					
						
							|  |  |  |  |             lock = InternalGlobalLocker | 
					
						
							|  |  |  |  |         self._locker = lock | 
					
						
							|  |  |  |  |         self._locker.acquire() | 
					
						
							|  |  |  |  |     def __del__(self): | 
					
						
							|  |  |  |  |         self._locker.release() | 
					
						
							| 
									
										
										
										
											2025-07-09 17:39:50 +08:00
										 |  |  |  |     def __enter__(self): | 
					
						
							|  |  |  |  |         return | 
					
						
							|  |  |  |  |     def __exit__(self,*args,**kwargs): | 
					
						
							|  |  |  |  |         return True | 
					
						
							| 
									
										
										
										
											2025-07-09 00:01:38 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | class global_lock_guard(lock_guard): | 
					
						
							|  |  |  |  |     def __init__(self): | 
					
						
							|  |  |  |  |         super().__init__(None) | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | class thread_instance(threading.Thread): | 
					
						
							|  |  |  |  |     def __init__( | 
					
						
							|  |  |  |  |         self, | 
					
						
							| 
									
										
										
										
											2025-07-13 00:32:17 +08:00
										 |  |  |  |         call:           Action, | 
					
						
							| 
									
										
										
										
											2025-07-09 00:01:38 +08:00
										 |  |  |  |         *, | 
					
						
							|  |  |  |  |         is_del_join:    bool = True, | 
					
						
							|  |  |  |  |         **kwargs | 
					
						
							|  |  |  |  |         ): | 
					
						
							|  |  |  |  |         kwargs.update({"target": call}) | 
					
						
							|  |  |  |  |         super().__init__(**kwargs) | 
					
						
							|  |  |  |  |         self.is_del_join = is_del_join | 
					
						
							|  |  |  |  |         self.start() | 
					
						
							|  |  |  |  |     def __del__(self): | 
					
						
							|  |  |  |  |         if self.is_del_join: | 
					
						
							|  |  |  |  |             self.join() | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | # region end | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | def Nowf() -> str: | 
					
						
							|  |  |  |  |     '''
 | 
					
						
							|  |  |  |  |     printf now time to YYYY-MM-DD_HH-MM-SS format, | 
					
						
							|  |  |  |  |     return: str | 
					
						
							|  |  |  |  |     '''
 | 
					
						
							|  |  |  |  |     return datetime.datetime.now().strftime("%Y-%m-%d_%H-%M-%S") | 
					
						
							| 
									
										
										
										
											2025-07-09 17:39:50 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | true: Literal[True] = True | 
					
						
							|  |  |  |  | false: Literal[False] = False | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | class PlatformIndicator: | 
					
						
							|  |  |  |  |     IsRelease           : bool  = False | 
					
						
							|  |  |  |  |     IsPlatformWindows   : bool  = sys.platform == "Windows" | 
					
						
							|  |  |  |  |     IsPlatformLinux     : bool  = sys.platform == "Linux" | 
					
						
							|  |  |  |  |     IsPlatformOsx       : bool  = sys.platform == "OSX" | 
					
						
							|  |  |  |  |     IsPlatformX64       : bool  = True | 
					
						
							|  |  |  |  |     CompanyName         : str   = "DefaultCompany" | 
					
						
							|  |  |  |  |     ProductName         : str   = "DefaultProject" | 
					
						
							|  |  |  |  |      | 
					
						
							| 
									
										
										
										
											2025-10-14 17:09:04 +08:00
										 |  |  |  |     @staticmethod | 
					
						
							|  |  |  |  |     def GetFileSeparator(is_not_this_platform:bool = False) -> str: | 
					
						
							|  |  |  |  |         if PlatformIndicator.IsPlatformWindows and not is_not_this_platform: | 
					
						
							|  |  |  |  |             return "\\" | 
					
						
							|  |  |  |  |         return "/" | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-09 17:39:50 +08:00
										 |  |  |  |     @staticmethod | 
					
						
							|  |  |  |  |     def GetApplicationPath() -> str: | 
					
						
							|  |  |  |  |         """获取应用程序所在目录""" | 
					
						
							|  |  |  |  |         import os | 
					
						
							|  |  |  |  |         return os.path.dirname(os.path.abspath(__file__)) | 
					
						
							|  |  |  |  |      | 
					
						
							|  |  |  |  |     @staticmethod | 
					
						
							|  |  |  |  |     def GetCurrentWorkingDirectory() -> str: | 
					
						
							|  |  |  |  |         """获取当前工作目录""" | 
					
						
							|  |  |  |  |         import os | 
					
						
							|  |  |  |  |         return os.getcwd() | 
					
						
							|  |  |  |  |      | 
					
						
							|  |  |  |  |     # 使用类方法获取路径 | 
					
						
							|  |  |  |  |     @classmethod | 
					
						
							|  |  |  |  |     def ApplicationPath(cls) -> str: | 
					
						
							|  |  |  |  |         """应用程序路径属性""" | 
					
						
							|  |  |  |  |         return cls.GetApplicationPath() | 
					
						
							|  |  |  |  |      | 
					
						
							|  |  |  |  |     @classmethod   | 
					
						
							|  |  |  |  |     def StreamingAssetsPath(cls) -> str: | 
					
						
							|  |  |  |  |         """流媒体资源路径属性""" | 
					
						
							|  |  |  |  |         return cls.ApplicationPath() + "/StreamingAssets/" | 
					
						
							|  |  |  |  |      | 
					
						
							|  |  |  |  |     @staticmethod | 
					
						
							|  |  |  |  |     def PersistentDataPath() -> str: | 
					
						
							|  |  |  |  |         """
 | 
					
						
							|  |  |  |  |         获取持久化数据路径,根据平台返回不同的路径 | 
					
						
							|  |  |  |  |         """
 | 
					
						
							|  |  |  |  |         import os | 
					
						
							|  |  |  |  |         if PlatformIndicator.IsPlatformWindows: | 
					
						
							|  |  |  |  |             return os.path.expandvars(f"%userprofile%\\AppData\\LocalLow\\{PlatformIndicator.CompanyName}\\{PlatformIndicator.ProductName}\\") | 
					
						
							|  |  |  |  |         elif PlatformIndicator.IsPlatformLinux: | 
					
						
							|  |  |  |  |             return os.path.expandvars("$HOME/.config/") | 
					
						
							|  |  |  |  |         return "" | 
					
						
							|  |  |  |  |      | 
					
						
							|  |  |  |  |     @staticmethod | 
					
						
							|  |  |  |  |     def DataPath() -> str: | 
					
						
							|  |  |  |  |         """
 | 
					
						
							|  |  |  |  |         获取数据路径 | 
					
						
							|  |  |  |  |         """
 | 
					
						
							|  |  |  |  |         return "Assets/" | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | class DescriptiveIndicator[T]: | 
					
						
							|  |  |  |  |     def __init__(self, description:str, value:T) -> None: | 
					
						
							|  |  |  |  |         self.descripion : str   = description | 
					
						
							|  |  |  |  |         self.value      : T     = value | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-09-20 03:39:51 +08:00
										 |  |  |  | class Switch: | 
					
						
							|  |  |  |  |     def __init__(self, value, isThougth = False) -> None: | 
					
						
							|  |  |  |  |         self.value = value | 
					
						
							|  |  |  |  |         self.isThougth = False | 
					
						
							|  |  |  |  |         self.caseStats = False | 
					
						
							|  |  |  |  |         self.result = None | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     def Case(self, caseValue, callback:Callable[[], Any]) -> 'Switch': | 
					
						
							|  |  |  |  |         if self.caseStats and self.isThougth: | 
					
						
							|  |  |  |  |             self.result = callback() | 
					
						
							|  |  |  |  |         elif caseValue == self.value: | 
					
						
							|  |  |  |  |             self.caseStats = True | 
					
						
							|  |  |  |  |             self.result = callback() | 
					
						
							|  |  |  |  |         return self | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     def Default(self, callback:Callable[[], Any]) -> Any: | 
					
						
							|  |  |  |  |         if self.caseStats and self.isThougth: | 
					
						
							|  |  |  |  |             self.result = callback() | 
					
						
							|  |  |  |  |         elif self.caseStats == False: | 
					
						
							|  |  |  |  |             self.caseStats = True | 
					
						
							|  |  |  |  |             self.result = callback() | 
					
						
							|  |  |  |  |         return self.result |