001/**
002 * Copyright 2010-2014 The Kuali Foundation
003 *
004 * Licensed under the Educational Community License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 * http://www.opensource.org/licenses/ecl2.php
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 */
016package org.kuali.common.util.log;
017
018import org.codehaus.plexus.util.cli.StreamConsumer;
019import org.kuali.common.util.Assert;
020import org.slf4j.Logger;
021
022/**
023 * @deprecated
024 */
025@Deprecated
026public final class LoggingStreamConsumer implements StreamConsumer {
027
028        private final Logger logger;
029        private final LoggerLevel level;
030
031        public LoggingStreamConsumer(Logger logger) {
032                this(logger, LoggerLevel.INFO);
033        }
034
035        public LoggingStreamConsumer(Logger logger, LoggerLevel level) {
036                Assert.noNulls(logger, level);
037                this.logger = logger;
038                this.level = level;
039        }
040
041        @Override
042        public void consumeLine(String line) {
043                switch (level) {
044                case TRACE:
045                        logger.trace(line);
046                        return;
047                case DEBUG:
048                        logger.debug(line);
049                        return;
050                case INFO:
051                        logger.info(line);
052                        return;
053                case WARN:
054                        logger.warn(line);
055                        return;
056                case ERROR:
057                        logger.error(line);
058                        return;
059                default:
060                        throw new IllegalStateException("Logger level " + level + " is unknown");
061                }
062        }
063
064        public Logger getLogger() {
065                return logger;
066        }
067
068        public LoggerLevel getLevel() {
069                return level;
070        }
071
072}