Implemented GUIMerger + GUISplitter
[Mograsim.git] / net.mograsim.logic.model / src / net / mograsim / logic / model / modeladapter / componentadapters / MergerAdapter.java
diff --git a/net.mograsim.logic.model/src/net/mograsim/logic/model/modeladapter/componentadapters/MergerAdapter.java b/net.mograsim.logic.model/src/net/mograsim/logic/model/modeladapter/componentadapters/MergerAdapter.java
new file mode 100644 (file)
index 0000000..a94118b
--- /dev/null
@@ -0,0 +1,34 @@
+package net.mograsim.logic.model.modeladapter.componentadapters;
+
+import java.util.Map;
+
+import net.mograsim.logic.core.timeline.Timeline;
+import net.mograsim.logic.core.wires.Wire;
+import net.mograsim.logic.core.wires.Wire.ReadEnd;
+import net.mograsim.logic.model.model.components.atomic.GUIMerger;
+import net.mograsim.logic.model.model.wires.Pin;
+import net.mograsim.logic.model.modeladapter.LogicModelParameters;
+
+public class MergerAdapter implements ComponentAdapter<GUIMerger>
+{
+       @Override
+       public Class<GUIMerger> getSupportedClass()
+       {
+               return GUIMerger.class;
+       }
+
+       @Override
+       public void createAndLinkComponent(Timeline timeline, LogicModelParameters params, GUIMerger guiComponent,
+                       Map<Pin, Wire> logicWiresPerPin)
+       {
+               Wire output = logicWiresPerPin.get(guiComponent.getPin("O"));
+               ReadEnd[] inputEnds = new ReadEnd[guiComponent.logicWidth];
+               for (int i = 0; i < guiComponent.logicWidth; i++)
+               {
+                       Wire input = logicWiresPerPin.get(guiComponent.getPin("I" + i));
+                       Wire.fuse(input, output, 0, i, 1);
+                       inputEnds[i] = input.createReadOnlyEnd();
+               }
+               guiComponent.setLogicModelBinding(inputEnds, output.createReadOnlyEnd());
+       }
+}
\ No newline at end of file