X-Git-Url: https://mograsim.net/gitweb/?a=blobdiff_plain;f=era.mi%2Fsrc%2Fera%2Fmi%2Flogic%2Fcomponents%2FSplitter.java;h=8c54d0f9f6e6475ae72aea6c7c8c8f48c22a4abb;hb=6c67a9ff8361cd9fc082f40e2676f2c8b5911fe4;hp=4764c27a1de2b7e69d02975f4eac192a8b7cccd8;hpb=b56437775ad8674edf9ab833627bf571fdf1bfd8;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 4764c27a..8c54d0f9 100644 --- a/era.mi/src/era/mi/logic/components/Splitter.java +++ b/era.mi/src/era/mi/logic/components/Splitter.java @@ -1,22 +1,26 @@ package era.mi.logic.components; +import java.util.List; + +import era.mi.logic.timeline.Timeline; import era.mi.logic.types.BitVector; -import era.mi.logic.wires.Wire; -import era.mi.logic.wires.Wire.WireEnd; +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 +public class Splitter extends Component implements WireObserver { - private WireEnd input; - private WireEnd[] outputs; + private ReadEnd input; + private ReadWriteEnd[] outputs; - public Splitter(WireEnd input, WireEnd... outputs) + public Splitter(Timeline timeline, ReadEnd input, ReadWriteEnd... outputs) { + super(timeline); 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) @@ -36,8 +40,20 @@ public class Splitter implements WireObserver } @Override - public void update(Wire initiator, BitVector 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); + } }