summaryrefslogtreecommitdiff
path: root/altoslib/AltosMag.java
diff options
context:
space:
mode:
authorKeith Packard <keithp@keithp.com>2016-06-15 22:40:27 -0700
committerKeith Packard <keithp@keithp.com>2016-06-15 22:40:27 -0700
commit1b5ea911049a8afae6af475a4a2bf62a6e3aa57b (patch)
tree7f896e587da5e7911b7b5a42aade1b7692670200 /altoslib/AltosMag.java
parent1de8b6c340cec0b5a327392686c5a4e00f201e98 (diff)
altoslib: Switch preserved state format to JSON
This is much easier to debug than the icky strings with backslashes everywhere. Signed-off-by: Keith Packard <keithp@keithp.com>
Diffstat (limited to 'altoslib/AltosMag.java')
-rw-r--r--altoslib/AltosMag.java26
1 files changed, 25 insertions, 1 deletions
diff --git a/altoslib/AltosMag.java b/altoslib/AltosMag.java
index c350ae46..ec98882f 100644
--- a/altoslib/AltosMag.java
+++ b/altoslib/AltosMag.java
@@ -20,7 +20,7 @@ package org.altusmetrum.altoslib_11;
import java.util.concurrent.*;
import java.io.*;
-public class AltosMag implements Cloneable, AltosHashable {
+public class AltosMag implements Cloneable, AltosHashable, AltosJsonable {
public int along;
public int across;
public int through;
@@ -103,6 +103,15 @@ public class AltosMag implements Cloneable, AltosHashable {
return h;
}
+ public AltosJson json() {
+ AltosJson j = new AltosJson();
+
+ j.put("along", along);
+ j.put("across", across);
+ j.put("through", through);
+ return j;
+ }
+
public AltosMag(AltosHashSet h) {
this();
@@ -117,4 +126,19 @@ public class AltosMag implements Cloneable, AltosHashable {
return new AltosMag(h);
}
+
+ public AltosMag(AltosJson j) {
+ this();
+
+ along = j.get_int("along", along);
+ across = j.get_int("across", across);
+ through = j.get_int("through", through);
+ }
+
+ public static AltosMag fromJson(AltosJson j, AltosMag def) {
+ if (j == null)
+ return def;
+
+ return new AltosMag(j);
+ }
}