fix(cli): InterfaceGenerator now works even without a namespace defined
continuous-integration/woodpecker the build failed Details

This commit is contained in:
Ferdinand Thiessen 2021-12-23 02:48:28 +01:00
parent 34ee95c66a
commit a6cbc002f6
1 changed files with 28 additions and 10 deletions

View File

@ -1,3 +1,4 @@
import io
import sys import sys
import inspect import inspect
import logging import logging
@ -93,15 +94,32 @@ class InterfaceGenerator:
self.basename = models.__name__ self.basename = models.__name__
self.walker(("models", models)) self.walker(("models", models))
def _write_types(self):
TYPE = "type {name} = {alias};\n"
INTERFACE = "interface {name} {{\n{properties}}}\n"
PROPERTY = "\t{name}{modifier}: {type};\n"
buffer = io.StringIO()
for cls, props in self.classes.items():
if isinstance(props, str):
buffer.write(TYPE.format(name=cls, alias=props))
else:
buffer.write(
INTERFACE.format(
name=cls,
properties="".join(
[PROPERTY.format(name=name, modifier=props[name][0], type=props[name][1]) for name in props]
),
)
)
return buffer
def write(self): def write(self):
with (open(self.filename, "w") if self.filename else sys.stdout) as file: with (open(self.filename, "w") if self.filename else sys.stdout) as file:
file.write("declare namespace {} {{\n".format(self.namespace)) if self.namespace:
for cls, params in self.classes.items(): file.write(f"declare namespace {self.namespace} {{\n")
if isinstance(params, str): for line in self._write_types().getvalue().split("\n"):
file.write("\ttype {} = {};\n".format(cls, params)) file.write(f"\t{line}\n")
else:
file.write("\tinterface {} {{\n".format(cls))
for name in params:
file.write("\t\t{}{}: {};\n".format(name, *params[name]))
file.write("\t}\n")
file.write("}\n") file.write("}\n")
else:
file.write(self._write_types().getvalue())