/* fm - File management class library Copyright (C) 2024 Ulrich Hilger This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with this program. If not, see . */ package de.uhilger.fm; import java.io.File; import java.io.IOException; import java.nio.file.DirectoryStream; import java.nio.file.Files; import java.nio.file.Path; /** * Verschieben und Kopieren von Dateien und Ordnern * * Handhabung von Bilddateien: * * Fuer jede Datei mit Endung jpg, jpeg und png werden alle Varianten wie zum Beispiel * dateiname.jpg, dateiname_kl.jpg, dateiname_gr.jpg, dateiname_gr_b64.jpg usw. * beruecksichtigt. * * @author Ulrich Hilger, 15. Janaur 2024 */ public class Mover extends FileHelper { public static final int OP_COPY = 1; public static final int OP_MOVE = 2; /** * Dateien und Ordner kopieren * * @param fromPath der Pfad zur Quelle der Kopieraktion * @param toPath der Pfad zum Ziel der Kopieraktion * @param fileNames die Liste der Dateien und Ordner, die kopiert werden sollen * @param base der Basispfad, gegen den fromPath und toPath aufgeloest werden sollen * @throws IOException wenn etwas schief geht */ public void copy(String fromPath, String toPath, String[] fileNames, String base) throws IOException { copyOrMoveFiles(fromPath, toPath, fileNames, OP_COPY, base); } /** * Dateien und Ordner verschieben * * @param fromPath der Pfad zur Quelle der Verschiebeaktion * @param toPath der Pfad zum Ziel der Verschiebeaktion * @param fileNames die Liste der Dateien und Ordner, die verschoben werden sollen * @param base der Basispfad, gegen den fromPath und toPath aufgeloest werden sollen * @throws IOException wenn etwas schief geht */ public void move(String fromPath, String toPath, String[] fileNames, String base) throws IOException { copyOrMoveFiles(fromPath, toPath, fileNames, OP_MOVE, base); } /** * Dateien und Ordner verschieben oder kopieren * * @param fromPath der Pfad zur Quelle der Verschiebe- oder Kopieraktion * @param toPath der Pfad zum Ziel der Verschiebe- oder Kopieraktion * @param fileNames die Liste der Dateien und Ordner, die verschoben oder kopiert werden sollen * @param operation die gewuenschte Dateioperation, OP_COPY oder OP_MOVE * @param base der Basispfad, gegen den fromPath und toPath aufgeloest werden sollen * @throws IOException wenn etwas schief geht */ private void copyOrMoveFiles(String fromPath, String toPath, String[] fileNames, int operation, String base) throws IOException { File srcDir = new File(base, fromPath); File targetDir = new File(base, toPath); for (String fileName : fileNames) { File srcFile = new File(srcDir, fileName); if (srcFile.isDirectory()) { FileOpsVisitor bearbeiter = new FileOpsVisitor(); bearbeiter.setTargetDir(targetDir.toPath()); bearbeiter.setOperation(operation); Files.walkFileTree(srcFile.toPath(), bearbeiter); } else { Path source = srcFile.toPath(); File destFile = targetDir.toPath().resolve(source.getFileName()).toFile(); if (destFile.exists()) { destFile = getNewFileName(destFile); } String fname = srcFile.getName().toLowerCase(); if (fname.endsWith(ImageFileFilter.JPEG) || fname.endsWith(ImageFileFilter.JPG) || fname.endsWith(ImageFileFilter.PNG)) { copyOrMoveImgFilesToDirectory(srcFile, srcDir, targetDir/*, false*/, operation); } else { if (operation == OP_MOVE) { Files.move(source, destFile.toPath()); } else { Files.copy(source, destFile.toPath()); } } } } } /** * Eine Bilddatei mit allen Varianten verschieben oder kopieren * * Fuer jede Datei mit Endung jpg, jpeg und png werden alle Varianten wie zum Beispiel * dateiname.jpg, dateiname_kl.jpg, dateiname_gr.jpg, dateiname_gr_b64.jpg usw. * beruecksichtigt, also dateiname*.jpg. * * @param srcFile die Bilddatei, deren Varianten beruecksichtigt werden sollen * @param srcDir der Herkunftsort * @param targetDir der Zielort * @throws IOException wenn etwas schief geht */ private void copyOrMoveImgFilesToDirectory(File srcFile, File srcDir, File targetDir, int operation) throws IOException { String fnameext = srcFile.getName(); int dotpos = fnameext.lastIndexOf("."); String fname = fnameext.substring(0, dotpos); String ext = fnameext.substring(dotpos); Path targetPath = targetDir.toPath(); DirectoryStream stream = Files.newDirectoryStream(srcDir.toPath(), fname + "*" + ext); for (Path path : stream) { if(operation == OP_COPY) { Files.copy(path, targetPath.resolve(path.getFileName())); } else { Files.move(path, targetPath.resolve(path.getFileName())); } } stream.close(); } }