Fixed a bug in Am2900; created dlatch8/80; relayouted some components
[Mograsim.git] / net.mograsim.logic.model.am2900 / test / net / mograsim / logic / model / am2900 / am2904 / Am2904Testbench.java
1 package net.mograsim.logic.model.am2900.am2904;
2
3 import net.haspamelodica.swt.helper.gcs.GeneralGC;
4 import net.haspamelodica.swt.helper.swtobjectwrappers.Rectangle;
5 import net.mograsim.logic.core.types.Bit;
6 import net.mograsim.logic.core.types.BitVector;
7 import net.mograsim.logic.model.SimpleLogicUIStandalone;
8 import net.mograsim.logic.model.SimpleLogicUIStandalone.VisualisationObjects;
9 import net.mograsim.logic.model.am2900.Am2900Loader;
10 import net.mograsim.logic.model.model.LogicModelModifiable;
11 import net.mograsim.logic.model.model.components.atomic.ModelManualSwitch;
12 import net.mograsim.logic.model.model.components.submodels.SubmodelComponent;
13 import net.mograsim.logic.model.serializing.DeserializedSubmodelComponent;
14 import net.mograsim.logic.model.serializing.IdentifyParams;
15 import net.mograsim.logic.model.serializing.IndirectModelComponentCreator;
16 import net.mograsim.logic.model.snippets.Renderer;
17
18 public class Am2904Testbench
19 {
20         public static void main(String[] args)
21         {
22                 Am2900Loader.setup();
23                 SimpleLogicUIStandalone.executeVisualisation(Am2904Testbench::create, Am2904Testbench::beforeRun);
24         }
25
26         public static void create(LogicModelModifiable model)
27         {
28                 // TODO replace with proper LogicModel deserialization
29                 DeserializedSubmodelComponent testbench = (DeserializedSubmodelComponent) IndirectModelComponentCreator.createComponent(model,
30                                 "jsonfile:Am2904Testbench.json", "testbench");
31                 testbench.setSize(1000, 1000);
32                 testbench.setOutlineRenderer(new Renderer()
33                 {
34                         @Override
35                         public String getIDForSerializing(IdentifyParams idParams)
36                         {
37                                 return null;
38                         }
39
40                         @Override
41                         public Void getParamsForSerializing(IdentifyParams idParams)
42                         {
43                                 return null;
44                         }
45
46                         @Override
47                         public void render(GeneralGC gc, Rectangle visibleRegion)
48                         {
49                                 // do nothing
50                         }
51                 });
52         }
53
54         public static void beforeRun(VisualisationObjects vis)
55         {
56                 ((SubmodelComponent) vis.model.getComponentsByName().get("testbench")).submodel.getComponentsByName().values().forEach(c ->
57                 {
58                         if (c instanceof ModelManualSwitch)
59                         {
60                                 ModelManualSwitch cCasted = (ModelManualSwitch) c;
61                                 cCasted.setHighLevelState("out", BitVector.of(Bit.ZERO, cCasted.logicWidth));
62                         }
63                 });
64         }
65 }