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.ModelMerger;
9 import net.mograsim.logic.model.model.wires.Pin;
10 import net.mograsim.logic.model.modeladapter.CoreModelParameters;
12 public class MergerAdapter implements ComponentAdapter<ModelMerger>
15 public Class<ModelMerger> getSupportedClass()
17 return ModelMerger.class;
21 public void createAndLinkComponent(Timeline timeline, CoreModelParameters params, ModelMerger modelComponent,
22 Map<Pin, CoreWire> logicWiresPerPin)
24 CoreWire output = logicWiresPerPin.get(modelComponent.getPin("O"));
25 ReadEnd[] inputEnds = new ReadEnd[modelComponent.logicWidth];
26 for (int i = 0; i < modelComponent.logicWidth; i++)
28 CoreWire input = logicWiresPerPin.get(modelComponent.getPin("I" + (modelComponent.logicWidth - 1 - i)));
29 CoreWire.fuse(input, output, 0, i);
30 inputEnds[i] = input.createReadOnlyEnd();
32 modelComponent.setCoreModelBinding(inputEnds, output.createReadOnlyEnd());