Fix some warnings
[nikiroo-utils.git] / src / be / nikiroo / fanfix / output / InfoCover.java
index 2280e2dc4487bbdb0adf84f139a1a135c0c35772..9227d3e440d9f9371506c160813b9827c029c851 100644 (file)
@@ -1,23 +1,26 @@
 package be.nikiroo.fanfix.output;
 
+import java.io.BufferedWriter;
 import java.io.File;
-import java.io.FileWriter;
+import java.io.FileOutputStream;
 import java.io.IOException;
-
-import javax.imageio.ImageIO;
+import java.io.OutputStreamWriter;
 
 import be.nikiroo.fanfix.Instance;
 import be.nikiroo.fanfix.bundles.Config;
 import be.nikiroo.fanfix.data.MetaData;
 
-class InfoCover {
+public class InfoCover {
        public static void writeInfo(File targetDir, String targetName,
                        MetaData meta) throws IOException {
                File info = new File(targetDir, targetName + ".info");
-               FileWriter infoWriter = new FileWriter(info);
 
-               if (meta != null) {
-                       try {
+               BufferedWriter infoWriter = null;
+               try {
+                       infoWriter = new BufferedWriter(new OutputStreamWriter(
+                                       new FileOutputStream(info), "UTF-8"));
+
+                       if (meta != null) {
                                String tags = "";
                                if (meta.getTags() != null) {
                                        for (String tag : meta.getTags()) {
@@ -28,22 +31,20 @@ class InfoCover {
                                        }
                                }
 
-                               String lang = meta.getLang();
-                               if (lang != null) {
-                                       lang = lang.toLowerCase();
-                               }
-
                                writeMeta(infoWriter, "TITLE", meta.getTitle());
                                writeMeta(infoWriter, "AUTHOR", meta.getAuthor());
                                writeMeta(infoWriter, "DATE", meta.getDate());
                                writeMeta(infoWriter, "SUBJECT", meta.getSubject());
                                writeMeta(infoWriter, "SOURCE", meta.getSource());
+                               writeMeta(infoWriter, "URL", meta.getUrl());
                                writeMeta(infoWriter, "TAGS", tags);
                                writeMeta(infoWriter, "UUID", meta.getUuid());
                                writeMeta(infoWriter, "LUID", meta.getLuid());
-                               writeMeta(infoWriter, "LANG", lang);
+                               writeMeta(infoWriter, "LANG", meta.getLang() == null ? ""
+                                               : meta.getLang().toLowerCase());
                                writeMeta(infoWriter, "IMAGES_DOCUMENT",
                                                meta.isImageDocument() ? "true" : "false");
+                               writeMeta(infoWriter, "TYPE", meta.getType());
                                if (meta.getCover() != null) {
                                        String format = Instance.getConfig()
                                                        .getString(Config.IMAGE_FORMAT_COVER).toLowerCase();
@@ -53,7 +54,14 @@ class InfoCover {
                                }
                                writeMeta(infoWriter, "EPUBCREATOR", BasicOutput.EPUB_CREATOR);
                                writeMeta(infoWriter, "PUBLISHER", meta.getPublisher());
-                       } finally {
+                               writeMeta(infoWriter, "WORDCOUNT",
+                                               Long.toString(meta.getWords()));
+                               writeMeta(infoWriter, "CREATION_DATE", meta.getCreationDate());
+                               writeMeta(infoWriter, "FAKE_COVER",
+                                               Boolean.toString(meta.isFakeCover()));
+                       }
+               } finally {
+                       if (infoWriter != null) {
                                infoWriter.close();
                        }
                }
@@ -63,20 +71,18 @@ class InfoCover {
                        MetaData meta) {
                if (meta != null && meta.getCover() != null) {
                        try {
-                               String format = Instance.getConfig()
-                                               .getString(Config.IMAGE_FORMAT_COVER).toLowerCase();
-                               ImageIO.write(meta.getCover(), format, new File(targetDir,
-                                               targetName + "." + format));
+                               Instance.getCache().saveAsImage(meta.getCover(),
+                                               new File(targetDir, targetName), true);
                        } catch (IOException e) {
                                // Allow to continue without cover
-                               Instance.syserr(new IOException(
-                                               "Failed to save the cover image", e));
+                               Instance.getTraceHandler().error(
+                                               new IOException("Failed to save the cover image", e));
                        }
                }
        }
 
-       private static void writeMeta(FileWriter writer, String key, String value)
-                       throws IOException {
+       private static void writeMeta(BufferedWriter writer, String key,
+                       String value) throws IOException {
                if (value == null) {
                        value = "";
                }