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