Remove unnecessary casts
[Sone.git] / src / main / java / net / pterodactylus / sone / template / ParserFilter.java
index db41830..53862e3 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Sone - ParserFilter.java - Copyright © 2011–2013 David Roden
+ * Sone - ParserFilter.java - Copyright © 2011–2015 David Roden
  *
  * This program is free software: you can redistribute it and/or modify
  * it under the terms of the GNU General Public License as published by
@@ -17,6 +17,9 @@
 
 package net.pterodactylus.sone.template;
 
+import static java.lang.String.valueOf;
+import static net.pterodactylus.sone.utils.NumberParsers.parseInt;
+
 import java.io.IOException;
 import java.io.StringReader;
 import java.io.StringWriter;
@@ -44,9 +47,6 @@ import net.pterodactylus.util.template.TemplateContext;
 import net.pterodactylus.util.template.TemplateContextFactory;
 import net.pterodactylus.util.template.TemplateParser;
 
-import com.google.common.base.Optional;
-import com.google.common.primitives.Ints;
-
 /**
  * Filter that filters a given text through a {@link SoneTextParser}.
  *
@@ -91,24 +91,24 @@ public class ParserFilter implements Filter {
         */
        @Override
        public Object format(TemplateContext templateContext, Object data, Map<String, Object> parameters) {
-               String text = String.valueOf(data);
-               int length = Optional.fromNullable(Ints.tryParse(String.valueOf(parameters.get("length")))).or(-1);
-               int cutOffLength = Optional.fromNullable(Ints.tryParse(String.valueOf(parameters.get("cut-off-length")))).or(length);
+               String text = valueOf(data);
+               int length = parseInt(valueOf(parameters.get("length")), -1);
+               int cutOffLength = parseInt(valueOf(parameters.get("cut-off-length")), length);
                Object sone = parameters.get("sone");
                if (sone instanceof String) {
-                       sone = core.getSone((String) sone, false);
+                       sone = core.getSone((String) sone).orNull();
                }
                FreenetRequest request = (FreenetRequest) templateContext.get("request");
                SoneTextParserContext context = new SoneTextParserContext(request, (Sone) sone);
                StringWriter parsedTextWriter = new StringWriter();
                try {
-                       Iterable<Part> parts = soneTextParser.parse(context, new StringReader(text));
+                       Iterable<Part> parts = soneTextParser.parse(context, text);
                        if (length > -1) {
                                int allPartsLength = 0;
                                List<Part> shortenedParts = new ArrayList<Part>();
                                for (Part part : parts) {
                                        if (part instanceof PlainTextPart) {
-                                               String longText = ((PlainTextPart) part).getText();
+                                               String longText = part.getText();
                                                if (allPartsLength < cutOffLength) {
                                                        if ((allPartsLength + longText.length()) > cutOffLength) {
                                                                shortenedParts.add(new PlainTextPart(longText.substring(0, cutOffLength - allPartsLength) + "…"));
@@ -121,7 +121,7 @@ public class ParserFilter implements Filter {
                                                if (allPartsLength < cutOffLength) {
                                                        shortenedParts.add(part);
                                                }
-                                               allPartsLength += ((LinkPart) part).getText().length();
+                                               allPartsLength += part.getText().length();
                                        } else {
                                                if (allPartsLength < cutOffLength) {
                                                        shortenedParts.add(part);
@@ -253,7 +253,7 @@ public class ParserFilter implements Filter {
                SoneTextParser parser = new SoneTextParser(core, core);
                SoneTextParserContext parserContext = new SoneTextParserContext(null, postPart.getPost().getSone());
                try {
-                       Iterable<Part> parts = parser.parse(parserContext, new StringReader(postPart.getPost().getText()));
+                       Iterable<Part> parts = parser.parse(parserContext, postPart.getPost().getText());
                        StringBuilder excerpt = new StringBuilder();
                        for (Part part : parts) {
                                excerpt.append(part.getText());