All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.tools.ant.taskdefs.TaskOutputStream Maven / Gradle / Ivy

There is a newer version: 1.0-rc5
Show newest version
/*
 * Copyright  2000,2002-2004 The Apache Software Foundation
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.
 *
 */

package org.apache.tools.ant.taskdefs;

import java.io.IOException;
import java.io.OutputStream;
import org.apache.tools.ant.Task;

/**
 * Redirects text written to a stream thru the standard
 * ant logging mechanism. This class is useful for integrating
 * with tools that write to System.out and System.err. For example,
 * the following will cause all text written to System.out to be
 * logged with "info" priority:
 * 
System.setOut(new PrintStream(new TaskOutputStream(project, Project.MSG_INFO)));
* *

As of Ant 1.2, this class is considered to be dead code * by the Ant developers and is unmaintained. Don't use * it.

* * @deprecated use LogOutputStream instead. */ public class TaskOutputStream extends OutputStream { private Task task; private StringBuffer line; private int msgOutputLevel; /** * Constructs a new JavacOutputStream with the given project * as the output source for messages. */ TaskOutputStream(Task task, int msgOutputLevel) { System.err.println("As of Ant 1.2 released in October 2000, the " + "TaskOutputStream class"); System.err.println("is considered to be dead code by the Ant " + "developers and is unmaintained."); System.err.println("Don\'t use it!"); this.task = task; this.msgOutputLevel = msgOutputLevel; line = new StringBuffer(); } /** * Write a character to the output stream. This method looks * to make sure that there isn't an error being reported and * will flush each line of input out to the project's log stream. */ public void write(int c) throws IOException { char cc = (char) c; if (cc == '\r' || cc == '\n') { // line feed if (line.length() > 0) { processLine(); } } else { line.append(cc); } } /** * Processes a line of input and determines if an error occurred. */ private void processLine() { String s = line.toString(); task.log(s, msgOutputLevel); line = new StringBuffer(); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy