/*******************************************************************************
* Copyright (c) 2009-2013 CWI
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* * Arnold Lankamp - Arnold.Lankamp@cwi.nl
*******************************************************************************/
package org.rascalmpl.parser.gtd.stack;
import org.rascalmpl.parser.gtd.result.AbstractNode;
import org.rascalmpl.parser.gtd.result.EpsilonNode;
import org.rascalmpl.parser.gtd.stack.filter.ICompletionFilter;
import org.rascalmpl.parser.gtd.stack.filter.IEnterFilter;
public final class EpsilonStackNode<P> extends AbstractMatchableStackNode<P>{
public final static EpsilonNode EPSILON_RESULT = new EpsilonNode();
private final AbstractNode result;
public EpsilonStackNode(int id, int dot){
super(id, dot);
result = null;
}
public EpsilonStackNode(int id, int dot, IEnterFilter[] enterFilters, ICompletionFilter[] completionFilters){
super(id, dot, enterFilters, completionFilters);
result = null;
}
private EpsilonStackNode(EpsilonStackNode<P> original, int startLocation){
super(original, startLocation);
result = null;
}
private EpsilonStackNode(EpsilonStackNode<P> original, int startLocation, AbstractNode result){
super(original, startLocation);
this.result = result;
}
public boolean isEmptyLeafNode(){
return true;
}
public AbstractNode match(int[] input, int location){
return EPSILON_RESULT;
}
public AbstractStackNode<P> getCleanCopy(int startLocation){
return new EpsilonStackNode<P>(this, startLocation);
}
public AbstractStackNode<P> getCleanCopyWithResult(int startLocation, AbstractNode result){
return new EpsilonStackNode<P>(this, startLocation, result);
}
public int getLength(){
return 0;
}
public AbstractNode getResult(){
return result;
}
public String toString(){
StringBuilder sb = new StringBuilder();
sb.append('(');
sb.append(startLocation);
sb.append(')');
return sb.toString();
}
public int hashCode(){
return 0;
}
public boolean isEqual(AbstractStackNode<P> stackNode){
if(!(stackNode instanceof EpsilonStackNode)) return false;
return hasEqualFilters(stackNode);
}
}