X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Fsone%2Ftemplate%2FReplyAccessor.java;h=715b87f500693684c0e1c92c1f9b8bf4ed12da09;hb=7815943b9ecc1199e11dd8be9736d6f3e892118e;hp=d5fd7e4d2500e6a54ec0aaa4b4c6277404ddec82;hpb=63e85ddb7cebbb91f7be41640edb6104bd74650a;p=Sone.git diff --git a/src/main/java/net/pterodactylus/sone/template/ReplyAccessor.java b/src/main/java/net/pterodactylus/sone/template/ReplyAccessor.java index d5fd7e4..715b87f 100644 --- a/src/main/java/net/pterodactylus/sone/template/ReplyAccessor.java +++ b/src/main/java/net/pterodactylus/sone/template/ReplyAccessor.java @@ -17,23 +17,43 @@ package net.pterodactylus.sone.template; +import java.io.IOException; +import java.io.StringReader; + import net.pterodactylus.sone.core.Core; import net.pterodactylus.sone.data.Reply; import net.pterodactylus.sone.data.Sone; +import net.pterodactylus.sone.text.FreenetLinkParser; +import net.pterodactylus.util.template.Accessor; import net.pterodactylus.util.template.DataProvider; import net.pterodactylus.util.template.ReflectionAccessor; +import net.pterodactylus.util.template.TemplateFactory; /** - * TODO + * {@link Accessor} implementation that adds a couple of properties to + * {@link Reply}s. * * @author David ‘Bombe’ Roden */ public class ReplyAccessor extends ReflectionAccessor { + /** Parser for Freenet links. */ + private final FreenetLinkParser linkParser; + + /** The core. */ private final Core core; - public ReplyAccessor(Core core) { + /** + * Creates a new reply accessor. + * + * @param core + * The core + * @param templateFactory + * The template factory for the text parser + */ + public ReplyAccessor(Core core, TemplateFactory templateFactory) { this.core = core; + linkParser = new FreenetLinkParser(templateFactory); } /** @@ -47,6 +67,18 @@ public class ReplyAccessor extends ReflectionAccessor { } else if (member.equals("liked")) { Sone currentSone = (Sone) dataProvider.getData("currentSone"); return (currentSone != null) && (currentSone.isLikedReplyId(reply.getId())); + } else if (member.equals("new")) { + return core.isNewReply(reply.getId(), false); + } else if (member.equals("text")) { + String text = reply.getText(); + try { + synchronized (linkParser) { + linkParser.setPostingSone(reply.getSone()); + return linkParser.parse(new StringReader(text)); + } + } catch (IOException ioe1) { + /* ignore. */ + } } return super.get(dataProvider, object, member); }