Fixed a bug in Am2900; created dlatch8/80; relayouted some components
[Mograsim.git] / net.mograsim.logic.model / src / net / mograsim / logic / model / modeladapter / componentadapters / MergerAdapter.java
1 package net.mograsim.logic.model.modeladapter.componentadapters;
2
3 import java.util.Map;
4
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;
11
12 public class MergerAdapter implements ComponentAdapter<ModelMerger>
13 {
14         @Override
15         public Class<ModelMerger> getSupportedClass()
16         {
17                 return ModelMerger.class;
18         }
19
20         @Override
21         public void createAndLinkComponent(Timeline timeline, CoreModelParameters params, ModelMerger modelComponent,
22                         Map<Pin, CoreWire> logicWiresPerPin)
23         {
24                 CoreWire output = logicWiresPerPin.get(modelComponent.getPin("O"));
25                 ReadEnd[] inputEnds = new ReadEnd[modelComponent.logicWidth];
26                 for (int i = 0; i < modelComponent.logicWidth; i++)
27                 {
28                         CoreWire input = logicWiresPerPin.get(modelComponent.getPin("I" + (modelComponent.logicWidth - 1 - i)));
29                         CoreWire.fuse(input, output, 0, i);
30                         inputEnds[i] = input.createReadOnlyEnd();
31                 }
32                 modelComponent.setCoreModelBinding(inputEnds, output.createReadOnlyEnd());
33         }
34 }