Implemented some high level state handlers; changed standard snippet IDs
[Mograsim.git] / net.mograsim.logic.model / src / net / mograsim / logic / model / snippets / highlevelstatehandlers / standard / StandardHighLevelStateHandler.java
index ec3b04d..1c3ac62 100644 (file)
@@ -2,8 +2,10 @@ package net.mograsim.logic.model.snippets.highlevelstatehandlers.standard;
 
 import java.util.HashMap;
 import java.util.Map;
+import java.util.function.BiFunction;
+import java.util.function.Function;
 
-import net.mograsim.logic.model.model.components.GUIComponent;
+import net.mograsim.logic.model.model.components.submodels.SubmodelComponent;
 import net.mograsim.logic.model.snippets.HighLevelStateHandler;
 import net.mograsim.logic.model.snippets.SnippetDefinintion;
 import net.mograsim.logic.model.snippets.SubmodelComponentSnippetSuppliers;
@@ -14,24 +16,48 @@ import net.mograsim.logic.model.snippets.highlevelstatehandlers.standard.subcomp
 
 public class StandardHighLevelStateHandler implements HighLevelStateHandler
 {
-       private final GUIComponent component;
+       private final SubmodelComponent component;
        private final Map<String, SubcomponentHighLevelStateHandler> subcomponentHighLevelStateHandlers;
        private final Map<String, AtomicHighLevelStateHandler> atomicHighLevelStateHandlers;
 
-       public StandardHighLevelStateHandler(GUIComponent component, SimpleHighLevelStateHandlerParams params)
+       public StandardHighLevelStateHandler(SubmodelComponent component)
+       {
+               this(component, null);
+       }
+
+       public StandardHighLevelStateHandler(SubmodelComponent component, StandardHighLevelStateHandlerParams params)
        {
                this.component = component;
                this.subcomponentHighLevelStateHandlers = new HashMap<>();
                this.atomicHighLevelStateHandlers = new HashMap<>();
-               params.subcomponentHighLevelStates.forEach(this::addSubcomponentHighLevelState);
-               params.atomicHighLevelStates.forEach(this::addAtomicHighLevelState);
+               if (params != null)
+               {
+                       params.subcomponentHighLevelStates.forEach(this::addSubcomponentHighLevelState);
+                       params.atomicHighLevelStates.forEach(this::addAtomicHighLevelState);
+               }
+       }
+
+       public SubcomponentHighLevelStateHandler addSubcomponentHighLevelState(String subcomponentStateID,
+                       SubcomponentHighLevelStateHandlerParams handlerParams)
+       {
+               return addSubcomponentHighLevelState(subcomponentStateID,
+                               StandardHighLevelStateHandlerSnippetSuppliers.subcomponentHandlerSupplier.getSnippetSupplier(handlerParams.id)::create,
+                               handlerParams.params);
+       }
+
+       public <P, H extends SubcomponentHighLevelStateHandler> H addSubcomponentHighLevelState(String subcomponentStateID,
+                       BiFunction<HighLevelStateHandlerContext, P, H> handlerConstructor, P handlerParams)
+       {
+               return addSubcomponentHighLevelState(subcomponentStateID, c -> handlerConstructor.apply(c, handlerParams));
        }
 
-       public void addSubcomponentHighLevelState(String subcomponentStateID, SubcomponentHighLevelStateHandlerParams handlerParams)
+       public <H extends SubcomponentHighLevelStateHandler> H addSubcomponentHighLevelState(String subcomponentStateID,
+                       Function<HighLevelStateHandlerContext, H> handlerConstructor)
        {
                HighLevelStateHandlerContext context = new HighLevelStateHandlerContext(component, subcomponentStateID);
-               addSubcomponentHighLevelState(subcomponentStateID, StandardHighLevelStateHandlerSnippetSuppliers.subcomponentHandlerSupplier
-                               .getSnippetSupplier(handlerParams.id).create(context, handlerParams.params));
+               H handler = handlerConstructor.apply(context);
+               addSubcomponentHighLevelState(subcomponentStateID, handler);
+               return handler;
        }
 
        public void addSubcomponentHighLevelState(String subcomponentStateID, SubcomponentHighLevelStateHandler handler)
@@ -40,11 +66,26 @@ public class StandardHighLevelStateHandler implements HighLevelStateHandler
                subcomponentHighLevelStateHandlers.put(subcomponentStateID, handler);
        }
 
-       public void addAtomicHighLevelState(String atomicStateID, AtomicHighLevelStateHandlerParams handlerParams)
+       public AtomicHighLevelStateHandler addAtomicHighLevelState(String atomicStateID, AtomicHighLevelStateHandlerParams handlerParams)
+       {
+               return addAtomicHighLevelState(atomicStateID,
+                               StandardHighLevelStateHandlerSnippetSuppliers.atomicHandlerSupplier.getSnippetSupplier(handlerParams.id)::create,
+                               handlerParams.params);
+       }
+
+       public <P, H extends AtomicHighLevelStateHandler> H addAtomicHighLevelState(String subcomponentStateID,
+                       BiFunction<HighLevelStateHandlerContext, P, H> handlerConstructor, P handlerParams)
        {
-               HighLevelStateHandlerContext context = new HighLevelStateHandlerContext(component, atomicStateID);
-               addSubcomponentHighLevelState(atomicStateID, StandardHighLevelStateHandlerSnippetSuppliers.subcomponentHandlerSupplier
-                               .getSnippetSupplier(handlerParams.id).create(context, handlerParams.params));
+               return addAtomicHighLevelState(subcomponentStateID, c -> handlerConstructor.apply(c, handlerParams));
+       }
+
+       public <H extends AtomicHighLevelStateHandler> H addAtomicHighLevelState(String subcomponentStateID,
+                       Function<HighLevelStateHandlerContext, H> handlerConstructor)
+       {
+               HighLevelStateHandlerContext context = new HighLevelStateHandlerContext(component, subcomponentStateID);
+               H handler = handlerConstructor.apply(context);
+               addAtomicHighLevelState(subcomponentStateID, handler);
+               return handler;
        }
 
        public void addAtomicHighLevelState(String atomicStateID, AtomicHighLevelStateHandler handler)
@@ -98,7 +139,7 @@ public class StandardHighLevelStateHandler implements HighLevelStateHandler
                }
        }
 
-       public static class SimpleHighLevelStateHandlerParams
+       public static class StandardHighLevelStateHandlerParams
        {
                public Map<String, SubcomponentHighLevelStateHandlerParams> subcomponentHighLevelStates;
                public Map<String, AtomicHighLevelStateHandlerParams> atomicHighLevelStates;
@@ -108,6 +149,6 @@ public class StandardHighLevelStateHandler implements HighLevelStateHandler
        {
                SubmodelComponentSnippetSuppliers.highLevelStateHandlerSupplier.setSnippetSupplier(
                                StandardHighLevelStateHandler.class.getCanonicalName(),
-                               SnippetDefinintion.create(SimpleHighLevelStateHandlerParams.class, StandardHighLevelStateHandler::new));
+                               SnippetDefinintion.create(StandardHighLevelStateHandlerParams.class, StandardHighLevelStateHandler::new));
        }
 }
\ No newline at end of file