import java.io.IOException;
-import com.google.gson.Gson;
-import com.google.gson.GsonBuilder;
import com.google.gson.JsonNull;
import net.mograsim.logic.ui.SimpleLogicUIStandalone;
import net.mograsim.logic.ui.serializing.IndirectGUIComponentCreator;
import net.mograsim.logic.ui.serializing.SubmodelComponentDeserializer;
import net.mograsim.logic.ui.serializing.SubmodelComponentParams;
+import net.mograsim.logic.ui.util.JsonHandler;
public class JsonExample
{
GUI_rsLatch comp = new GUI_rsLatch(viewModel);
comp.moveTo(30, 0);
SubmodelComponentParams params = comp.calculateParams();
- String jsonString = new GsonBuilder().setPrettyPrinting().create().toJson(params);
+ String jsonString = JsonHandler.toJson(params);
System.out.println(jsonString);
- SubmodelComponent deserialized = SubmodelComponentDeserializer.create(viewModel,
- new Gson().fromJson(jsonString, SubmodelComponentParams.class));
- deserialized.moveTo(30, 50);
+ SubmodelComponentParams paramsD = JsonHandler.fromJson(jsonString, SubmodelComponentParams.class);
+ SubmodelComponent componentD = SubmodelComponentDeserializer.create(viewModel, paramsD);
+ componentD.moveTo(30, 50);
double h = 0;
for (String s : comp.getInputPinNames())
{
new GUIWire(viewModel, sw.getOutputPin(), comp.getPin(s));
sw = new GUIManualSwitch(viewModel);
sw.moveTo(0, h + 50);
- new GUIWire(viewModel, sw.getOutputPin(), deserialized.getPin(s));
+ new GUIWire(viewModel, sw.getOutputPin(), componentD.getPin(s));
h += 20;
}
h = 0;
new GUIWire(viewModel, bd.getInputPin(), comp.getPin(s));
bd = new GUIBitDisplay(viewModel);
bd.moveTo(80, h + 50);
- new GUIWire(viewModel, bd.getInputPin(), deserialized.getPin(s));
+ new GUIWire(viewModel, bd.getInputPin(), componentD.getPin(s));
h += 20;
}
}
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
+import java.util.stream.Collectors;
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
{
try (InputStreamReader reader = new InputStreamReader(input); BufferedReader bf = new BufferedReader(reader))
{
- String json = bf.lines().dropWhile(s -> s.length() == 0 || s.charAt(0) != '{').reduce("", (x, y) -> x.concat(y));
- T params = parser.fromJson(json, type);
- return params;
+ return fromJson(bf.lines().collect(Collectors.joining("\n")), type);
}
}
+ public static <T> T fromJson(String src, Class<T> type)
+ {
+ // TODO actually parse and compare version
+ String rawJson = src.lines().dropWhile(s -> s.length() == 0 || s.charAt(0) != '{').collect(Collectors.joining());
+ return parser.fromJson(rawJson, type);
+ }
+
public static void writeJson(Object o, String path) throws IOException
{
try (FileWriter writer = new FileWriter(path))
{
- writer.write(String.format("mograsim version: %s\n", Version.jsonCompVersion.toString()));
- writer.write(parser.toJson(o));
+ writer.write(toJson(o));
}
}
+
+ public static String toJson(Object o)
+ {
+ return String.format("mograsim version: %s\n%s", Version.jsonCompVersion.toString(), parser.toJson(o));
+ }
}