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
/
Splitter.java
diff --git
a/era.mi/src/era/mi/logic/components/Splitter.java
b/era.mi/src/era/mi/logic/components/Splitter.java
index
4764c27
..
32841ab
100644
(file)
--- a/
era.mi/src/era/mi/logic/components/Splitter.java
+++ b/
era.mi/src/era/mi/logic/components/Splitter.java
@@
-1,22
+1,24
@@
package era.mi.logic.components;
package era.mi.logic.components;
+import java.util.List;
+
import era.mi.logic.types.BitVector;
import era.mi.logic.types.BitVector;
-import era.mi.logic.wires.Wire;
-import era.mi.logic.wires.Wire.
Wir
eEnd;
+import era.mi.logic.wires.Wire
.ReadEnd
;
+import era.mi.logic.wires.Wire.
ReadWrit
eEnd;
import era.mi.logic.wires.WireObserver;
import era.mi.logic.wires.WireObserver;
-public class Splitter implements WireObserver
+public class Splitter implements WireObserver
, Component
{
{
- private
Wire
End input;
- private
Wir
eEnd[] outputs;
+ private
Read
End input;
+ private
ReadWrit
eEnd[] outputs;
- public Splitter(
WireEnd input, Wir
eEnd... outputs)
+ public Splitter(
ReadEnd input, ReadWrit
eEnd... outputs)
{
this.input = input;
this.outputs = outputs;
input.addObserver(this);
int length = 0;
{
this.input = input;
this.outputs = outputs;
input.addObserver(this);
int length = 0;
- for (
Wire
End out : outputs)
+ for (
Read
End out : outputs)
length += out.length();
if (input.length() != length)
length += out.length();
if (input.length() != length)
@@
-36,8
+38,20
@@
public class Splitter implements WireObserver
}
@Override
}
@Override
- public void update(
Wire
initiator, BitVector oldValues)
+ public void update(
ReadEnd
initiator, BitVector oldValues)
{
compute();
}
{
compute();
}
+
+ @Override
+ public List<ReadEnd> getAllInputs()
+ {
+ return List.of(input);
+ }
+
+ @Override
+ public List<ReadWriteEnd> getAllOutputs()
+ {
+ return List.of(outputs);
+ }
}
}