X-Git-Url: https://mograsim.net/gitweb/?a=blobdiff_plain;f=era.mi%2Fsrc%2Fera%2Fmi%2Flogic%2Fcomponents%2FSplitter.java;h=32841ab97e64ebbd0adad14b5affa588f25dbb21;hb=b7ce41467a2cbd9f45554982730741810e99feaa;hp=127f70d1798beeee7af72bfd2a60732499f12346;hpb=c1d0ddc342c482051fa6c455bb286617135bd3c3;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 127f70d1..32841ab9 100644 --- a/era.mi/src/era/mi/logic/components/Splitter.java +++ b/era.mi/src/era/mi/logic/components/Splitter.java @@ -1,22 +1,24 @@ package era.mi.logic.components; -import era.mi.logic.Bit; -import era.mi.logic.wires.Wire; -import era.mi.logic.wires.Wire.WireEnd; -import era.mi.logic.wires.WireArrayObserver; +import java.util.List; -public class Splitter implements WireArrayObserver +import era.mi.logic.types.BitVector; +import era.mi.logic.wires.Wire.ReadEnd; +import era.mi.logic.wires.Wire.ReadWriteEnd; +import era.mi.logic.wires.WireObserver; + +public class Splitter implements WireObserver, Component { - private WireEnd input; - private WireEnd[] outputs; + private ReadEnd input; + private ReadWriteEnd[] outputs; - public Splitter(WireEnd input, WireEnd... outputs) + public Splitter(ReadEnd input, ReadWriteEnd... outputs) { this.input = input; this.outputs = outputs; input.addObserver(this); int length = 0; - for (WireEnd out : outputs) + for (ReadEnd out : outputs) length += out.length(); if (input.length() != length) @@ -26,20 +28,30 @@ public class Splitter implements WireArrayObserver protected void compute() { + BitVector inputBits = input.getValues(); int startIndex = 0; - 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()); - outputs[i].feedSignals(outputBits); + outputs[i].feedSignals(inputBits.subVector(startIndex, startIndex + outputs[i].length())); startIndex += outputs[i].length(); } } @Override - public void update(Wire initiator, Bit[] oldValues) + public void update(ReadEnd initiator, BitVector oldValues) { compute(); } + + @Override + public List getAllInputs() + { + return List.of(input); + } + + @Override + public List getAllOutputs() + { + return List.of(outputs); + } }