X-Git-Url: http://git.nikiroo.be/?p=nikiroo-utils.git;a=blobdiff_plain;f=data%2FJsonIO.java;h=524f99a7da2de6a56c0d5ad8bc8de027efbaacdc;hp=db81db65a03b93555445a7ac4254b19707aa9c1f;hb=9bd801bfc6a10e5298cdec6e48ca0506ecdfde53;hpb=5f3671e17febc5b7f6abbfc62c66c4045d47ec8d diff --git a/data/JsonIO.java b/data/JsonIO.java index db81db6..524f99a 100644 --- a/data/JsonIO.java +++ b/data/JsonIO.java @@ -7,6 +7,9 @@ import org.json.JSONArray; import org.json.JSONException; import org.json.JSONObject; +import be.nikiroo.fanfix.data.Paragraph.ParagraphType; +import be.nikiroo.utils.Progress; + public class JsonIO { static public JSONObject toJson(MetaData meta) { if (meta == null) { @@ -14,6 +17,7 @@ public class JsonIO { } JSONObject json = new JSONObject(); + put(json, "", MetaData.class.getName()); put(json, "luid", meta.getLuid()); put(json, "title", meta.getTitle()); @@ -28,6 +32,9 @@ public class JsonIO { put(json, "subject", meta.getSubject()); put(json, "type", meta.getType()); put(json, "uuid", meta.getUuid()); + put(json, "fake_cover", meta.isFakeCover()); + put(json, "image_document", meta.isImageDocument()); + put(json, "resume", toJson(meta.getResume())); put(json, "tags", new JSONArray(meta.getTags())); @@ -35,6 +42,7 @@ public class JsonIO { } /** + * // no image * * @param json * @@ -49,6 +57,7 @@ public class JsonIO { } MetaData meta = new MetaData(); + meta.setLuid(getString(json, "luid")); meta.setTitle(getString(json, "title")); meta.setAuthor(getString(json, "author")); @@ -62,6 +71,8 @@ public class JsonIO { meta.setSubject(getString(json, "subject")); meta.setType(getString(json, "type")); meta.setUuid(getString(json, "uuid")); + meta.setFakeCover(getBoolean(json, "fake_cover", false)); + meta.setImageDocument(getBoolean(json, "image_document", false)); meta.setResume(toChapter(getJson(json, "resume"))); meta.setTags(toListString(getJsonArr(json, "tags"))); @@ -69,14 +80,61 @@ public class JsonIO { return meta; } + static public JSONObject toJson(Story story) { + if (story == null) { + return null; + } + + JSONObject json = new JSONObject(); + put(json, "", Story.class.getName()); + put(json, "meta", toJson(story.getMeta())); + + List chapters = new ArrayList(); + for (Chapter chap : story) { + chapters.add(toJson(chap)); + } + put(json, "chapters", new JSONArray(chapters)); + + return json; + } + + /** + * + * @param json + * + * @return + * + * @throws JSONException + * when it cannot be converted + */ + static public Story toStory(JSONObject json) { + if (json == null) { + return null; + } + + Story story = new Story(); + story.setMeta(toMetaData(getJson(json, "meta"))); + story.setChapters(toListChapter(getJsonArr(json, "chapters"))); + + return story; + } + static public JSONObject toJson(Chapter chap) { if (chap == null) { return null; } JSONObject json = new JSONObject(); + put(json, "", Chapter.class.getName()); + put(json, "name", chap.getName()); + put(json, "number", chap.getNumber()); + put(json, "words", chap.getWords()); - // TODO + List paragraphs = new ArrayList(); + for (Paragraph para : chap) { + paragraphs.add(toJson(para)); + } + put(json, "paragraphs", new JSONArray(paragraphs)); return json; } @@ -95,18 +153,115 @@ public class JsonIO { return null; } - Chapter chap = new Chapter(0, ""); + Chapter chap = new Chapter(getInt(json, "number", 0), + getString(json, "name")); + chap.setWords(getLong(json, "words", 0)); - // TODO + chap.setParagraphs(toListParagraph(getJsonArr(json, "paragraphs"))); return chap; } + // no images + static public JSONObject toJson(Paragraph para) { + if (para == null) { + return null; + } + + JSONObject json = new JSONObject(); + + put(json, "", Paragraph.class.getName()); + put(json, "content", para.getContent()); + put(json, "words", para.getWords()); + + put(json, "type", para.getType().toString()); + + return json; + } + + /** + * // no images + * + * @param json + * + * @return + * + * @throws JSONException + * when it cannot be converted + */ + static public Paragraph toParagraph(JSONObject json) { + if (json == null) { + return null; + } + + Paragraph para = new Paragraph( + ParagraphType.valueOf(getString(json, "type")), + getString(json, "content"), getLong(json, "words", 0)); + + return para; + } + + // no children included + static public JSONObject toJson(Progress pg) { + if (pg == null) { + return null; + } + + JSONObject json = new JSONObject(); + + put(json, "", Progress.class.getName()); + put(json, "name", pg.getName()); + put(json, "min", pg.getMin()); + put(json, "max", pg.getMax()); + put(json, "progress", pg.getProgress()); + + return json; + } + + // no children included + static public Progress toProgress(JSONObject json) { + if (json == null) { + return null; + } + + Progress pg = new Progress(getString(json, "name"), + getInt(json, "min", 0), getInt(json, "max", 100)); + pg.setProgress(getInt(json, "progress", 0)); + + return pg; + } + static public List toListString(JSONArray array) { if (array != null) { List values = new ArrayList(); - for (Object value : array.toList()) { - values.add(value == null ? null : value.toString()); + for (int i = 0; i < array.length(); i++) { + values.add(array.getString(i)); + } + return values; + } + + return null; + } + + static public List toListParagraph(JSONArray array) { + if (array != null) { + List values = new ArrayList(); + for (int i = 0; i < array.length(); i++) { + JSONObject value = array.getJSONObject(i); + values.add(toParagraph(value)); + } + return values; + } + + return null; + } + + private static List toListChapter(JSONArray array) { + if (array != null) { + List values = new ArrayList(); + for (int i = 0; i < array.length(); i++) { + JSONObject value = array.getJSONObject(i); + values.add(toChapter(value)); } return values; } @@ -132,8 +287,44 @@ public class JsonIO { static long getLong(JSONObject json, String key, long def) { if (json.has(key)) { Object o = json.get(key); - if (o instanceof Long) { + if (o instanceof Byte) + return (Byte) o; + if (o instanceof Short) + return (Short) o; + if (o instanceof Integer) + return (Integer) o; + if (o instanceof Long) return (Long) o; + } + + return def; + } + + static boolean getBoolean(JSONObject json, String key, boolean def) { + if (json.has(key)) { + Object o = json.get(key); + if (o instanceof Boolean) { + return (Boolean) o; + } + } + + return def; + } + + static int getInt(JSONObject json, String key, int def) { + if (json.has(key)) { + Object o = json.get(key); + if (o instanceof Byte) + return (Byte) o; + if (o instanceof Short) + return (Short) o; + if (o instanceof Integer) + return (Integer) o; + if (o instanceof Long) { + try { + return (int) (long) ((Long) o); + } catch (Exception e) { + } } }