X-Git-Url: https://mograsim.net/gitweb/?a=blobdiff_plain;f=era.mi%2Fsrc%2Fera%2Fmi%2Flogic%2Fcomponents%2FSplitter.java;h=e936c82e30c11714741db0dc85efae3d9ba971a0;hb=70afb26181aba8de30ea6f796ea5c2a573d9ecab;hp=87c0f60f27ba9ad695e609142cbe83b53b1ed2f7;hpb=7c7b279981f4686d4fe165cf327ff5b52d71c5f6;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 87c0f60f..e936c82e 100644 --- a/era.mi/src/era/mi/logic/components/Splitter.java +++ b/era.mi/src/era/mi/logic/components/Splitter.java @@ -1,6 +1,6 @@ package era.mi.logic.components; -import era.mi.logic.Bit; +import era.mi.logic.types.BitVector; import era.mi.logic.wires.Wire; import era.mi.logic.wires.Wire.WireEnd; import era.mi.logic.wires.WireObserver; @@ -26,19 +26,17 @@ public class Splitter implements WireObserver 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(Wire initiator, BitVector oldValues) { compute(); }