f4pga/sfbuild/sf_stage.py

79 lines
2.6 KiB
Python
Raw Normal View History

from sf_common import decompose_depname, resolve_modstr
from sf_module import Module
from sf_module_runner import get_module, module_io
class StageIO:
"""
Stage dependency input/output.
TODO: Solve the inconsistecy between usage of that and usage of
`decompose_depname` with an unprocessed string.
"""
name: str # A symbolic name given to the dependency
spec: str
def __init__(self, encoded_name: str):
"""
Encoded name feauters special characters that imply certain qualifiers.
Any name that ends with '?' is treated as with 'maybe' qualifier.
The '?' Symbol is then dropped from the dependency name.
"""
self.name, self.spec = decompose_depname(encoded_name)
def __repr__(self) -> str:
return 'StageIO { name: \'' + self.name + '\', spec: ' + \
self.spec + '}'
class Stage:
"""
Represents a single stage in a flow. I.e an instance of a module with a
local set of values.
"""
name: str # Name of the stage (module's name)
takes: 'list[StageIO]' # List of symbolic names of dependencies used by
# the stage
produces: 'list[StageIO]' # List of symbolic names of dependencies
# produced by the stage
value_overrides: 'dict[str, ]' # Stage-specific values
module: Module
meta: 'dict[str, str]' # Stage's metadata extracted from module's
# output.
def __init__(self, name: str, modstr: str, mod_opts: 'dict[str, ] | None'):
if mod_opts is None:
mod_opts = {}
module_path = resolve_modstr(modstr)
ModuleClass = get_module(module_path)
self.module = ModuleClass(mod_opts.get('params'))
values = mod_opts.get('values')
if values is not None:
self.value_overrides = values
else:
self.value_overrides = {}
mod_io = module_io(self.module)
self.name = name
self.takes = []
for input in mod_io['takes']:
io = StageIO(input)
self.takes.append(io)
self.produces = []
for input in mod_io['produces']:
io = StageIO(input)
self.produces.append(io)
self.meta = mod_io['meta']
def __repr__(self) -> str:
return 'Stage \'' + self.name + '\' {' \
f' value_overrides: {self.value_ovds},' \
f' args: {self.args},' \
f' takes: {self.takes},' \
f' produces: {self.produces} ' + '}'