Fixed Merger, Mux, Splitter: onedirectional again. Tests added.
[Mograsim.git] / era.mi / src / era / mi / logic / components / Splitter.java
index 58d48e7..5475fa1 100644 (file)
@@ -2,17 +2,18 @@ package era.mi.logic.components;
 
 import era.mi.logic.Bit;
 import era.mi.logic.wires.WireArray;
+import era.mi.logic.wires.WireArray.WireArrayInput;
 import era.mi.logic.wires.WireArrayObserver;
 
 public class Splitter implements WireArrayObserver
 {
        private WireArray input;
-       private WireArray[] outputs;
+       private WireArrayInput[] outputs;
        
        public Splitter(WireArray input, WireArray... outputs)
        {
                this.input = input;
-               this.outputs = outputs;
+               this.outputs = WireArray.extractInputs(outputs);
                input.addObserver(this);
                int length = 0;
                for(WireArray out : outputs)
@@ -28,22 +29,12 @@ public class Splitter implements WireArrayObserver
                Bit[] inputBits = input.getValues();
                for(int i = 0; i < outputs.length; i++)
                {
-                       Bit[] outputBits = new Bit[outputs[i].length];
-                       System.arraycopy(inputBits, startIndex, outputBits, 0, outputs[i].length);
+                       Bit[] outputBits = new Bit[outputs[i].owner.length];
+                       System.arraycopy(inputBits, startIndex, outputBits, 0, outputs[i].owner.length);
                        outputs[i].feedSignals(outputBits);
-                       startIndex += outputs[i].length;
+                       startIndex += outputs[i].owner.length;
                }
        }
-
-       public WireArray getInput()
-       {
-               return input;
-       }
-       
-       public WireArray[] getOutputs()
-       {
-               return outputs.clone();
-       }
        
        @Override
        public void update(WireArray initiator)