diff options
author | crupest <crupest@outlook.com> | 2024-11-11 01:12:29 +0800 |
---|---|---|
committer | Yuqian Yang <crupest@crupest.life> | 2025-01-20 23:41:34 +0800 |
commit | 672492caff469ea135d5e1338d4406d2b20bab16 (patch) | |
tree | 4ae61ce81e170c5208123d1b0a63bba20c6119f1 /tools/cru-py/cru/service/_base.py | |
parent | 90a72d2d7ed4a5eadfe36f62d81f26ca3324e49b (diff) | |
download | crupest-672492caff469ea135d5e1338d4406d2b20bab16.tar.gz crupest-672492caff469ea135d5e1338d4406d2b20bab16.tar.bz2 crupest-672492caff469ea135d5e1338d4406d2b20bab16.zip |
HALF WORK: 2024.1.20 - 5
Diffstat (limited to 'tools/cru-py/cru/service/_base.py')
-rw-r--r-- | tools/cru-py/cru/service/_base.py | 23 |
1 files changed, 14 insertions, 9 deletions
diff --git a/tools/cru-py/cru/service/_base.py b/tools/cru-py/cru/service/_base.py index 6f2a61a..ad813c9 100644 --- a/tools/cru-py/cru/service/_base.py +++ b/tools/cru-py/cru/service/_base.py @@ -7,7 +7,7 @@ import os from pathlib import Path from typing import TypeVar, overload -from cru import CruException, CruLogicError, CruPath +from cru import CruException, CruLogicError _Feature = TypeVar("_Feature", bound="AppFeatureProvider") @@ -64,14 +64,19 @@ class AppPath(ABC): @property @abstractmethod - def full_path(self) -> CruPath: ... + def full_path(self) -> Path: ... @property def full_path_str(self) -> str: return str(self.full_path) def check_parents(self, must_exist: bool = False) -> bool: - return self.full_path.check_parents_dir(must_exist) + for p in reversed(self.full_path.parents): + if not p.exists() and not must_exist: + return False + if not p.is_dir(): + raise AppPathError("Parents' path must be a dir.", self.full_path) + return True def check_self(self, must_exist: bool = False) -> bool: if not self.check_parents(must_exist): @@ -112,7 +117,7 @@ class AppPath(ABC): return self.app.add_path(name, is_dir, self, id, description) @property - def app_relative_path(self) -> CruPath: + def app_relative_path(self) -> Path: return self.full_path.relative_to(self.app.root.full_path) @@ -143,15 +148,15 @@ class AppFeaturePath(AppPath): return self.parent.app @property - def full_path(self) -> CruPath: - return CruPath(self.parent.full_path, self.name).resolve() + def full_path(self) -> Path: + return Path(self.parent.full_path, self.name).resolve() class AppRootPath(AppPath): def __init__(self, app: AppBase): super().__init__("root", True, "Application root path.") self._app = app - self._full_path: CruPath | None = None + self._full_path: Path | None = None @property def parent(self) -> None: @@ -162,7 +167,7 @@ class AppRootPath(AppPath): return self._app @property - def full_path(self) -> CruPath: + def full_path(self) -> Path: if self._full_path is None: raise AppError("App root path is not set yet.") return self._full_path @@ -170,7 +175,7 @@ class AppRootPath(AppPath): def setup(self, path: os.PathLike) -> None: if self._full_path is not None: raise AppError("App root path is already set.") - self._full_path = CruPath(path).resolve() + self._full_path = Path(path).resolve() class AppFeatureProvider(ABC): |