55b31c44b8979943e780c4abb286c697b936511b
[mir.git] / source / mir / log / LoggerToWriterAdapter.java
1 /*
2  * Copyright (C) 2005 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  * You must obey the GNU General Public License in all respects for all of the code used
23  * other than the above mentioned libraries.  If you modify this file, you may extend this
24  * exception to your version of the file, but you are not obligated to do so.
25  * If you do not wish to do so, delete this exception statement from your version.
26  */
27 package mir.log;
28
29 import java.io.Writer;
30
31 public class LoggerToWriterAdapter extends Writer {
32   private LoggerWrapper logger;
33   private int messageType;
34   private StringBuffer lineBuffer;
35   private String lineSeparator;
36
37   public LoggerToWriterAdapter(LoggerWrapper aLogger, int aMessageType) {
38     lineBuffer = new StringBuffer();
39     logger = aLogger;
40     messageType = aMessageType;
41     lineSeparator = System.getProperty("line.separator");
42   }
43
44   public LoggerToWriterAdapter(Logger aLogger, int aMessageType) {
45     this(new LoggerWrapper(aLogger), aMessageType);
46   }
47
48   public void close() {
49     flush();
50   }
51
52   public void flush() {
53     if (lineBuffer.length()>0) {
54       logger.message(messageType, lineBuffer.toString());
55       lineBuffer.delete(0, lineBuffer.length());
56     }
57   }
58
59   protected void checkBuffer() {
60     int from = 0;
61     int until = lineBuffer.toString().indexOf(lineSeparator, from);
62
63     while (until>-1) {
64       String line = lineBuffer.substring(from, until);
65       logger.message(messageType, line);
66       from = until + lineSeparator.length();
67       until = lineBuffer.toString().indexOf(lineSeparator, from);
68     }
69
70     lineBuffer.delete(0, from);
71   }
72
73   public void write(char[] aBuffer, int anOffset, int aLength)  {
74     lineBuffer.append(aBuffer, anOffset, aLength);
75     checkBuffer();
76   }
77 }