Made get/setHLS final to force components to set a HLSHandler
[Mograsim.git] / plugins / net.mograsim.machine / src / net / mograsim / machine / standard / memory / ModelWordAddressableMemory.java
index 7490b36..b249849 100644 (file)
@@ -4,6 +4,8 @@ import net.mograsim.logic.model.model.LogicModelModifiable;
 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.MainMemory;
 import net.mograsim.machine.MainMemoryDefinition;
 import net.mograsim.machine.ModelMemory;
@@ -23,6 +25,38 @@ public abstract class ModelWordAddressableMemory extends ModelMemory
                addPin(dataPin = new Pin(model, this, "D", definition.getCellWidth(), PinUsage.TRISTATE, getWidth(), 50));
                addPin(rWPin = new Pin(model, this, "RW", 1, PinUsage.INPUT, getWidth(), 70));
 
+               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((MainMemory) 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();
        }
 
@@ -56,23 +90,6 @@ public abstract class ModelWordAddressableMemory extends ModelMemory
                return memory;
        }
 
-       @Override
-       public void setHighLevelState(String stateID, Object newState)
-       {
-               if (stateID.equals("memory_binding"))
-                       memory.setMemory((MainMemory) 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 WordAddressableMemoryAdapter());