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