Klassenbiliothek fuer Dateiverwaltung
ulrich
16 hours ago 243c03070748d5008e689a3cc7212c1f87917464
commit | author | age
e369b9 1 /*
c45b52 2   fm - File management class library
e369b9 3   Copyright (C) 2024  Ulrich Hilger
U 4
5   This program is free software: you can redistribute it and/or modify
6   it under the terms of the GNU Affero General Public License as
7   published by the Free Software Foundation, either version 3 of the
8   License, or (at your option) any later version.
9
10   This program is distributed in the hope that it will be useful,
11   but WITHOUT ANY WARRANTY; without even the implied warranty of
12   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13   GNU Affero General Public License for more details.
14
15   You should have received a copy of the GNU Affero General Public License
16   along with this program.  If not, see <https://www.gnu.org/licenses/>.
17  */
18 package de.uhilger.fm;
19
20 import java.io.File;
21 import java.io.FileOutputStream;
22 import java.io.IOException;
23 import java.io.OutputStream;
24 import java.net.URLDecoder;
25 import java.util.logging.Level;
26 import java.util.logging.Logger;
27
28 /**
29  * Dateien und Ordner anlegen. 
30  * Ggf. deren Inhalt schreiben.
31  * 
32  * @author Ulrich Hilger
33  * @version 0.1, 07.11.2024
34  */
35 public class Writer {
36
243c03 37   /**
U 38    * Einen Ordner anlegen, wenn er noch nicht exisitert
39    * 
40    * @param file der Ordner, der angelegt werden soll
41    * @return 0, wenn der Ordner angelegt wurde, -1 wenn nicht
42    */
e369b9 43   public int newFolder(File file) {
U 44     if (!file.exists()) {
45       file.mkdir();
46       return 0;
47     } else {
48       return -1;
49     }
50   }
51   
52   /**
53    * Datei speichern. Eine existierende Datei gleichen Namens wird 
54    * zuvor geloescht (= Ueberschreiben). 
55    * 
56    * Wenn Aenderungen in eine schon existierende Datei gespeichert werden 
57    * sollen, ist es noetig, die existierende Datei mit dem neuen Inhalt zu 
58    * ueberschreiben, so, wie es diese Methode ausfuehrt.
59    * 
60    * Soll statdessen eine Datei neu erstellt werden und wird dabei also unterstellt, dass 
61    * unter ihrem Namen am Ablageort noch keine Datei gleichen Namens existiert, muss 
62    * vor der Verwendung dieser Methode sichergestellt werden, dass es so ist.
63    * 
64    * @param file
65    * @param content
66    * @return 0, wenn erfolgreich, sonst -1
67    */
68   public int speichern(File file, String content) {
69     try {
70       if (file.exists()) {
71         /*
72         muss delete() sein?
73         pruefen: ueberschreibt der FileWriter den alten Inhalt oder
74         entsteht eine unerwuenschte Mischung aus altem und neuem
75         Inhalt?
76         */
77         file.delete();
78       } else {
79         file.getParentFile().mkdirs();
80       }
81       String decoded = URLDecoder.decode(content, "UTF-8");
82       byte[] bytes = decoded.getBytes();
83       file.createNewFile();
84       try (OutputStream os = new FileOutputStream(file)) {
85         os.write(bytes);
86         os.flush();
87       }
88       return 0;
89     } catch (IOException ex) {
90       Logger.getLogger(Writer.class.getName()).log(Level.SEVERE, null, ex);
91       return -1;
92     }      
93   }  
94 }