lockss-pybasic 0.1.0.dev15__tar.gz → 0.1.0.dev17__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {lockss_pybasic-0.1.0.dev15 → lockss_pybasic-0.1.0.dev17}/PKG-INFO +1 -1
- {lockss_pybasic-0.1.0.dev15 → lockss_pybasic-0.1.0.dev17}/pyproject.toml +1 -1
- {lockss_pybasic-0.1.0.dev15 → lockss_pybasic-0.1.0.dev17}/src/lockss/pybasic/__init__.py +1 -1
- {lockss_pybasic-0.1.0.dev15 → lockss_pybasic-0.1.0.dev17}/src/lockss/pybasic/cliutil.py +10 -10
- {lockss_pybasic-0.1.0.dev15 → lockss_pybasic-0.1.0.dev17}/LICENSE +0 -0
- {lockss_pybasic-0.1.0.dev15 → lockss_pybasic-0.1.0.dev17}/README.rst +0 -0
- {lockss_pybasic-0.1.0.dev15 → lockss_pybasic-0.1.0.dev17}/src/lockss/pybasic/errorutil.py +0 -0
- {lockss_pybasic-0.1.0.dev15 → lockss_pybasic-0.1.0.dev17}/src/lockss/pybasic/fileutil.py +0 -0
- {lockss_pybasic-0.1.0.dev15 → lockss_pybasic-0.1.0.dev17}/src/lockss/pybasic/outpututil.py +0 -0
|
@@ -89,8 +89,8 @@ class BaseCli(Generic[BaseModelT]):
|
|
|
89
89
|
the program.
|
|
90
90
|
"""
|
|
91
91
|
super().__init__()
|
|
92
|
-
self.
|
|
93
|
-
self.
|
|
92
|
+
self._args: Optional[BaseModelT] = None
|
|
93
|
+
self._parser: Optional[ArgumentParser] = None
|
|
94
94
|
self.extra: Dict[str, Any] = dict(**extra)
|
|
95
95
|
|
|
96
96
|
def run(self) -> None:
|
|
@@ -107,10 +107,10 @@ class BaseCli(Generic[BaseModelT]):
|
|
|
107
107
|
|
|
108
108
|
:return: Nothing.
|
|
109
109
|
"""
|
|
110
|
-
self.
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
self.
|
|
110
|
+
self._parser: ArgumentParser = ArgumentParser(model=self.extra.get('model'),
|
|
111
|
+
prog=self.extra.get('prog'),
|
|
112
|
+
description=self.extra.get('description'))
|
|
113
|
+
self._args = self._parser.parse_typed_args()
|
|
114
114
|
self.dispatch()
|
|
115
115
|
|
|
116
116
|
def dispatch(self) -> None:
|
|
@@ -121,18 +121,18 @@ class BaseCli(Generic[BaseModelT]):
|
|
|
121
121
|
|
|
122
122
|
:return: Nothing.
|
|
123
123
|
"""
|
|
124
|
-
field_names = self.
|
|
124
|
+
field_names = self._args.__class__.__fields__.keys()
|
|
125
125
|
for field_name in field_names:
|
|
126
|
-
field_value = getattr(self.
|
|
126
|
+
field_value = getattr(self._args, field_name)
|
|
127
127
|
if issubclass(type(field_value), BaseModel):
|
|
128
128
|
func = getattr(self, f'_{field_name}')
|
|
129
129
|
if callable(func):
|
|
130
130
|
func(field_value)
|
|
131
131
|
else:
|
|
132
|
-
self.
|
|
132
|
+
self._parser.exit(1, f'internal error: no _{field_name} callable for the {field_name} command')
|
|
133
133
|
break
|
|
134
134
|
else:
|
|
135
|
-
self.
|
|
135
|
+
self._parser.error(f'unknown command; expected one of {', '.join(field_names)}')
|
|
136
136
|
|
|
137
137
|
|
|
138
138
|
def at_most_one_from_enum(model_cls, values: Dict[str, Any], enum_cls) -> Dict[str, Any]:
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|