/**
* $Id$
* $Date$
*
*/
package org.xmlsh.sh.shell;
import java.io.File;
import org.apache.log4j.LogManager;
import org.apache.log4j.Logger;
import org.xmlsh.sh.core.Command;
import org.xmlsh.xpath.ShellContext;
public class ShellThread extends Thread {
@SuppressWarnings("unused")
private static Logger mLogger = LogManager.getLogger( ShellThread.class);
private Shell mShell ;
private Command mCommand;
private File mIniitalCD;
private Shell mParent = null;
public ShellThread(Shell shell , Shell parent , Command cmd ) {
mShell = shell;
mParent = parent ;
mCommand = cmd;
mIniitalCD = shell.getCurdir();
}
/* (non-Javadoc)
* @see java.lang.Thread#run()
*/
@Override
public void run()
{
try {
ShellContext.set( mShell );
mShell.setCurdir(mIniitalCD); // Populate the current directory in this thread
mCommand.exec(mShell);
} catch (Exception e) {
// mShell.printErr("Exception running: " + mCommand.toString(true) + "\n" + e.toString() );
mLogger.error("Exception running command: " + mCommand.toString(false) , e );
} finally {
ShellContext.set(null);
mShell.close();
if( mParent != null )
mParent.removeJob( this );
}
}
public Command getCommand(){
return mCommand ;
}
}
//
//
//Copyright (C) 2008-2014 David A. Lee.
//
//The contents of this file are subject to the "Simplified BSD License" (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.opensource.org/licenses/bsd-license.php
//
//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 Original Code is: all this file.
//
//The Initial Developer of the Original Code is David A. Lee
//
//Portions created by (your name) are Copyright (C) (your legal entity). All Rights Reserved.
//
//Contributor(s): none.
//