From 96d8cfc0368d09ee25b846d4aa47f1ff0d9e8ae1 Mon Sep 17 00:00:00 2001
From: ulrich <undisclosed>
Date: Tue, 03 Apr 2018 16:39:04 +0000
Subject: [PATCH] collectFiles nach WbxUtils verschoben

---
 src/de/uhilger/wbx/WbxUtils.java        |   95 +++++++++++++++++++++++
 src/de/uhilger/wbx/web/FeedServlet.java |   89 ---------------------
 2 files changed, 97 insertions(+), 87 deletions(-)

diff --git a/src/de/uhilger/wbx/WbxUtils.java b/src/de/uhilger/wbx/WbxUtils.java
index d65a71c..9705fce 100644
--- a/src/de/uhilger/wbx/WbxUtils.java
+++ b/src/de/uhilger/wbx/WbxUtils.java
@@ -18,6 +18,12 @@
 
 package de.uhilger.wbx;
 
+import java.io.File;
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.Comparator;
+import java.util.Iterator;
+import java.util.List;
 import java.util.logging.Level;
 import java.util.logging.Logger;
 import javax.naming.Context;
@@ -36,6 +42,95 @@
   public static final String NOT_FOUND = " nicht gefunden";
   public static final String NO_STRING = " ist kein String";  
   public static final String EMPTY_STRING = "";
+  
+  public static final String WBX_PUB_DIR_NAME = "wbxPubDirName";
+  public static final String WBX_DEFAULT_PUB_DIR_NAME = "/www";
+  
+  /**
+   * Diese Methode funktioniert nur, wenn entweder ein Ordner uebergeben 
+   * wird, der keine Unterordner enthaelt wie zum Beispiel der Ordner 'neu' 
+   * der Bildersammlung oder ein Ordner, dessen Unterordner 
+   * nach dem Schema Jahr, Monat benannt sind wie bei einem Journal, das 
+   * die Beitraege wie folgt enthaelt:
+   * Journal-Ordner
+   *   2018
+   *     12
+   *     11
+   *     10
+   *     usw.
+   *   2017
+   *     12
+   *     11
+   *     10
+   *     usw.
+   * 
+   * @param out
+   * @param dir
+   * @param tiefe
+   * @param dateizaehler 
+   */
+  public void collectFiles(File dir, int tiefe, List beitraege, int maxTiefe, int maxBeitraege) {
+    List dirs = new ArrayList();
+    List beitraegeHier = new ArrayList();
+    File[] files = dir.listFiles();
+    for(int i = 0; i < files.length; i++) {
+      if(files[i].isDirectory()) {
+        if(tiefe < maxTiefe) {
+          dirs.add(files[i]);
+        }
+      } else {
+        beitraegeHier.add(files[i]);
+      }
+    }
+      
+    if(dirs.size() > 0) {
+      // hier zuvor die Verzeichnissse absteigend nach Name sortieren      
+      Collections.sort(dirs, new Comparator<File>() {
+        @Override
+        public int compare(File o1, File o2) {
+          return o2.getName().compareTo(o1.getName());
+        }
+      });
+      
+      Iterator i = dirs.iterator();
+      while(i.hasNext() && beitraege.size() < maxBeitraege) {
+        collectFiles((File) i.next(), tiefe+1, beitraege, maxTiefe, maxBeitraege);
+      }
+    } 
+    if(beitraegeHier.size() > 0) {
+      // hier zuvor die Liste der Beitraege dieses Ordners nach lastModified absteigend sortieren
+      // dann die neuesten in beitraege aufnehmen, bis die maximale Zahl gesuchter 
+      // neuer Beitraege erreicht ist.
+      
+      Collections.sort(beitraegeHier, new Comparator<File>() {
+        @Override
+        public int compare(File o1, File o2) {
+          int ergebnis;
+          if(o1.lastModified() > o2.lastModified()) {
+            ergebnis = -1;
+          } else if(o2.lastModified() > o1.lastModified()) {
+            ergebnis = 1;
+          } else {
+            ergebnis = 0;
+          }
+          return ergebnis;
+        }
+      });
+      
+      Iterator i = beitraegeHier.iterator();
+      while(i.hasNext() && beitraege.size() < maxBeitraege) {
+        File bf = (File) i.next();
+        String nm = bf.getName().toLowerCase();
+        if(nm.endsWith(".htmi") || nm.endsWith(".html") || nm.endsWith(".htm") || 
+           nm.endsWith(".jpg") || nm.endsWith(".jpeg") || nm.endsWith(".png") || 
+           nm.endsWith(".txt")) {
+          beitraege.add(bf);
+        }
+      }
+      
+    }
+  }
+  
 
   public int getJNDIInt(String paramName, int defaultVal) {
     String jndiStr = getJNDIParameter(paramName, Integer.toString(defaultVal));
diff --git a/src/de/uhilger/wbx/web/FeedServlet.java b/src/de/uhilger/wbx/web/FeedServlet.java
index 16a3ef7..d74d7d6 100644
--- a/src/de/uhilger/wbx/web/FeedServlet.java
+++ b/src/de/uhilger/wbx/web/FeedServlet.java
@@ -107,7 +107,7 @@
       List beitraege = new ArrayList();
       int maxBeitraege = wu.getJNDIInt(WBX_MAX_FEED_ENTRIES, WBX_DEF_MAX_FEED_ENTRIES);
       int maxTiefe = wu.getJNDIInt(WBX_MAX_FEED_DEPTH, WBX_DEF_MAX_FEED_DEPTH);
-      collectFiles(dir, 0, beitraege, maxTiefe, maxBeitraege);
+      wu.collectFiles(dir, 0, beitraege, maxTiefe, maxBeitraege);
       Iterator i = beitraege.iterator();
       while (i.hasNext()) {
         File f = (File) i.next();
@@ -120,92 +120,7 @@
       logger.fine(dir.getAbsolutePath() + " ist kein Ordner.");
     }
   }
-  
-  /**
-   * Diese Methode funktioniert nur, wenn entweder ein Ordner uebergeben 
-   * wird, der keine Unterordner enthaelt wie zum Beispiel der Ordner 'neu' 
-   * der Bildersammlung oder ein Ordner, dessen Unterordner 
-   * nach dem Schema Jahr, Monat benannt sind wie bei einem Journal, das 
-   * die Beitraege wie folgt enthaelt:
-   * Journal-Ordner
-   *   2018
-   *     12
-   *     11
-   *     10
-   *     usw.
-   *   2017
-   *     12
-   *     11
-   *     10
-   *     usw.
-   * 
-   * @param out
-   * @param dir
-   * @param tiefe
-   * @param dateizaehler 
-   */
-  private void collectFiles(File dir, int tiefe, List beitraege, int maxTiefe, int maxBeitraege) {
-    List dirs = new ArrayList();
-    List beitraegeHier = new ArrayList();
-    File[] files = dir.listFiles();
-    for(int i = 0; i < files.length; i++) {
-      if(files[i].isDirectory()) {
-        if(tiefe < maxTiefe) {
-          dirs.add(files[i]);
-        }
-      } else {
-        beitraegeHier.add(files[i]);
-      }
-    }
-      
-    if(dirs.size() > 0) {
-      // hier zuvor die Verzeichnissse absteigend nach Name sortieren      
-      Collections.sort(dirs, new Comparator<File>() {
-        @Override
-        public int compare(File o1, File o2) {
-          return o2.getName().compareTo(o1.getName());
-        }
-      });
-      
-      Iterator i = dirs.iterator();
-      while(i.hasNext() && beitraege.size() < maxBeitraege) {
-        collectFiles((File) i.next(), tiefe+1, beitraege, maxTiefe, maxBeitraege);
-      }
-    } 
-    if(beitraegeHier.size() > 0) {
-      // hier zuvor die Liste der Beitraege dieses Ordners nach lastModified absteigend sortieren
-      // dann die neuesten in beitraege aufnehmen, bis die maximale Zahl gesuchter 
-      // neuer Beitraege erreicht ist.
-      
-      Collections.sort(beitraegeHier, new Comparator<File>() {
-        @Override
-        public int compare(File o1, File o2) {
-          int ergebnis;
-          if(o1.lastModified() > o2.lastModified()) {
-            ergebnis = -1;
-          } else if(o2.lastModified() > o1.lastModified()) {
-            ergebnis = 1;
-          } else {
-            ergebnis = 0;
-          }
-          return ergebnis;
-        }
-      });
-      
-      Iterator i = beitraegeHier.iterator();
-      while(i.hasNext() && beitraege.size() < maxBeitraege) {
-        File bf = (File) i.next();
-        String nm = bf.getName().toLowerCase();
-        if(nm.endsWith(".htmi") || nm.endsWith(".html") || nm.endsWith(".htm") || 
-           nm.endsWith(".jpg") || nm.endsWith(".jpeg") || nm.endsWith(".png") || 
-           nm.endsWith(".txt")) {
-          beitraege.add(bf);
-        }
-      }
-      
-    }
-  }
-  
+    
   public void writeFeed(String feedTitel, String beschr, ServletOutputStream s, 
           List beitraege, String basis, String pfad, String contextPath, WbxUtils wu) {
     

--
Gitblit v1.9.3