org.apache.camel.processor
Class DelegateProcessor

java.lang.Object
  extended by org.apache.camel.support.ServiceSupport
      extended by org.apache.camel.processor.DelegateProcessor
All Implemented Interfaces:
DelegateProcessor, Navigate<Processor>, Processor, Service, ShutdownableService, StatefulService, SuspendableService
Direct Known Subclasses:
DirectVmProcessor

public class DelegateProcessor
extends ServiceSupport
implements DelegateProcessor, Processor, Navigate<Processor>

A Delegate pattern which delegates processing to a nested Processor which can be useful for implementation inheritance when writing an Policy

Important: This implementation does not support the asynchronous routing engine. If you are implementing a EIP pattern please use the DelegateAsyncProcessor instead.

Version:
See Also:
DelegateAsyncProcessor

Field Summary
protected  Processor processor
           
 
Fields inherited from class org.apache.camel.support.ServiceSupport
shutdown, shuttingdown, started, starting, stopped, stopping, suspended, suspending
 
Constructor Summary
DelegateProcessor()
           
DelegateProcessor(Processor processor)
           
 
Method Summary
protected  void doStart()
          Implementations override this method to support customized start/stop.
protected  void doStop()
          Implementations override this method to support customized start/stop.
 Processor getProcessor()
           
 boolean hasNext()
          Are there more outputs?
 List<Processor> next()
          Next group of outputs
 void process(Exchange exchange)
          Processes the message exchange
protected  void processNext(Exchange exchange)
           
 void setProcessor(Processor processor)
           
 String toString()
           
 
Methods inherited from class org.apache.camel.support.ServiceSupport
doResume, doShutdown, doSuspend, getStatus, getVersion, isRunAllowed, isStarted, isStarting, isStopped, isStopping, isSuspended, isSuspending, resume, shutdown, start, stop, suspend
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 

Field Detail

processor

protected Processor processor
Constructor Detail

DelegateProcessor

public DelegateProcessor()

DelegateProcessor

public DelegateProcessor(Processor processor)
Method Detail

process

public void process(Exchange exchange)
             throws Exception
Description copied from interface: Processor
Processes the message exchange

Specified by:
process in interface Processor
Parameters:
exchange - the message exchange
Throws:
Exception - if an internal processing error has occurred.

processNext

protected void processNext(Exchange exchange)
                    throws Exception
Throws:
Exception

toString

public String toString()
Overrides:
toString in class Object

getProcessor

public Processor getProcessor()
Specified by:
getProcessor in interface DelegateProcessor
Returns:
the processor we delegate to

setProcessor

public void setProcessor(Processor processor)

doStart

protected void doStart()
                throws Exception
Description copied from class: ServiceSupport
Implementations override this method to support customized start/stop.

Important: See ServiceSupport.doStop() for more details.

Specified by:
doStart in class ServiceSupport
Throws:
Exception
See Also:
ServiceSupport.doStop()

doStop

protected void doStop()
               throws Exception
Description copied from class: ServiceSupport
Implementations override this method to support customized start/stop.

Important: Camel will invoke this ServiceSupport.doStop() method when the service is being stopped. This method will also be invoked if the service is still in uninitialized state (eg has not been started). The method is always called to allow the service to do custom logic when the service is being stopped, such as when CamelContext is shutting down.

Specified by:
doStop in class ServiceSupport
Throws:
Exception
See Also:
ServiceSupport.doStart()

hasNext

public boolean hasNext()
Description copied from interface: Navigate
Are there more outputs?

Specified by:
hasNext in interface Navigate<Processor>
Returns:
true if more outputs

next

public List<Processor> next()
Description copied from interface: Navigate
Next group of outputs

Specified by:
next in interface Navigate<Processor>
Returns:
next group or null if no more outputs


Apache CAMEL