From 5f70da71c8e71990715dcb4be5cc433284abdede Mon Sep 17 00:00:00 2001
From: ulrich
Date: Mon, 05 Apr 2021 12:35:50 +0000
Subject: [PATCH] Lesen und neu fuer Ablageort fertig

---
 src/de/uhilger/mediaz/store/FileStorage.java |   47 +++++++++++++++++++++++++++--------------------
 1 files changed, 27 insertions(+), 20 deletions(-)

diff --git a/src/de/uhilger/mediaz/store/FileStorage.java b/src/de/uhilger/mediaz/store/FileStorage.java
index 0282ed7..3819699 100644
--- a/src/de/uhilger/mediaz/store/FileStorage.java
+++ b/src/de/uhilger/mediaz/store/FileStorage.java
@@ -49,7 +49,7 @@
   public FileStorage(String base) {
     this.fileBase = base;
     
-    //TypeToken<List<String>> list = new TypeToken<List<String>>() {};
+    // Beispiel: TypeToken<List<String>> list = new TypeToken<List<String>>() {};
     TypeToken<Ablageort> ttAblageort = new TypeToken<Ablageort>() {};
     types = new HashMap();
     types.put(Ablageort.class.getSimpleName(), ttAblageort);
@@ -69,7 +69,6 @@
    * @param o 
    */
   public File writeToFile(Entity o) throws IOException {
-    Gson gson = new Gson();
     String className = o.getClass().getSimpleName();
     logger.finer(className); 
     File dir = new File(fileBase, className);
@@ -79,34 +78,29 @@
       file.delete();
     }
     FileWriter fw = new FileWriter(file);
+    Gson gson = new Gson();
     fw.write(gson.toJson(o));
     fw.flush();
     fw.close();
     return file;
   }
   
-  public Entity readFromFile(File file) throws ClassNotFoundException, FileNotFoundException, IOException {
-    String type = typeNameFromPath(file);
+  public String readFromFile(File file) throws IOException {
     StringBuilder sb = new StringBuilder();
-    FileReader in = new FileReader(file);
-    BufferedReader r = new BufferedReader(in);
+    BufferedReader r = new BufferedReader(new FileReader(file));
     String line = r.readLine();
     while(line != null) {
       sb.append(line);
       line = r.readLine();
     }
     r.close();
-    in.close();
-    String json = sb.toString();
+    return sb.toString();
+  }
+  
+  public Entity entityFromFile(File file) throws ClassNotFoundException, FileNotFoundException, IOException {
+    String json = readFromFile(file);
     Gson gson = new Gson();
-    switch(type) {
-      case ST_ABLAGEORT:
-        return gson.fromJson(json, Ablageort.class);
-      default:
-        Ablageort ablage = new Ablageort();
-        ablage.setName("Test");
-        return ablage;
-    }
+    return gson.fromJson(json, typeFromName(typeNameFromPath(file)).getType());
   }
   
   private String typeNameFromPath(File file) {
@@ -127,11 +121,8 @@
 
   @Override
   public Entity read(String typ, String name) {
-    File base = new File(fileBase);
-    File dir = new File(base, typ);
-    File file = new File(dir, name);
     try {
-      return readFromFile(file);
+      return entityFromFile(getFile(typ, name));
     } catch (ClassNotFoundException | IOException ex) {
       logger.log(Level.SEVERE, null, ex);
       return null;
@@ -155,6 +146,22 @@
     return types.get(name);
   }
 
+  @Override
+  public String readJson(String typ, String name) {
+    try {
+      return readFromFile(getFile(typ, name));
+    } catch (IOException ex) {
+      logger.log(Level.SEVERE, null, ex);
+      return null;
+    }
+  }
+  
+  private File getFile(String typ, String name) {
+    File base = new File(fileBase);
+    File dir = new File(base, typ);
+    return new File(dir, name);    
+  }
+
   
   
 }

--
Gitblit v1.9.3