X-Git-Url: https://mograsim.net/gitweb/?a=blobdiff_plain;f=era.mi%2Fsrc%2Fera%2Fmi%2Flogic%2Fcomponents%2FSplitter.java;h=37e940157090ce93ff62679a8180c7e37baf21b0;hb=4712d3e6ee08461b7754dbfba1c9e82372bb474d;hp=360ff431f6c0668606397d720598bd65f57b6973;hpb=74aebd92f41d03f4a44c9a455ef8c05465136412;p=Mograsim.git diff --git a/era.mi/src/era/mi/logic/components/Splitter.java b/era.mi/src/era/mi/logic/components/Splitter.java index 360ff431..37e94015 100644 --- a/era.mi/src/era/mi/logic/components/Splitter.java +++ b/era.mi/src/era/mi/logic/components/Splitter.java @@ -2,14 +2,16 @@ 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.WireArray.WireArrayEnd; import era.mi.logic.wires.WireArrayObserver; -public class Splitter implements WireArrayObserver { +public class Splitter implements WireArrayObserver +{ private WireArray input; - private WireArrayInput[] outputs; + private WireArrayEnd[] outputs; - public Splitter(WireArray input, WireArray... outputs) { + public Splitter(WireArray input, WireArray... outputs) + { this.input = input; this.outputs = WireArray.extractInputs(outputs); input.addObserver(this); @@ -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()."); } - protected void compute() { + protected void compute() + { int startIndex = 0; Bit[] inputBits = input.getValues(); - for (int i = 0; i < outputs.length; i++) { + for (int i = 0; i < outputs.length; i++) + { Bit[] outputBits = new Bit[outputs[i].owner.length]; System.arraycopy(inputBits, startIndex, outputBits, 0, outputs[i].owner.length); outputs[i].feedSignals(outputBits); @@ -34,7 +38,8 @@ public class Splitter implements WireArrayObserver { } @Override - public void update(WireArray initiator, Bit[] oldValues) { + public void update(WireArray initiator, Bit[] oldValues) + { compute(); } }