Exchanged all Bit[] by BitVector, tests work
[Mograsim.git] / era.mi / src / era / mi / logic / components / gates / MultiInputGate.java
index 7d0e485..e76661d 100644 (file)
@@ -3,7 +3,8 @@ package era.mi.logic.components.gates;
 import java.util.List;\r
 \r
 import era.mi.logic.components.BasicComponent;\r
-import era.mi.logic.types.Bit;\r
+import era.mi.logic.types.BitVector.BitVectorMutator;\r
+import era.mi.logic.types.MutationOperation;\r
 import era.mi.logic.wires.Wire.WireEnd;\r
 \r
 public abstract class MultiInputGate extends BasicComponent\r
@@ -11,9 +12,9 @@ public abstract class MultiInputGate extends BasicComponent
        protected WireEnd[] in;\r
        protected WireEnd out;\r
        protected final int length;\r
-       protected Operation op;\r
+       protected MutationOperation op;\r
 \r
-       protected MultiInputGate(int processTime, Operation op, WireEnd out, WireEnd... in)\r
+       protected MultiInputGate(int processTime, MutationOperation op, WireEnd out, WireEnd... in)\r
        {\r
                super(processTime);\r
                this.op = op;\r
@@ -45,14 +46,9 @@ public abstract class MultiInputGate extends BasicComponent
        @Override\r
        protected void compute()\r
        {\r
-               Bit[] result = in[0].getValues();\r
-               for (int i = 1; i < in.length; i++)\r
-                       result = op.execute(result, in[i].getValues());\r
-               out.feedSignals(result);\r
-       }\r
-\r
-       protected interface Operation\r
-       {\r
-               public Bit[] execute(Bit[] a, Bit[] b);\r
+               BitVectorMutator mutator = BitVectorMutator.empty();\r
+               for (WireEnd w : in)\r
+                       op.apply(mutator, w.getValues());\r
+               out.feedSignals(mutator.get());\r
        }\r
 }\r