Merge branch 'release-0.3.6.4' 0.3.6.4
authorDavid ‘Bombe’ Roden <bombe@pterodactylus.net>
Thu, 6 Jan 2011 13:42:06 +0000 (14:42 +0100)
committerDavid ‘Bombe’ Roden <bombe@pterodactylus.net>
Thu, 6 Jan 2011 13:42:06 +0000 (14:42 +0100)
pom.xml
src/main/java/net/pterodactylus/sone/main/SonePlugin.java
src/main/java/net/pterodactylus/sone/text/FreenetLinkParser.java

diff --git a/pom.xml b/pom.xml
index fa77daa..1ceef4f 100644 (file)
--- a/pom.xml
+++ b/pom.xml
@@ -2,7 +2,7 @@
        <modelVersion>4.0.0</modelVersion>
        <groupId>net.pterodactylus</groupId>
        <artifactId>sone</artifactId>
-       <version>0.3.6-3</version>
+       <version>0.3.6-4</version>
        <dependencies>
                <dependency>
                        <groupId>net.pterodactylus</groupId>
index 262d777..81c1472 100644 (file)
@@ -78,7 +78,7 @@ public class SonePlugin implements FredPlugin, FredPluginL10n, FredPluginBaseL10
        }
 
        /** The version. */
-       public static final Version VERSION = new Version(0, 3, 6, 3);
+       public static final Version VERSION = new Version(0, 3, 6, 4);
 
        /** The logger. */
        private static final Logger logger = Logging.getLogger(SonePlugin.class);
index 24eac3b..b50113d 100644 (file)
@@ -21,6 +21,7 @@ import java.io.BufferedReader;
 import java.io.IOException;
 import java.io.Reader;
 import java.io.StringReader;
+import java.net.MalformedURLException;
 import java.util.logging.Level;
 import java.util.logging.Logger;
 import java.util.regex.Matcher;
@@ -29,6 +30,7 @@ import java.util.regex.Pattern;
 import net.pterodactylus.sone.data.Sone;
 import net.pterodactylus.util.logging.Logging;
 import net.pterodactylus.util.template.TemplateFactory;
+import freenet.keys.FreenetURI;
 
 /**
  * {@link Parser} implementation that can recognize Freenet URIs.
@@ -176,7 +178,7 @@ public class FreenetLinkParser implements Parser {
                                                                        name = name.substring(name.lastIndexOf('/', name.lastIndexOf('/') - 1));
                                                                } else {
                                                                        /* shorten to 5 chars. */
-                                                                       name = name.substring(4, 9);
+                                                                       name = name.substring(4, Math.min(9, name.length()));
                                                                }
                                                        }
                                                }
@@ -185,9 +187,17 @@ public class FreenetLinkParser implements Parser {
                                                }
                                                boolean fromPostingSone = false;
                                                if ((linkType == LinkType.SSK) || (linkType == LinkType.USK)) {
-                                                       fromPostingSone = link.substring(4, 47).equals(postingSone.getId());
+                                                       try {
+                                                               new FreenetURI(link);
+                                                               fromPostingSone = link.substring(4, 47).equals(postingSone.getId());
+                                                               parts.add(fromPostingSone ? createTrustedFreenetLinkPart(link, name) : createFreenetLinkPart(link, name));
+                                                       } catch (MalformedURLException mue1) {
+                                                               /* it’s not a valid link. */
+                                                               parts.add(createPlainTextPart(link));
+                                                       }
+                                               } else {
+                                                       parts.add(fromPostingSone ? createTrustedFreenetLinkPart(link, name) : createFreenetLinkPart(link, name));
                                                }
-                                               parts.add(fromPostingSone ? createTrustedFreenetLinkPart(link, name) : createFreenetLinkPart(link, name));
                                        } else if ((linkType == LinkType.HTTP) || (linkType == LinkType.HTTPS)) {
                                                name = link.substring(linkType == LinkType.HTTP ? 7 : 8);
                                                int firstSlash = name.indexOf('/');