/*! ****************************************************************************** * * Pentaho Data Integration * * Copyright (C) 2002-2017 by Pentaho : http://www.pentaho.com * ******************************************************************************* * * 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.pentaho.di.trans.steps.abort; import org.pentaho.di.core.Const; import org.pentaho.di.core.exception.KettleException; import org.pentaho.di.i18n.BaseMessages; import org.pentaho.di.trans.Trans; import org.pentaho.di.trans.TransMeta; import org.pentaho.di.trans.step.BaseStep; import org.pentaho.di.trans.step.StepDataInterface; import org.pentaho.di.trans.step.StepInterface; import org.pentaho.di.trans.step.StepMeta; import org.pentaho.di.trans.step.StepMetaInterface; /** * Step that will abort after having seen 'x' number of rows on its input. * * @author Sven Boden */ public class Abort extends BaseStep implements StepInterface { private static Class<?> PKG = Abort.class; // for i18n purposes, needed by Translator2!! private AbortMeta meta; private int nrInputRows; private int nrThresholdRows; public Abort( StepMeta stepMeta, StepDataInterface stepDataInterface, int copyNr, TransMeta transMeta, Trans trans ) { super( stepMeta, stepDataInterface, copyNr, transMeta, trans ); } public boolean init( StepMetaInterface smi, StepDataInterface sdi ) { meta = (AbortMeta) smi; if ( super.init( smi, sdi ) ) { // Add init code here. nrInputRows = 0; String threshold = environmentSubstitute( meta.getRowThreshold() ); nrThresholdRows = Const.toInt( threshold, -1 ); if ( nrThresholdRows < 0 ) { logError( BaseMessages.getString( PKG, "Abort.Log.ThresholdInvalid", threshold ) ); } return true; } return false; } public boolean processRow( StepMetaInterface smi, StepDataInterface sdi ) throws KettleException { meta = (AbortMeta) smi; Object[] r = getRow(); // Get row from input rowset & set row busy! // no more input to be expected... if ( r == null ) { setOutputDone(); return false; } else { putRow( getInputRowMeta(), r ); nrInputRows++; if ( nrInputRows > nrThresholdRows ) { // // Here we abort!! // logError( BaseMessages.getString( PKG, "Abort.Log.Wrote.AbortRow", Long.toString( nrInputRows ), getInputRowMeta().getString( r ) ) ); String message = environmentSubstitute( meta.getMessage() ); if ( message == null || message.length() == 0 ) { logError( BaseMessages.getString( PKG, "Abort.Log.DefaultAbortMessage", "" + nrInputRows ) ); } else { logError( message ); } if ( meta.isAbortWithError() ) { setErrors( 1 ); } stopAll(); } else { // seen a row but not yet reached the threshold if ( meta.isAlwaysLogRows() ) { logMinimal( BaseMessages.getString( PKG, "Abort.Log.Wrote.Row", Long.toString( nrInputRows ), getInputRowMeta().getString( r ) ) ); } else { if ( log.isRowLevel() ) { logRowlevel( BaseMessages.getString( PKG, "Abort.Log.Wrote.Row", Long.toString( nrInputRows ), getInputRowMeta().getString( r ) ) ); } } } } return true; } }