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

java.fedora.utilities.ExecUtility Maven / Gradle / Ivy

Go to download

The Fedora Client is a Java Library that allows API access to a Fedora Repository. The client is typically one part of a full Fedora installation.

The newest version!
/*
 * -----------------------------------------------------------------------------
 *
 * 

License and Copyright: The contents of this file are subject to 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.fedora-commons.org/licenses.

* *

Software distributed under the License is distributed on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for * the specific language governing rights and limitations under the License.

* *

The entire file consists of original code.

*

Copyright © 2008 Fedora Commons, Inc.
*

Copyright © 2002-2007 The Rector and Visitors of the University of * Virginia and Cornell University
* All rights reserved.

* * ----------------------------------------------------------------------------- */ package fedora.utilities; import java.io.BufferedReader; import java.io.File; import java.io.IOException; import java.io.InputStreamReader; import java.io.OutputStream; import java.io.PrintStream; /** * Utility class for executing commands and sending the command's output to a * given OutputStream. * * @author Edwin Shin */ public class ExecUtility { public static Process exec(String cmd) { return exec(cmd, null, System.out, null); } public static Process exec(String[] cmd) { return exec(cmd, null, System.out, null); } public static Process exec(String cmd, OutputStream out) { return exec(cmd, null, out, null); } public static Process exec(String[] cmd, OutputStream out) { return exec(cmd, null, out, null); } public static Process exec(String cmd, File dir) { return exec(cmd, dir, System.out, null); } public static Process exec(String[] cmd, File dir) { return exec(cmd, dir, System.out, null); } public static Process exec(String cmd, File dir, OutputStream out, OutputStream err) { return exec(new String[]{cmd}, dir, out, err); } public static Process exec(String[] cmd, File dir, OutputStream out, OutputStream err) { Process cp = null; try { if (dir == null) { cp = Runtime.getRuntime().exec(cmd, null); } else { cp = Runtime.getRuntime().exec(cmd, null, dir); } // Print stdio of cmd if (out != null) { PrintStream pout = new PrintStream(out); PrintStream perr = null; if (err != null) { if (out == err) { perr = pout; } else { perr = new PrintStream(err); } } else { perr = System.err; } String err_line; String in_line; BufferedReader input = new BufferedReader( new InputStreamReader(cp.getInputStream())); BufferedReader error = new BufferedReader( new InputStreamReader(cp.getErrorStream())); while (true) { try { cp.exitValue(); break; // process exited, } catch (IllegalThreadStateException e) { // process has not terminated check for output if (error.ready()) { err_line = error.readLine(); perr.println(err_line); } else if (input.ready()) { in_line = input.readLine(); pout.println(in_line); } else { try { Thread.sleep(10); } catch (InterruptedException ie) { // don't worry, be happy } } } } // Read any remaining buffered output from the process // after it terminates while (error.ready()) { err_line = error.readLine(); perr.println(err_line); } while (input.ready()) { in_line = input.readLine(); pout.println(in_line); } input.close(); error.close(); } } catch (IOException e) { e.printStackTrace(); } return cp; } public static Process execCommandLineUtility(String cmd) { return execCommandLineUtility(cmd, System.out, null); } public static Process execCommandLineUtility(String[] cmd) { return execCommandLineUtility(cmd, System.out, null); } public static Process execCommandLineUtility(String cmd, OutputStream out, OutputStream err) { return execCommandLineUtility(new String[] {cmd}, out, err); } public static Process execCommandLineUtility(String[] cmd, OutputStream out, OutputStream err) { String osName = System.getProperty("os.name"); if (osName.startsWith("Windows")) { String[] temp = new String[cmd.length + 2]; System.arraycopy(cmd, 0, temp, 2, cmd.length); temp[0] = "cmd.exe"; temp[1] = "/C"; cmd = temp; } return exec(cmd, null, out, err); } public static Process altExec(String cmd) { return altExec(new String[]{cmd}); } public static Process altExec(String[] cmd) { int result; // prepare buffers for process output and error streams StringBuffer err = new StringBuffer(); StringBuffer out = new StringBuffer(); try { Process proc = Runtime.getRuntime().exec(cmd); //create thread for reading inputStream (process' stdout) StreamReaderThread outThread = new StreamReaderThread(proc .getInputStream(), out); //create thread for reading errorStream (process' stderr) StreamReaderThread errThread = new StreamReaderThread(proc .getErrorStream(), err); //start both threads outThread.start(); errThread.start(); //wait for process to end result = proc.waitFor(); //finish reading whatever's left in the buffers outThread.join(); errThread.join(); if (result != 0) { System.out.println("Process " + cmd + " returned non-zero value:" + result); System.out.println("Process output:\n" + out.toString()); System.out.println("Process error:\n" + err.toString()); } else { System.out.println("Process " + cmd + " executed successfully"); System.out.println("Process output:\n" + out.toString()); System.out.println("Process error:\n" + err.toString()); } } catch (Exception e) { System.out.println("Error executing " + cmd); e.printStackTrace(); //throw e; } return null; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy