/*******************************************************************************
* 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:
* * Jurgen J. Vinju - Jurgen.Vinju@cwi.nl - CWI
* * Emilie Balland - (CWI)
*******************************************************************************/
package org.rascalmpl.interpreter.matching;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import org.rascalmpl.ast.Expression;
import org.rascalmpl.interpreter.IEvaluatorContext;
import org.rascalmpl.interpreter.env.Environment;
import org.rascalmpl.interpreter.result.Result;
import org.rascalmpl.interpreter.types.RascalTypeFactory;
import org.rascalmpl.value.IValue;
import org.rascalmpl.value.type.Type;
import org.rascalmpl.values.uptr.RascalValueFactory;
public class ReifiedTypePattern extends AbstractMatchingResult {
private final NodePattern nodePattern;
public ReifiedTypePattern(IEvaluatorContext ctx, Expression x, IMatchingResult symbol, IMatchingResult def) {
super(ctx, x);
List<IMatchingResult> arguments = new ArrayList<IMatchingResult>(2);
arguments.add(symbol);
arguments.add(def);
this.nodePattern = new NodePattern(ctx, x, new LiteralPattern(ctx, x, ctx.getValueFactory().string("type")), null, RascalValueFactory.Type_Reified, arguments, Collections.<String,IMatchingResult>emptyMap());
}
@Override
public Type getType(Environment env, HashMap<String,IVarPattern> patternVars) {
// TODO: check if this would do it
return RascalTypeFactory.getInstance().reifiedType(tf.valueType());
}
@Override
public void initMatch(Result<IValue> subject) {
super.initMatch(subject);
nodePattern.initMatch(subject);
hasNext = nodePattern.hasNext();
}
@Override
public List<IVarPattern> getVariables() {
return nodePattern.getVariables();
}
@Override
public boolean next() {
if (hasNext()) {
boolean result = nodePattern.next();
hasNext = nodePattern.hasNext();
return result;
}
return false;
}
}