net.pms.io.OutputTextLogger.java Source code

Java tutorial

Introduction

Here is the source code for net.pms.io.OutputTextLogger.java

Source

/*
 * PS3 Media Server, for streaming any medias to your PS3.
 * Copyright (C) 2008  A.Brochard
 *
 * This program 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; version 2
 * of the License only.
 *
 * This program 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 this program; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
 */
package net.pms.io;

import org.apache.commons.io.IOUtils;
import org.apache.commons.io.LineIterator;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.List;

/**
 *  A version of OutputTextConsumer that a) logs all output to the debug.log and b) doesn't store the output
 */
public class OutputTextLogger extends OutputConsumer {
    private static final Logger logger = LoggerFactory.getLogger(OutputTextLogger.class);

    public OutputTextLogger(InputStream inputStream) {
        super(inputStream);
    }

    public void run() {
        LineIterator it = null;

        try {
            it = IOUtils.lineIterator(inputStream, "UTF-8");

            while (it.hasNext()) {
                String line = it.nextLine();
                logger.debug(line);
            }
        } catch (IOException ioe) {
            logger.debug("Error consuming input stream: {}", ioe.getMessage());
        } catch (IllegalStateException ise) {
            logger.debug("Error reading from closed input stream: {}", ise.getMessage());
        } finally {
            LineIterator.closeQuietly(it); // clean up all associated resources
        }
    }

    public BufferedOutputFile getBuffer() {
        return null;
    }

    public List<String> getResults() {
        return null;
    }
}