All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.dihedron.patterns.activities.engine.SequentialEngine Maven / Gradle / Ivy

/**
 * Copyright (c) 2012-2014, Andrea Funto'. All rights reserved. See LICENSE for details.
 */ 

package org.dihedron.patterns.activities.engine;

import org.dihedron.core.License;
import org.dihedron.patterns.activities.TypedVector;
import org.dihedron.patterns.activities.exceptions.ActivityException;
import org.dihedron.patterns.activities.types.ActivityData;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * @author Andrea Funto'
 */
@License
public class SequentialEngine implements ActivityEngine {
	
	/**
	 * The logger.
	 */
	private static final Logger logger = LoggerFactory.getLogger(SequentialEngine.class);

	/**
	 * @throws ActivityException 
	 * @see org.dihedron.patterns.activities.engine.ActivityEngine#execute(org.dihedron.commons.TypedVector)
	 */
	@Override
	public ActivityData execute(TypedVector infos) throws ActivityException {
		ActivityData data = null;
		if(infos != null) {
			logger.trace("executing {} activities...", infos.size());			
			for(ActivityInfo info : infos) {
				logger.trace("starting activity '{}'...", info.getActivity().getId());
				if(data == null) {
					logger.trace("... using data from the input");
					data = info.getData();
				} else {
					logger.trace("... using data from the previous step");
				}
				data = info.getActivity().perform(info.getContext(), data);
			}
		} else {
			logger.warn("no activities to execute");
		}
		return data;
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy