projects
/
Mograsim.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
WireEnd functionality split into ReadEnd and ReadWriteEnd
[Mograsim.git]
/
era.mi
/
src
/
era
/
mi
/
logic
/
components
/
gates
/
NotGate.java
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
f81ba92
..
150785b
100644
(file)
--- a/
era.mi/src/era/mi/logic/components/gates/NotGate.java
+++ b/
era.mi/src/era/mi/logic/components/gates/NotGate.java
@@
-1,45
+1,49
@@
package era.mi.logic.components.gates;
package era.mi.logic.components.gates;
-import java.util.Arrays;
-import java.util.Collections;
import java.util.List;
import java.util.List;
-import era.mi.logic.Util;
import era.mi.logic.components.BasicComponent;
import era.mi.logic.components.BasicComponent;
-import era.mi.logic.wires.Wire
Array
;
-import era.mi.logic.wires.Wire
Array.WireArrayInput
;
+import era.mi.logic.wires.Wire
.ReadEnd
;
+import era.mi.logic.wires.Wire
.ReadWriteEnd
;
-public class NotGate extends BasicComponent {
- private WireArray in, out;
- private WireArrayInput outI;
+public class NotGate extends BasicComponent
+{
+ private ReadEnd in;
+ private ReadWriteEnd out;
- public NotGate(int processTime, WireArray in, WireArray out) {
+ public NotGate(int processTime, ReadEnd in, ReadWriteEnd out)
+ {
super(processTime);
this.in = in;
in.addObserver(this);
this.out = out;
super(processTime);
this.in = in;
in.addObserver(this);
this.out = out;
- outI = out.createInput();
}
}
- public void compute() {
- outI.feedSignals(Util.not(in.getValues()));
+ @Override
+ protected void compute()
+ {
+ out.feedSignals(in.getValues().not());
}
}
- public WireArray getIn() {
+ public ReadEnd getIn()
+ {
return in;
}
return in;
}
- public WireArray getOut() {
+ public ReadEnd getOut()
+ {
return out;
}
@Override
return out;
}
@Override
- public List<WireArray> getAllInputs() {
- return Collections.unmodifiableList(Arrays.asList(in));
+ public List<ReadEnd> getAllInputs()
+ {
+ return List.of(in);
}
@Override
}
@Override
- public List<WireArray> getAllOutputs() {
- return Collections.unmodifiableList(Arrays.asList(out));
+ public List<ReadWriteEnd> getAllOutputs()
+ {
+ return List.of(out);
}
}
}
}