Suppressed warnings where the thing warned about is intentional
[Mograsim.git] / era.mi / src / era / mi / logic / components / Splitter.java
index 1264aa3..b26cb3c 100644 (file)
@@ -1,45 +1,59 @@
 package era.mi.logic.components;\r
 \r
-import era.mi.logic.Bit;\r
-import era.mi.logic.wires.WireArray;\r
-import era.mi.logic.wires.WireArray.WireArrayEnd;\r
-import era.mi.logic.wires.WireArrayObserver;\r
+import java.util.List;\r
 \r
-public class Splitter implements WireArrayObserver\r
+import era.mi.logic.timeline.Timeline;\r
+import era.mi.logic.types.BitVector;\r
+import era.mi.logic.wires.Wire.ReadEnd;\r
+import era.mi.logic.wires.Wire.ReadWriteEnd;\r
+import era.mi.logic.wires.WireObserver;\r
+\r
+public class Splitter extends Component implements WireObserver\r
 {\r
-       private WireArray input;\r
-       private WireArrayEnd[] outputs;\r
+       private ReadEnd input;\r
+       private ReadWriteEnd[] outputs;\r
 \r
-       public Splitter(WireArray input, WireArray... outputs)\r
+       public Splitter(Timeline timeline, ReadEnd input, ReadWriteEnd... outputs)\r
        {\r
+               super(timeline);\r
                this.input = input;\r
-               this.outputs = WireArray.extractInputs(outputs);\r
+               this.outputs = outputs;\r
                input.addObserver(this);\r
                int length = 0;\r
-               for (WireArray out : outputs)\r
-                       length += out.length;\r
+               for (ReadEnd out : outputs)\r
+                       length += out.length();\r
 \r
-               if (input.length != length)\r
+               if (input.length() != length)\r
                        throw new IllegalArgumentException(\r
                                        "The input of splitting one into n WireArrays must have length = a1.length() + a2.length() + ... + an.length().");\r
        }\r
 \r
        protected void compute()\r
        {\r
+               BitVector inputBits = input.getValues();\r
                int startIndex = 0;\r
-               Bit[] inputBits = input.getValues();\r
                for (int i = 0; i < outputs.length; i++)\r
                {\r
-                       Bit[] outputBits = new Bit[outputs[i].owner.length];\r
-                       System.arraycopy(inputBits, startIndex, outputBits, 0, outputs[i].owner.length);\r
-                       outputs[i].feedSignals(outputBits);\r
-                       startIndex += outputs[i].owner.length;\r
+                       outputs[i].feedSignals(inputBits.subVector(startIndex, startIndex + outputs[i].length()));\r
+                       startIndex += outputs[i].length();\r
                }\r
        }\r
 \r
        @Override\r
-       public void update(WireArray initiator, Bit[] oldValues)\r
+       public void update(ReadEnd initiator, BitVector oldValues)\r
        {\r
                compute();\r
        }\r
+\r
+       @Override\r
+       public List<ReadEnd> getAllInputs()\r
+       {\r
+               return List.of(input);\r
+       }\r
+\r
+       @Override\r
+       public List<ReadWriteEnd> getAllOutputs()\r
+       {\r
+               return List.of(outputs);\r
+       }\r
 }\r