X-Git-Url: https://mograsim.net/gitweb/?a=blobdiff_plain;f=era.mi%2Fsrc%2Fera%2Fmi%2Flogic%2Fcomponents%2FBasicComponent.java;h=3e5b6e06595764202a833fcb28786f212079a701;hb=f2cd90fa2b844507bc9697d3af1f3e18aac80b37;hp=ddcf4ceaaecdc4615b7033067637f968d98c3de0;hpb=4c8fb641dc21efe699f457dcd48fc3cf3660740d;p=Mograsim.git diff --git a/era.mi/src/era/mi/logic/components/BasicComponent.java b/era.mi/src/era/mi/logic/components/BasicComponent.java index ddcf4cea..3e5b6e06 100644 --- a/era.mi/src/era/mi/logic/components/BasicComponent.java +++ b/era.mi/src/era/mi/logic/components/BasicComponent.java @@ -1,29 +1,35 @@ -package era.mi.logic.components; - -import era.mi.logic.Simulation; -import era.mi.logic.wires.WireArray; -import era.mi.logic.wires.WireArrayObserver; - -public abstract class BasicComponent implements WireArrayObserver -{ - private int processTime; - - /** - * - * @param processTime Amount of time this component takes to update its outputs. Must be more than 0, otherwise 1 is assumed. - * - * @author Fabian Stemmler - */ - public BasicComponent(int processTime) - { - this.processTime = processTime > 0 ? processTime : 1; - } - - @Override - public void update(WireArray initiator) - { - Simulation.TIMELINE.addEvent((e) -> {compute();}, processTime); - } - - protected abstract void compute(); -} +package era.mi.logic.components; + +import era.mi.logic.Bit; +import era.mi.logic.Simulation; +import era.mi.logic.wires.WireArray; +import era.mi.logic.wires.WireArrayObserver; + +/** + * A basic component that recomputes all outputs (with a delay), when it is updated. + * + * @author Fabian Stemmler + */ +public abstract class BasicComponent implements WireArrayObserver, Component +{ + private int processTime; + + /** + * + * @param processTime Amount of time this component takes to update its outputs. Must be more than 0, otherwise 1 is assumed. + * + * @author Fabian Stemmler + */ + public BasicComponent(int processTime) + { + this.processTime = processTime > 0 ? processTime : 1; + } + + @Override + public void update(WireArray initiator, Bit[] oldValues) + { + Simulation.TIMELINE.addEvent(e -> compute(), processTime); + } + + protected abstract void compute(); +}