1 package net.mograsim.logic.model.modeladapter.componentadapters;
5 import net.mograsim.logic.core.timeline.Timeline;
6 import net.mograsim.logic.core.wires.CoreWire;
7 import net.mograsim.logic.core.wires.CoreWire.ReadEnd;
8 import net.mograsim.logic.model.model.components.atomic.ModelSplitter;
9 import net.mograsim.logic.model.model.wires.Pin;
10 import net.mograsim.logic.model.modeladapter.CoreModelParameters;
12 public class SplitterAdapter implements ComponentAdapter<ModelSplitter>
15 public Class<ModelSplitter> getSupportedClass()
17 return ModelSplitter.class;
21 public void createAndLinkComponent(Timeline timeline, CoreModelParameters params, ModelSplitter modelComponent,
22 Map<Pin, CoreWire> logicWiresPerPin)
24 CoreWire input = logicWiresPerPin.get(modelComponent.getPin("I"));
25 ReadEnd[] outputEnds = new ReadEnd[modelComponent.logicWidth];
26 for (int i = 0; i < modelComponent.logicWidth; i++)
28 CoreWire output = logicWiresPerPin.get(modelComponent.getPin("O" + (modelComponent.logicWidth - 1 - i)));
29 CoreWire.fuse(input, output, i, 0);
30 outputEnds[i] = output.createReadOnlyEnd();
32 modelComponent.setCoreModelBinding(input.createReadOnlyEnd(), outputEnds);