import net.mograsim.logic.model.model.wires.Pin;
import net.mograsim.logic.model.model.wires.PinUsage;
import net.mograsim.logic.model.modeladapter.LogicCoreAdapter;
+import net.mograsim.logic.model.serializing.IdentifyParams;
+import net.mograsim.logic.model.snippets.HighLevelStateHandler;
import net.mograsim.machine.ModelMemory;
import net.mograsim.machine.mi.MicroInstructionMemory;
import net.mograsim.machine.mi.MicroInstructionMemoryDefinition;
addPin(dataPin = new Pin(model, this, "D", definition.getMicroInstructionDefinition().sizeInBits(), PinUsage.OUTPUT, getWidth(),
50));
+ setHighLevelStateHandler(new HighLevelStateHandler()
+ {
+ @Override
+ public Object getHighLevelState(String stateID)
+ {
+ if (stateID.equals("memory_binding"))
+ return memory.getMemory();
+ throw new IllegalArgumentException("No high level state with ID " + stateID);
+ }
+
+ @Override
+ public void setHighLevelState(String stateID, Object newState)
+ {
+ if (stateID.equals("memory_binding"))
+ memory.setMemory((MicroInstructionMemory) newState);
+ else
+ throw new IllegalArgumentException("No high level state with ID " + stateID);
+ }
+
+ @Override
+ public String getIDForSerializing(IdentifyParams idParams)
+ {
+ return null;
+ }
+
+ @Override
+ public Object getParamsForSerializing(IdentifyParams idParams)
+ {
+ return null;
+ }
+ });
+
init();
}
this.memory = memory;
}
- @Override
- public void setHighLevelState(String stateID, Object newState)
- {
- if (stateID.equals("memory_binding"))
- memory.setMemory((MicroInstructionMemory) newState);
- else
- super.setHighLevelState(stateID, newState);
- }
-
- @Override
- public Object getHighLevelState(String stateID)
- {
- if (stateID.equals("memory_binding"))
- return memory.getMemory();
- return super.getHighLevelState(stateID);
- }
-
static
{
LogicCoreAdapter.addComponentAdapter(new MicroInstructionMemoryAdapter());