From 47ebda69daa34ea7992b6bbadf46de98dd17a390 Mon Sep 17 00:00:00 2001 From: crupest Date: Mon, 11 Nov 2024 01:12:29 +0800 Subject: HALF WORK: 2024.1.9 --- tools/cru-py/cru/service/__main__.py | 49 ++++++------------------------------ 1 file changed, 7 insertions(+), 42 deletions(-) (limited to 'tools/cru-py/cru/service/__main__.py') diff --git a/tools/cru-py/cru/service/__main__.py b/tools/cru-py/cru/service/__main__.py index 923c25b..c218bc6 100644 --- a/tools/cru-py/cru/service/__main__.py +++ b/tools/cru-py/cru/service/__main__.py @@ -1,45 +1,6 @@ -from pathlib import Path +from cru import CruUserFriendlyException -from cru import CruException - -from ._base import AppBase, DATA_DIR_NAME, CommandDispatcher -from ._config import ConfigManager -from ._data import DataManager -from ._template import TemplateManager - - -class App(AppBase): - def __init__(self, root: str): - super().__init__("crupest-service", root) - self.add_feature(DataManager()) - self.add_feature(ConfigManager()) - self.add_feature(TemplateManager()) - self.add_feature(CommandDispatcher()) - - def setup(self): - for feature in self.features: - feature.setup() - - def run_command(self): - command_dispatcher = self.get_feature(CommandDispatcher) - command_dispatcher.run_command() - - -def _find_root() -> Path: - cwd = Path.cwd() - data_dir = cwd / DATA_DIR_NAME - if data_dir.is_dir(): - return data_dir - raise CruException( - "No valid data directory found. Please run 'init' to create one." - ) - - -def create_app() -> App: - root = _find_root() - app = App(str(root)) - app.setup() - return app +from ._app import create_app def main(): @@ -48,4 +9,8 @@ def main(): if __name__ == "__main__": - main() + try: + main() + except CruUserFriendlyException as e: + print(f"Error: {e.user_message}") + exit(1) -- cgit v1.2.3