Added project specific format; Default values in WireArray are now U
[Mograsim.git] / era.mi / src / era / mi / logic / components / Splitter.java
index ff23e5c..1264aa3 100644 (file)
@@ -2,14 +2,16 @@ package era.mi.logic.components;
 \r
 import era.mi.logic.Bit;\r
 import era.mi.logic.wires.WireArray;\r
-import era.mi.logic.wires.WireArray.WireArrayInput;\r
+import era.mi.logic.wires.WireArray.WireArrayEnd;\r
 import era.mi.logic.wires.WireArrayObserver;\r
 \r
-public class Splitter implements WireArrayObserver {\r
+public class Splitter implements WireArrayObserver\r
+{\r
        private WireArray input;\r
-       private WireArrayInput[] outputs;\r
+       private WireArrayEnd[] outputs;\r
 \r
-       public Splitter(WireArray input, WireArray... outputs) {\r
+       public Splitter(WireArray input, WireArray... outputs)\r
+       {\r
                this.input = input;\r
                this.outputs = WireArray.extractInputs(outputs);\r
                input.addObserver(this);\r
@@ -22,10 +24,12 @@ public class Splitter implements WireArrayObserver {
                                        "The input of splitting one into n WireArrays must have length = a1.length() + a2.length() + ... + an.length().");\r
        }\r
 \r
-       protected void compute() {\r
+       protected void compute()\r
+       {\r
                int startIndex = 0;\r
                Bit[] inputBits = input.getValues();\r
-               for (int i = 0; i < outputs.length; i++) {\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
@@ -34,7 +38,8 @@ public class Splitter implements WireArrayObserver {
        }\r
 \r
        @Override\r
-       public void update(WireArray initiator, Bit[] oldValues) {\r
+       public void update(WireArray initiator, Bit[] oldValues)\r
+       {\r
                compute();\r
        }\r
 }\r