avoid duplicate article instances
authorJean-Philippe Orsini <orsinije@fr.ibm.com>
Mon, 16 Oct 2017 22:46:24 +0000 (00:46 +0200)
committerJean-Philippe Orsini <orsinije@fr.ibm.com>
Mon, 16 Oct 2017 22:46:24 +0000 (00:46 +0200)
war/pom.xml
war/src/main/java/pnews/servlet/ArticleFactory.java [new file with mode: 0644]
war/src/main/java/pnews/servlet/ArticleProvider.java
war/src/main/java/pnews/servlet/ArticleStore.java [new file with mode: 0644]

index 3b1f825..e68b9c6 100644 (file)
@@ -8,8 +8,8 @@
 
         <properties>
                 <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
-                <maven.compiler.source>1.7</maven.compiler.source>
-                <maven.compiler.target>1.7</maven.compiler.target>
+                <maven.compiler.source>1.8</maven.compiler.source>
+                <maven.compiler.target>1.8</maven.compiler.target>
         </properties>
 
         <dependencies>
diff --git a/war/src/main/java/pnews/servlet/ArticleFactory.java b/war/src/main/java/pnews/servlet/ArticleFactory.java
new file mode 100644 (file)
index 0000000..b89bebb
--- /dev/null
@@ -0,0 +1,8 @@
+package pnews.servlet;
+
+import pnews.Article;
+
+@FunctionalInterface
+public interface ArticleFactory {
+        Article create();
+}
index c6cad50..d3e4f3d 100644 (file)
@@ -120,10 +120,10 @@ public class ArticleProvider {
                 return false;
         }
         
-        private Article toArticle(String link, Category cat, SyndEntry entry, SyndFeed feed) {
+        private static Article toArticle(String link, SyndEntry entry, SyndFeed feed) {
                 String desc, title, thumbnail;
                 Date date;
-
+                
                 thumbnail = null;
                 for (SyndEnclosure e: entry.getEnclosures()) {
                         if (e.getType().startsWith("image/"))
@@ -151,9 +151,9 @@ public class ArticleProvider {
                                      
                 return new Article(link, title, desc, thumbnail, date, title);
         }
-                            
+        
         private void addArticles(Category cat, SyndFeed feed) {
-                String link, feedTitle;
+                String feedTitle;
                 List<Article> articles;
                 Article a;
                 
@@ -162,14 +162,14 @@ public class ArticleProvider {
                 LOG.info("addArticles " + cat.getId() + " " + feedTitle + " number of articles: " + feed.getEntries().size());
                 
                 for (SyndEntry entry: feed.getEntries()) {
-                        link = entry.getLink().trim();
+                        String link = entry.getLink().trim();
                         articles = getArticlesForUpdate(cat);
                         if (exists(link, articles)) {
                                 LOG.fine("addArticles " + link + " is already present");
                                 continue ;
                         }
                         
-                        a = toArticle(link, cat, entry, feed);                        
+                        a = ArticleStore.singleton.getArticle(link, ()->toArticle(link, entry, feed));
                         
                         synchronized (articles) {
                                 articles.add(a);
@@ -185,14 +185,13 @@ public class ArticleProvider {
                                                         return -1;
                                                 return o2.publicationDate.compareTo(o1.publicationDate);
                                         }
-
                                 });
                         }
                 }          
                 
                 LOG.info("addArticles done " + cat.getId());
         }
-        
+             
         private void retrieveArticles(Category cat) throws IllegalArgumentException, MalformedURLException, FeedException, IOException {
                 String[] feeds;
                 
diff --git a/war/src/main/java/pnews/servlet/ArticleStore.java b/war/src/main/java/pnews/servlet/ArticleStore.java
new file mode 100644 (file)
index 0000000..0b40cc3
--- /dev/null
@@ -0,0 +1,36 @@
+package pnews.servlet;
+
+import java.lang.ref.WeakReference;
+import java.util.HashMap;
+
+import pnews.Article;
+
+public class ArticleStore {
+        public final static ArticleStore singleton = new ArticleStore();
+        private final HashMap<String, WeakReference<Article>> articles = new HashMap<>();
+        
+        public Article get(String link) {
+                WeakReference<Article> ref;
+                
+                synchronized (articles) {
+                        ref = articles.get(link);
+                        if (ref == null)
+                                return null;
+                        return ref.get();
+                }
+        }
+        
+        public Article getArticle(String link, ArticleFactory factory) {
+                Article result;
+                
+                synchronized (articles) {
+                        result = get(link);
+                        if (result == null) {
+                                result = factory.create();
+                                articles.put(link, new WeakReference<>(result));
+                        }
+                        
+                        return result;
+                }
+        }
+}