Mercurial > dive4elements > river
view flys-artifacts/src/main/java/de/intevation/flys/wsplgen/JobExecutor.java @ 1649:74142aa5d938
Improved WSPLGEN start to suppress inconsistent Artifact states.
flys-artifacts/trunk@2836 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Ingo Weinzierl <ingo.weinzierl@intevation.de> |
---|---|
date | Tue, 27 Sep 2011 11:33:45 +0000 |
parents | e7d5452a7381 |
children | aaf8d32f85bd |
line wrap: on
line source
package de.intevation.flys.wsplgen; import java.io.IOException; import java.io.File; import org.apache.log4j.Logger; import de.intevation.artifacts.CallContext; import de.intevation.flys.artifacts.model.WSPLGENJob; import de.intevation.flys.utils.MapfileGenerator; public class JobExecutor { public static final String WSPLGEN_PARAMETER_FILE = "wsplgen.par"; public static final String WSPLGEN_BIN_PATH = System.getProperty("wsplgen.bin.path"); private Logger logger = Logger.getLogger(JobExecutor.class); private Process process; protected WSPLGENJob job; protected JobObserver logObserver; protected ProblemObserver errorObserver; public JobExecutor(WSPLGENJob job) { this.job = job; this.logObserver = new JobObserver(job); this.errorObserver = new ProblemObserver(job); } public void execute() { File dir = job.getWorkingDir(); File parameter = new File(dir, WSPLGEN_PARAMETER_FILE); String[] args = new String[] { WSPLGEN_BIN_PATH, "-PAR=\"" + parameter.getAbsolutePath() + "\"" }; execute(args, dir); } protected void execute(String[] args, File dir) { logger.info("Start JobExecutor for artifact: " + dir.getName()); String errorMsg = null; try { synchronized (this) { process = Runtime.getRuntime().exec(args, null, dir); logObserver.setInputStream(process.getInputStream()); errorObserver.setInputStream(process.getErrorStream()); logObserver.start(); errorObserver.start(); try { process.waitFor(); } catch (InterruptedException ie) { logger.error("WSPLGEN job interrupted: " + ie.getMessage()); } try { logObserver.join(); errorObserver.join(); } catch (InterruptedException iee) { /* do nothing */ } job.getCallContext().afterBackground(CallContext.STORE); logger.info("WSPLGEN exit value: " + process.exitValue()); logger.info( "WSPLGEN throw " + errorObserver.numErrors() + " errors."); logger.info( "WSPLGEN throw " + errorObserver.numWarnings() + " warnings."); MapfileGenerator.getInstance().update(); return; } } catch (SecurityException se) { logger.error(se); } catch (IOException ioe) { logger.error(ioe); } catch (NullPointerException npe) { logger.error(npe, npe); } catch (IndexOutOfBoundsException ioobe) { logger.error(ioobe, ioobe); } } } // vim:set ts=4 sw=4 si et sta sts=4 fenc=utf-8 :