X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fnet%2Fpterodactylus%2Fsone%2Ftext%2FFreenetLinkParser.java;h=85bda1a588fd9f28b37b576524e3e9e84babc0b6;hb=f3beba50c66473b89594743c7e790e49fd4d9ad9;hp=7749b0091e8c567f08e445f8d0853d19d81bc6af;hpb=967adc51224c9cfc5ce3fe36faa8ecd6e31959b3;p=Sone.git diff --git a/src/main/java/net/pterodactylus/sone/text/FreenetLinkParser.java b/src/main/java/net/pterodactylus/sone/text/FreenetLinkParser.java index 7749b00..85bda1a 100644 --- a/src/main/java/net/pterodactylus/sone/text/FreenetLinkParser.java +++ b/src/main/java/net/pterodactylus/sone/text/FreenetLinkParser.java @@ -42,6 +42,27 @@ public class FreenetLinkParser implements Parser { /** Pattern to detect whitespace. */ private static final Pattern whitespacePattern = Pattern.compile("[\\p{javaWhitespace}]"); + /** + * Enumeration for all recognized link types. + * + * @author David ‘Bombe’ Roden + */ + private enum LinkType { + + /** Link is a KSK. */ + KSK, + + /** Link is a CHK. */ + CHK, + + /** Link is an SSK. */ + SSK, + + /** Link is a USK. */ + USK + + } + /** The template factory. */ private final TemplateFactory templateFactory; @@ -79,17 +100,26 @@ public class FreenetLinkParser implements Parser { break; } int next = Integer.MAX_VALUE; + LinkType linkType = null; if ((nextKsk > -1) && (nextKsk < next)) { next = nextKsk; + linkType = LinkType.KSK; } if ((nextChk > -1) && (nextChk < next)) { next = nextChk; + linkType = LinkType.CHK; } if ((nextSsk > -1) && (nextSsk < next)) { next = nextSsk; + linkType = LinkType.SSK; } if ((nextUsk > -1) && (nextUsk < next)) { next = nextUsk; + linkType = LinkType.USK; + } + if ((next >= 8) && (line.substring(next - 8, next).equals("freenet:"))) { + next -= 8; + line = line.substring(0, next) + line.substring(next + 8); } Matcher matcher = whitespacePattern.matcher(line); int nextSpace = matcher.find(next) ? matcher.start() : line.length(); @@ -99,7 +129,7 @@ public class FreenetLinkParser implements Parser { String name = link; logger.log(Level.FINER, "Found link: " + link); logger.log(Level.FINEST, "Next: %d, CHK: %d, SSK: %d, USK: %d", new Object[] { next, nextChk, nextSsk, nextUsk }); - if (((next == nextChk) || (next == nextSsk) || (next == nextUsk)) && (link.length() > 98) && (link.charAt(47) == ',') && (link.charAt(91) == ',') && (link.charAt(99) == '/')) { + if (((linkType == LinkType.CHK) || (linkType == LinkType.SSK) || (linkType == LinkType.USK)) && (link.length() > 98) && (link.charAt(47) == ',') && (link.charAt(91) == ',') && (link.charAt(99) == '/')) { name = link.substring(0, 47) + "…" + link.substring(99); } parts.add(createLinkPart(link, name));