/* This file is part of Airsonic. Airsonic 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. Airsonic 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 Airsonic. If not, see . Copyright 2016 (C) Airsonic Authors Based upon Subsonic, Copyright 2009 (C) Sindre Mehus */ package org.airsonic.player.io; import org.airsonic.player.util.FileUtil; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; /** * 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 = LoggerFactory.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() { try (BufferedReader reader = new BufferedReader(new InputStreamReader(input))) { for (String line = reader.readLine(); line != null; line = reader.readLine()) { if (log) { LOG.info('(' + name + ") " + line); } } } catch (IOException ignored) { } finally { FileUtil.closeQuietly(input); } } }