X-Git-Url: https://mograsim.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=era.mi%2Fsrc%2Fera%2Fmi%2Flogic%2Fcomponents%2Fgates%2FNotGate.java;h=f81ba9250cd32c21b7aeb17947586bfe8bda94d6;hb=74aebd92f41d03f4a44c9a455ef8c05465136412;hp=55d0cb01bb42b49115e36cde1fc58c0d9f48ab3d;hpb=a4c5cfb856026771dfcf31eb22434b8b6ff20ad4;p=Mograsim.git diff --git a/era.mi/src/era/mi/logic/components/gates/NotGate.java b/era.mi/src/era/mi/logic/components/gates/NotGate.java index 55d0cb01..f81ba925 100644 --- a/era.mi/src/era/mi/logic/components/gates/NotGate.java +++ b/era.mi/src/era/mi/logic/components/gates/NotGate.java @@ -1,33 +1,45 @@ package era.mi.logic.components.gates; +import java.util.Arrays; +import java.util.Collections; +import java.util.List; + import era.mi.logic.Util; -import era.mi.logic.WireArray; import era.mi.logic.components.BasicComponent; +import era.mi.logic.wires.WireArray; +import era.mi.logic.wires.WireArray.WireArrayInput; -public class NotGate extends BasicComponent -{ +public class NotGate extends BasicComponent { private WireArray in, out; - - public NotGate(int processTime, WireArray in, WireArray out) - { + private WireArrayInput outI; + + public NotGate(int processTime, WireArray in, WireArray out) { super(processTime); this.in = in; in.addObserver(this); this.out = out; + outI = out.createInput(); } - - public void compute() - { - out.feedSignals(Util.not(in.getValues())); + + public void compute() { + outI.feedSignals(Util.not(in.getValues())); } - public WireArray getIn() - { + public WireArray getIn() { return in; } - public WireArray getOut() - { + public WireArray getOut() { return out; } + + @Override + public List getAllInputs() { + return Collections.unmodifiableList(Arrays.asList(in)); + } + + @Override + public List getAllOutputs() { + return Collections.unmodifiableList(Arrays.asList(out)); + } }