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

com.googlecode.sarasvati.join.AndJoinStrategy Maven / Gradle / Ivy

The newest version!
/*
    This file is part of Sarasvati.

    Sarasvati is free software: you can redistribute it and/or modify
    it under the terms of the GNU Lesser General Public License as
    published by the Free Software Foundation, either version 3 of the
    License, or (at your option) any later version.

    Sarasvati is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU Lesser General Public License for more details.

    You should have received a copy of the GNU Lesser General Public
    License along with Sarasvati.  If not, see .

    Copyright 2009 Paul Lorenz
*/
package com.googlecode.sarasvati.join;

import java.util.ArrayList;
import java.util.List;

import com.googlecode.sarasvati.Arc;
import com.googlecode.sarasvati.ArcToken;
import com.googlecode.sarasvati.Engine;
import com.googlecode.sarasvati.GraphProcess;
import com.googlecode.sarasvati.JoinResult;
import com.googlecode.sarasvati.JoinStrategy;
import com.googlecode.sarasvati.SarasvatiException;
import com.googlecode.sarasvati.TokenSetMember;

/**
 * Implements a join strategy in which nodes will wait for arc tokens to be
 * present on all incoming arcs before completing the join.
 *
 * @author Paul Lorenz
 */
public class AndJoinStrategy implements JoinStrategy
{
  protected List getJoiningArcs(final GraphProcess process, final ArcToken token)
  {
    return process.getGraph().getInputArcs(token.getArc().getEndNode());
  }

  /**
   * Returns the filter to use when joining
   *
   * @param engine Engine may be used by subclass to return different set of nodes
   * @param arcToken The arc token being joined
   *
   * @return The filter to use when joining
   */
  protected ArcTokenFilter getTokenFilter(final Engine engine, final ArcToken arcToken)
  {
    if (!arcToken.isTokenSetMember())
    {
      return NoTokenMembershipsFilter.INSTANCE;
    }

    TokenSetMember tokenSetMember = null;
    for (final TokenSetMember next : arcToken.getTokenSetMemberships())
    {
      if (tokenSetMember == null || tokenSetMember.getTokenSet().getLevel() < next.getTokenSet().getLevel())
      {
        tokenSetMember = next;
      }
    }

    if (tokenSetMember == null)
    {
      throw new SarasvatiException("Arc Token " + arcToken + " was marking as having token set memberships, but didn't.");
    }

    return new TokenSetGroupFilter(tokenSetMember.getTokenSet(), tokenSetMember.getMemberIndex());
  }

  @Override
  public JoinResult performJoin(final Engine engine, final ArcToken token)
  {
    final ArcTokenFilter filter = getTokenFilter(engine, token);
    return performJoin(token, filter);
  }

  public JoinResult performJoin(final ArcToken initiatingToken,
                                final ArcTokenFilter filter)
  {
    final List joinArcs = getJoiningArcs(initiatingToken.getProcess(), initiatingToken);

    final ArrayList tokens = new ArrayList(joinArcs.size());

    for (final Arc arc : joinArcs)
    {
      for (final ArcToken arcToken : initiatingToken.getProcess().getActiveArcTokens())
      {
        if (arcToken.getArc().equals(arc) && filter.isValidForJoin(arcToken))
        {
          tokens.add(arcToken);
          break;
        }
      }
    }

    return joinArcs.size() == tokens.size() ? new CompleteJoinResult(tokens) : IncompleteJoinResult.INSTANCE;
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy