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

com.googlecode.sarasvati.visitor.CreateOrderTokenTraversal 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 2008-2009 Paul Lorenz
*/

package com.googlecode.sarasvati.visitor;

import java.util.Comparator;
import java.util.HashSet;
import java.util.PriorityQueue;
import java.util.Queue;
import java.util.Set;

import com.googlecode.sarasvati.ArcToken;
import com.googlecode.sarasvati.NodeToken;
import com.googlecode.sarasvati.Token;

public class CreateOrderTokenTraversal implements TokenTraversal
{
  protected static final Comparator tokenSorter = new Comparator()
  {
    @Override
    public int compare (final Token o1, final Token o2)
    {
      if ( o1 instanceof NodeToken )
      {
        NodeToken t1 = (NodeToken)o1;
        if ( o2 instanceof NodeToken )
        {
          NodeToken t2 = (NodeToken)o2;
          return t1.getCreateDate().compareTo( t2.getCreateDate() );
        }

        ArcToken t2 = (ArcToken)o2;
        return t1.getCreateDate().compareTo( t2.getParentToken().getCompleteDate() );
      }

      ArcToken t1 = (ArcToken)o1;
      if ( o2 instanceof NodeToken )
      {
        NodeToken t2 = (NodeToken)o2;
        return t1.getParentToken().getCompleteDate().compareTo( t2.getCreateDate() );
      }

      ArcToken t2 = (ArcToken)o2;
      return t1.getParentToken().getCompleteDate().compareTo( t2.getParentToken().getCompleteDate() );
    }
  };

  private final Queue queue = new PriorityQueue( 10, tokenSorter );
  private final Set nodeTokens = new HashSet();

  private final boolean forward;

  public CreateOrderTokenTraversal ()
  {
    this.forward = true;
  }

  public CreateOrderTokenTraversal (final boolean forward)
  {
    this.forward = forward;
  }

  @Override
  public void traverse (final NodeToken token, final TokenVisitor visitor)
  {
    enqueueNodeToken( token );
    traverse( visitor );
  }

  @Override
  public void traverse (final ArcToken token, final TokenVisitor visitor)
  {
    queue.add( token );
    traverse( visitor );
  }

  protected void traverse (final TokenVisitor visitor)
  {
    while ( !queue.isEmpty() )
    {
      Token next = queue.remove();

      if ( next instanceof NodeToken )
      {
        NodeToken token = (NodeToken)next;
        token.accept( visitor );
        queue.addAll( forward ? token.getChildTokens() : token.getParentTokens() );
      }
      else
      {
        ArcToken token = (ArcToken)next;

        if ( visitor.follow( token ) )
        {
          token.accept( visitor );
          enqueueNodeToken( forward ? token.getChildToken() : token.getParentToken() );
        }
      }
    }
  }

  protected void enqueueNodeToken (final NodeToken token)
  {
    if ( token != null && !nodeTokens.contains( token.getId() ) )
    {
      queue.add( token );
      nodeTokens.add( token.getId() );
    }
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy