org.carrot2.core.IProcessingComponent Maven / Gradle / Ivy
/*
* Carrot2 project.
*
* Copyright (C) 2002-2016, Dawid Weiss, Stanisław Osiński.
* All rights reserved.
*
* Refer to the full license file "carrot2.LICENSE"
* in the root folder of the repository checkout or at:
* http://www.carrot2.org/carrot2.LICENSE
*/
package org.carrot2.core;
import org.carrot2.core.attribute.Init;
import org.carrot2.core.attribute.Processing;
import org.carrot2.util.attribute.Input;
import org.carrot2.util.attribute.Output;
/**
* Defines the life cycle of a Carrot2 processing component. The life cycle
* governs how {@link IProcessingComponent} instances are initialized and disposed of ({@link #init(IControllerContext)},
* {@link #dispose()}) and how processing proceeds ({@link #beforeProcessing()},
* {@link #process()}, {@link #afterProcessing()}). See {@link Controller} for a
* reference implementation of this life cycle.
*/
public interface IProcessingComponent
{
/**
* Invoked after component's attributes marked with {@link Init} and {@link Input}
* annotations have been bound, but before calls to any other methods of this
* component. After a call to this method completes without an exception, attributes
* marked with {@link Init} {@link Output} will be collected. In this method,
* components should perform initializations based on the initialization-time
* attributes. This method is called once in the life time of a processing
* component instance.
*
* @param ctx An instance of {@link IControllerContext} of the controller to which this
* component instance will be bound.
* @throws ComponentInitializationException when initialization failed. If thrown, the
* {@link #dispose()} method will be called on this component instance to
* allow clean-up actions. The instance will not be used for any further
* processing and should be made reclaimable to the garbage collector.
* Finally, the exception will be rethrown from the controller method that
* caused the component to initialize.
*/
public void init(IControllerContext ctx) throws ComponentInitializationException;
/**
* Invoked after the attributes marked with {@link Processing} and {@link Input}
* annotations have been bound, but before a call to {@link #process()}. In this
* method, the processing component should perform any initializations based on the
* runtime attributes. This method is called once per request.
*
* @throws ProcessingException when processing cannot start, e.g. because some
* attributes were not bound. If thrown, the {@link #process()} method
* will not be called. Instead, {@link #afterProcessing()} will be called
* immediately to allow clean-up actions, and the component will be ready
* to accept further requests or to be disposed of. Finally, the exception
* will be rethrown from the controller method that caused the component
* to perform processing.
*/
public void beforeProcessing() throws ProcessingException;
/**
* Performs the processing required to fulfill the request. This method is called once
* per request.
*
* @throws ProcessingException when processing failed. If thrown, the
* {@link #afterProcessing()} method will be called and the component will
* be ready to accept further requests or to be disposed of. Finally, the
* exception will be rethrown from the controller method that caused the
* component to perform processing.
*/
public void process() throws ProcessingException;
/**
* Invoked after the processing has finished, no matter whether an exception has been
* thrown or not. After a call to this method completes, attributes marked with
* {@link Processing} and {@link Output} annotations will be collected. In this
* method, the processing component should dispose of any resources it has allocated
* to fulfill the request. No matter whether a call to this method completes
* successfully or with an exception, the component will be ready to accept further
* requests or to be disposed of. This method is called once per request.
*/
public void afterProcessing();
/**
* Invoked before this processing component is about to be destroyed. In this method,
* the processing component should release any resources it allocated during
* initialization. After the call to this method, no other method of this processing
* component will be called and the component should be made reclaimable to the
* garbage collector. Exceptions thrown by this method will be ignored. This method is
* called once in the life time of a processing component instance.
*/
public void dispose();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy