/******************************************************************************* * 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; } }