for (String id : am2901.getOutputPinNames())
{
GUIBitDisplay bd = new GUIBitDisplay(viewModel);
+// bd.addRedrawListener(() -> System.out.println(id + " " + bd.getBitDisplay().getDisplayedValue()));
new GUIWire(viewModel, am2901.getPin(id), bd.getInputPin());
idDisplayMap.put(id, bd);
}
setField(entry.getKey().replaceAll("\\+|=", "_"), entry.getValue().getManualSwitch());
for (var entry : idDisplayMap.entrySet())
setField(entry.getKey().replaceAll("\\+|=", "_"), entry.getValue().getBitDisplay());
- // Switch Clock off first
- C.switchOff();
// Debug code
HashSet<GUIWire> wiresIncludingSubmodels = new HashSet<>();
{
if (debugWires)
{
- System.out.println(w);
wireDebugChangeSet.add(w.toString());
}
}));
}
@Override
- public void toogleClock()
+ public void clockOn(boolean isClockOn)
{
- C.toggle();
+ C.setState(isClockOn);
}
@Override
}
return mutator.toBitVector();
}
+
+ @Override
+ public void setDirectly(Register r, String val_4_bit)
+ {
+ am2901.setHighLevelState(regToStateID(r), BitVector.parse(val_4_bit));
+ }
+
+ @Override
+ public String getDirectly(Register r)
+ {
+ return am2901.getHighLevelState(regToStateID(r)).toString();
+ }
+
+ private static String regToStateID(Register r)
+ {
+ if (r == Register.Q)
+ return "qreg.q";
+ return "regs.c" + r.toBitString() + ".q";
+ }
}