1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package org.apache.logging.log4j.core.appender;
18
19 import java.io.IOException;
20 import java.io.Writer;
21
22 import org.apache.logging.log4j.core.StringLayout;
23
24
25
26
27
28 public class WriterManager extends AbstractManager {
29
30
31
32
33
34
35
36
37
38
39 public static <T> WriterManager getManager(final String name, final T data,
40 final ManagerFactory<? extends WriterManager, T> factory) {
41 return AbstractManager.getManager(name, factory, data);
42 }
43 protected final StringLayout layout;
44
45 private volatile Writer writer;
46
47 public WriterManager(final Writer writer, final String streamName, final StringLayout layout,
48 final boolean writeHeader) {
49 super(streamName);
50 this.writer = writer;
51 this.layout = layout;
52 if (writeHeader && layout != null) {
53 final byte[] header = layout.getHeader();
54 if (header != null) {
55 try {
56 this.writer.write(new String(header, layout.getCharset()));
57 } catch (final IOException e) {
58 logError("Unable to write header", e);
59 }
60 }
61 }
62 }
63
64 protected synchronized void close() {
65 final Writer w = writer;
66 try {
67 w.close();
68 } catch (final IOException ex) {
69 logError("Unable to close stream", ex);
70 }
71 }
72
73
74
75
76 public synchronized void flush() {
77 try {
78 writer.flush();
79 } catch (final IOException ex) {
80 final String msg = "Error flushing stream " + getName();
81 throw new AppenderLoggingException(msg, ex);
82 }
83 }
84
85 protected Writer getWriter() {
86 return writer;
87 }
88
89
90
91
92
93 public boolean isOpen() {
94 return getCount() > 0;
95 }
96
97
98
99
100 @Override
101 public void releaseSub() {
102 writeFooter();
103 close();
104 }
105
106 protected void setWriter(final Writer writer) {
107 final byte[] header = layout.getHeader();
108 if (header != null) {
109 try {
110 writer.write(new String(header, layout.getCharset()));
111 this.writer = writer;
112 } catch (final IOException ioe) {
113 logError("Unable to write header", ioe);
114 }
115 } else {
116 this.writer = writer;
117 }
118 }
119
120
121
122
123
124
125
126
127
128 protected synchronized void write(final String str) {
129 try {
130 writer.write(str);
131 } catch (final IOException ex) {
132 final String msg = "Error writing to stream " + getName();
133 throw new AppenderLoggingException(msg, ex);
134 }
135 }
136
137
138
139
140 protected void writeFooter() {
141 if (layout == null) {
142 return;
143 }
144 final byte[] footer = layout.getFooter();
145 if (footer != null && footer.length > 0) {
146 write(new String(footer, layout.getCharset()));
147 }
148 }
149 }