X-Git-Url: http://www2.svjatoslav.eu/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Feu%2Fsvjatoslav%2Fsixth%2Fcore%2Fdocument%2Fcontent%2FListElement.java;h=e1cf33d36e595756d003e52b72969a2cb56f9d41;hb=1f96525468e7f76c1ce817a8a7b22c93a39e40b4;hp=c4e442538e332396102a49b68285ffcc0d9b9aca;hpb=e8052e0b1948260c3701bfe80dfaa8fdf5c38053;p=sixth.git diff --git a/src/main/java/eu/svjatoslav/sixth/core/document/content/ListElement.java b/src/main/java/eu/svjatoslav/sixth/core/document/content/ListElement.java index c4e4425..e1cf33d 100644 --- a/src/main/java/eu/svjatoslav/sixth/core/document/content/ListElement.java +++ b/src/main/java/eu/svjatoslav/sixth/core/document/content/ListElement.java @@ -7,52 +7,87 @@ import eu.svjatoslav.sixth.core.document.text.FormattedText; import java.util.ArrayList; import java.util.List; -import static eu.svjatoslav.sixth.core.document.Helper.TG_DOCUMENT_PROPERTY; +import static eu.svjatoslav.sixth.core.document.Helper.*; public class ListElement implements Content { public final FormattedText name; public final int indent; public final ListElement parent; - private String type; + private final String type; private final List content = new ArrayList<>(); + StringBuilder normalTextAccumulator = new StringBuilder(); public ListElement(FormattedText name, int indent, ListElement parent, String type) { this.indent = indent; this.name = name; - this.parent = parent; this.type = type; + this.parent = parent; } - public void addContent(ListElement content) { + public void addContent(Content content) { + applyTextAccumulator(); this.content.add(content); } + private void applyTextAccumulator(){ + if (normalTextAccumulator.length() == 0) + return; + + content.add(new TextBlock(normalTextAccumulator.toString())); + + normalTextAccumulator.setLength(0); + } + public void parse(TokenizerMatch tm) { if (tm.isGroup(TG_DOCUMENT_PROPERTY)) { -// System.out.println("DOCUMENT PROPERT!!!: " + tm.token); + // TODO + // System.out.println("DOCUMENT PROPERTY!!!: " + tm.token); return; } - if (tm.isGroup(null)) { -// System.out.println(" Plain text content: " + tm.token); + if (tm.isGroup(TG_DRAWER_PROPERTY)) { + // TODO + // System.out.println("DOCUMENT PROPERTY!!!: " + tm.token); return; } - System.out.println("ERROR!!!! Unable to handle: " + tm); + if (tm.isGroup(TG_NORMAL_TEXT)) { + normalTextAccumulator.append(tm.token); + return; + } + if (tm.isGroup(TG_MULTILINE_CODE)){ + // System.out.println(tm.toString()); + String[] groups = tm.getRegExpGroups(); + addContent(new MultilineCode( + groups[3], // language + groups[5] // code + )); + return; + } + + if (tm.isGroup(TG_VERSE)){ + String[] groups = tm.getRegExpGroups(); + addContent(new Verse(groups[5])); + return; + } + + System.out.println("ERROR!!!! Unable to handle: " + tm); } - public void toMD(StringBuilder sb, int i) { - if (indent >= 0){ + public void toMD(StringBuilder sb, int indent) { + applyTextAccumulator(); + + if (this.indent >= 0) { String2 s = new String2(); - s.addSuffix(" ", indent).addSuffix(type).addSuffix(" ").addSuffix(name.toMD()).addSuffix("\n"); + s.append(" ", indent).append(type).append(" ").append(name.toMD(indent + 2)).append("\n"); sb.append(s.toString()); } for (Content c : content) { - c.toMD(sb, indent + 2); + c.toMD(sb, this.indent + 2); } } }