blob: 1019f73ad6b45791037603e741cd7448b4f7f287 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
|
/*
This file is part of Subsonic.
Subsonic is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Subsonic is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Subsonic. If not, see <http://www.gnu.org/licenses/>.
Copyright 2009 (C) Sindre Mehus
*/
package net.sourceforge.subsonic.io;
import net.sourceforge.subsonic.*;
import org.apache.commons.io.*;
import java.io.*;
/**
* Utility class which reads everything from an input stream and optionally logs it.
*
* @see TranscodeInputStream
* @author Sindre Mehus
*/
public class InputStreamReaderThread extends Thread {
private static final Logger LOG = Logger.getLogger(InputStreamReaderThread.class);
private InputStream input;
private String name;
private boolean log;
public InputStreamReaderThread(InputStream input, String name, boolean log) {
super(name + " InputStreamLogger");
this.input = input;
this.name = name;
this.log = log;
}
public void run() {
BufferedReader reader = null;
try {
reader = new BufferedReader(new InputStreamReader(input));
for (String line = reader.readLine(); line != null; line = reader.readLine()) {
if (log) {
LOG.debug('(' + name + ") " + line);
}
}
} catch (IOException x) {
// Intentionally ignored.
} finally {
IOUtils.closeQuietly(reader);
IOUtils.closeQuietly(input);
}
}
}
|