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

cx.ath.matthew.io.ExecOutputStream Maven / Gradle / Ivy

Go to download

Some libraries from Matthew Johnson: http://www.matthew.ath.cx/projects/java/ Modifications: - including precompiled native C libraries (libunix-java) for architectures: arm, amd64 and i386 - UnixSocket/UnixServerSocket now implements closable (allows try-with-resources usage) - Cleaned up code style - Split test classes to test classpath - Introduced JUnit - Removed the whole CGI package, it should never ever been used these days

The newest version!
/*
 * Java Exec Pipe Library
 *
 * Copyright (c) Matthew Johnson 2005
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 *
 * To Contact the author, please email [email protected]
 *
 */

package cx.ath.matthew.io;

import java.io.FilterOutputStream;
import java.io.InputStream;
import java.io.IOException;
import java.io.OutputStream;

/**
 * Class to pipe an OutputStream through a command using stdin/stdout.
 * E.g.
 * 
 *    Writer w = new OutputStreamWriter(new ExecOutputStream(new FileOutputStream("file"), "command"));
 * 
*/ public class ExecOutputStream extends FilterOutputStream { private Process proc; private InputStream stdout; private OutputStream stdin; private InOutCopier copy; /** * Create a new ExecOutputStream on the given OutputStream * using the process to filter the stream. * @param os Writes to this OutputStream * @param p Filters data through stdin/out on this Process * @throws IOException on error */ public ExecOutputStream(OutputStream os, Process p) throws IOException { super(os); proc = p; stdin = p.getOutputStream(); stdout = p.getInputStream(); copy = new InOutCopier(stdout, out); copy.start(); } /** * Create a new ExecOutputStream on the given OutputStream * using the process to filter the stream. * @param os Writes to this OutputStream * @param cmd Creates a Process from this string to filter data through stdin/out * @throws IOException on error */ public ExecOutputStream(OutputStream os, String cmd) throws IOException { this(os, Runtime.getRuntime().exec(cmd)); } /** * Create a new ExecOutputStream on the given OutputStream * using the process to filter the stream. * @param os Writes to this OutputStream * @param cmd Creates a Process from this string array (command, arg, ...) to filter data through stdin/out * @throws IOException on error */ public ExecOutputStream(OutputStream os, String[] cmd) throws IOException { this(os, Runtime.getRuntime().exec(cmd)); } /** * Create a new ExecOutputStream on the given OutputStream * using the process to filter the stream. * @param os Writes to this OutputStream * @param cmd Creates a Process from this string to filter data through stdin/out * @param env Setup the environment for the command * @throws IOException on error */ public ExecOutputStream(OutputStream os, String cmd, String[] env) throws IOException { this(os, Runtime.getRuntime().exec(cmd, env)); } /** * Create a new ExecOutputStream on the given OutputStream * using the process to filter the stream. * @param os Writes to this OutputStream * @param cmd Creates a Process from this string array (command, arg, ...) to filter data through stdin/out * @param env Setup the environment for the command * @throws IOException on error */ public ExecOutputStream(OutputStream os, String[] cmd, String[] env) throws IOException { this(os, Runtime.getRuntime().exec(cmd, env)); } public void close() throws IOException { stdin.close(); try { proc.waitFor(); } catch (InterruptedException exI) { } // copy.close(); try { copy.join(); } catch (InterruptedException exI) { } stdout.close(); out.close(); } public void flush() throws IOException { stdin.flush(); copy.flush(); out.flush(); } public void write(byte[] b) throws IOException { stdin.write(b); } public void write(byte[] b, int off, int len) throws IOException { stdin.write(b, off, len); } public void write(int b) throws IOException { stdin.write(b); } public void finalize() { try { close(); } catch (Exception e) { } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy