public interface Flow
Typically, developers extend CasFlow_ImplBase
or
JCasFlow_ImplBase
depending on which CAS interface they wish to use.
Modifier and Type | Method and Description |
---|---|
void |
aborted()
Called by the framework if processing has been aborted for the CAS that was being
routed by this Flow object.
|
boolean |
continueOnFailure(String failedAeKey,
Exception failure)
May be called by the framework to ask the FlowController if processing of the CAS can
continue after a failure occurred while executing the last Step that the Flow Controller
returned.
|
Flow |
newCasProduced(AbstractCas newCas,
String producedBy)
Called by the framework if the CAS that is being routed by this Flow has been sent to a CAS
Multiplier which has then created a new CAS derived from that original CAS.
|
Step |
next()
Gets the next destination for the CAS.
|
Step next() throws AnalysisEngineProcessException
Step
object. There may be
different kinds of Step objects to indicate different kinds of routing actions.AnalysisEngineProcessException
- if a failure occurs while determining the next destinationFlow newCasProduced(AbstractCas newCas, String producedBy) throws AnalysisEngineProcessException
It is not required for a Flow implementation to support the production of new CASes in the middle of the flow, in which case this method may throw an exception.
If implemented, this method should construct a new Flow
object that will be used to
route the new CAS. The new Flow object then takes over all responsibility for that CAS.
newCas
- the new CASproducedBy
- key of the AnalysisEngine (CAS Multiplier) that produced the new CASaCAS
through the
Aggregate Analysis Engine.AnalysisEngineProcessException
- passthruboolean continueOnFailure(String failedAeKey, Exception failure)
If this method returns true, then the framework may continue to call the next()
method
to continue routing the CAS. If this method returns false, the framework will not make any
more calls to the next()
method, and will call the aborted()
method.
In the case where the last Step was a ParallelStep
, if at least one of the destinations
resulted in a failure, this method will be called to report one of the failures. If this method
returns true, but one of the other destinations in the ParallelStep resulted in a failure, this
method will be called again to report the next failure. This continues until either this method
returns false or there are no more failures.
Note that it is possible for processing of a CAS to be aborted without this method being called. This method is only called when an attempt is being made to continue processing of the CAS following an error, which may be an application configuration decision.
failedAeKey
- The key of the analysis engine that failed.failure
- the Exception that occurredvoid aborted()
next()
method again.
This method provides the Flow object with an opportunity to clean up any resources. Also, it could be used to allow the FlowController to reuse a Flow object if desired.
Copyright © 2006–2017 The Apache Software Foundation. All rights reserved.