importdataclassesimportjsonimportznflowimportznflow.handlerimportznflow.utilsimportznjsonfromzntrackimportconverterfromzntrack.configimportZNTRACK_FILE_PATH,FieldTypesfromzntrack.fields.baseimportfieldfromzntrack.nodeimportNodedef_deps_getter(self:"Node",name:str):withself.state.fs.open(ZNTRACK_FILE_PATH)asf:content=json.load(f)[self.name][name]# TODO: Ensure deps are loaded from the correct revisioncontent=znjson.loads(json.dumps(content),cls=znjson.ZnDecoder.from_converters([converter.NodeConverter,converter.ConnectionConverter,converter.CombinedConnectionsConverter,converter.DVCImportPathConverter,converter.DataclassConverter,],add_default=True,),)ifisinstance(content,converter.DataclassContainer):content=content.get_with_params(self.name,name)ifisinstance(content,list):new_content=[]idx=0forvalincontent:ifisinstance(val,converter.DataclassContainer):new_content.append(val.get_with_params(self.name,name,idx))idx+=1# index only runs over dataclasseselse:new_content.append(val)content=new_contentcontent=znflow.handler.UpdateConnectors()(content)returncontent
[docs]defdeps(default=dataclasses.MISSING,**kwargs):"""Define dependencies for a node. A Node dependency field can be used to pass data from one node to another. It can not be used to pass anything that is not a ``zntrack.Node`` or a ``dataclass``. Parameters ---------- default : Any, optional Should not be set on the class level. Examples -------- >>> import zntrack >>> class MyFirstNode(zntrack.Node): ... outs: int = zntrack.outs() ... ... def run(self) -> None: ... self.outs = 42 ... >>> class MySecondNode(zntrack.Node): ... deps: int = zntrack.deps() ... ... def run(self) -> None: ... ... >>> with zntrack.Project() as project: ... node1 = MyFirstNode() ... node2 = MySecondNode(deps=node1.outs) >>> project.build() """returnfield(default=default,load_fn=_deps_getter,field_type=FieldTypes.DEPS,**kwargs,)