summaryrefslogtreecommitdiff
path: root/src/main/java/com/c2kernel/lifecycle/instance/OrSplit.java
blob: 89f5ad202b55e80263a974e9a4cab73fba964cc5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
package com.c2kernel.lifecycle.instance;
import java.util.StringTokenizer;

import com.c2kernel.common.InvalidDataException;
import com.c2kernel.graph.model.DirectedEdge;
import com.c2kernel.lookup.AgentPath;
import com.c2kernel.scripting.ScriptingEngineException;
import com.c2kernel.utils.Logger;
/**
 * @version $Revision: 1.22 $ $Date: 2005/05/10 15:14:54 $
 * @author $Author: abranson $
 */
public class OrSplit extends Split
{
	/**
	 * @see java.lang.Object#Object()
	 */
	public OrSplit()
	{
		super();
	}
	@Override
	public void runNext(AgentPath agent, int itemSysKey) throws InvalidDataException
	{
		String nexts;
		String scriptName = (String) getProperties().get("RoutingScriptName");
		Integer scriptVersion = (Integer) getProperties().get("RoutingScriptVersion");
        try {
			nexts = this.evaluateScript(scriptName, scriptVersion, itemSysKey).toString();
		} catch (ScriptingEngineException e) {
			Logger.error(e);
			throw new InvalidDataException("Error running routing script "+scriptName+" v"+scriptVersion, null);
		}
		StringTokenizer tok = new StringTokenizer(nexts, ",");
		Logger.msg(7, tok.countTokens() + " nexts to activate:" + nexts);
		int active = 0;
		try
		{
			DirectedEdge[] outEdges = getOutEdges();
            AdvancementCalculator adv = new AdvancementCalculator();
            adv.calculate((CompositeActivity)getParent());
			while (tok.hasMoreTokens())
			{
				String thisNext = tok.nextToken();
				Logger.msg(7, "Finding next " + thisNext);
				for (DirectedEdge outEdge : outEdges) {
					Next nextEdge = (Next) outEdge;
					if (thisNext != null && thisNext.equals(nextEdge.getProperties().get("Alias")))
					{
                        WfVertex term = nextEdge.getTerminusVertex();
                        term.run(agent, itemSysKey);
						Logger.msg(7, "Running " + nextEdge.getProperties().get("Alias"));
						active++;
					}
				}
			}
			// if no active nexts throw exception
		}
		catch (Exception e)
		{
			Logger.error(e);
		}
		if (active == 0)
			throw new InvalidDataException("No nexts were activated!", null);
	}


}