removed some system.out logging
[mir.git] / source / mircoders / localizer / basic / MirBasicWriterEngine.java
1 /*
2  * Copyright (C) 2001, 2002 The Mir-coders group
3  *
4  * This file is part of Mir.
5  *
6  * Mir is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * Mir is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with Mir; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19  *
20  * In addition, as a special exception, The Mir-coders gives permission to link
21  * the code of this program with  any library licensed under the Apache Software License,
22  * The Sun (tm) Java Advanced Imaging library (JAI), The Sun JIMI library
23  * (or with modified versions of the above that use the same license as the above),
24  * and distribute linked combinations including the two.  You must obey the
25  * GNU General Public License in all respects for all of the code used other than
26  * the above mentioned libraries.  If you modify this file, you may extend this
27  * exception to your version of the file, but you are not obligated to do so.
28  * If you do not wish to do so, delete this exception statement from your version.
29  */
30 package mircoders.localizer.basic;
31
32 import mir.config.MirPropertiesConfiguration;
33 import mir.generator.WriterEngine;
34 import mir.log.LoggerWrapper;
35 import mir.util.FileRoutines;
36 import mircoders.localizer.MirLocalizerFailure;
37
38 import java.io.BufferedWriter;
39 import java.io.File;
40 import java.io.FileOutputStream;
41 import java.io.IOException;
42 import java.io.OutputStreamWriter;
43 import java.io.PrintWriter;
44 import java.io.Writer;
45
46 public class MirBasicWriterEngine implements WriterEngine {
47   private String defaultEncoding;
48
49   protected static LoggerWrapper logger = new LoggerWrapper("Localizer.WriterEngine");
50   protected MirPropertiesConfiguration configuration = MirPropertiesConfiguration.instance();
51
52   /**
53    * Directory to store temp files into
54    */
55   private File tempDirectory;
56
57   public MirBasicWriterEngine(String aDefaultEncoding) {
58     defaultEncoding = aDefaultEncoding;
59     tempDirectory = configuration.getFile("TempDir");
60   }
61
62   /**
63    * {@inheritDoc}
64    */
65   public Object openWriter(String anIdentifier, String anEncoding) throws MirLocalizerFailure {
66     String encoding;
67
68     if (anEncoding != null && !anEncoding.equals("")) {
69       encoding = anEncoding;
70     }
71     else {
72       encoding = defaultEncoding;
73     }
74
75     File destinationFile = new File(anIdentifier);
76
77     File destinationDirectory  = destinationFile.getParentFile();
78
79     if (destinationDirectory != null && !destinationDirectory.exists()) {
80       destinationDirectory.mkdirs();
81     }
82
83     try {
84       return new PrintWriter(
85           new TempWriter(destinationFile, encoding)
86       );
87     }
88     catch (IOException t) {
89       throw new MirLocalizerFailure("Failure while opening a writer", t);
90     }
91   }
92
93   public void closeWriter(Object aWriter) {
94     ((PrintWriter) aWriter).close();
95   }
96
97   private class TempWriter extends Writer {
98     TempWriter(File aDestination, String anEncoding) throws IOException {
99       destinationFile = aDestination;
100       slaveFile = File.createTempFile("Mir", ".generated", tempDirectory);
101       slaveFile.deleteOnExit();
102       slaveWriter = new BufferedWriter(
103           new OutputStreamWriter(
104             new FileOutputStream(slaveFile), anEncoding
105       ), 8192);
106     }
107
108     public void close() throws IOException {
109       slaveWriter.close();
110
111       try {
112         FileRoutines.move(slaveFile, destinationFile);
113
114         slaveFile.delete();
115       }
116       catch (Throwable e) {
117         System.out.println("error: " + e.toString());
118
119         throw new IOException(e.getMessage());
120       }
121     }
122
123     public void flush() throws IOException {
124       slaveWriter.flush();
125     }
126
127     public void write(char cbuf[], int off, int len) throws IOException {
128       slaveWriter.write(cbuf, off, len);
129     }
130
131     private Writer slaveWriter;
132     private File slaveFile;
133     private File destinationFile;
134   }
135
136 }