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

spoon.template.StatementTemplate Maven / Gradle / Ivy

/*
 * SPDX-License-Identifier: (MIT OR CECILL-C)
 *
 * Copyright (C) 2006-2019 INRIA and contributors
 *
 * Spoon is available either under the terms of the MIT License (see LICENSE-MIT.txt) of the Cecill-C License (see LICENSE-CECILL-C.txt). You as the user are entitled to choose the terms under which to adopt Spoon.
 */
package spoon.template;

import spoon.reflect.code.CtStatement;
import spoon.reflect.declaration.CtClass;
import spoon.reflect.declaration.CtType;

import java.util.List;

/**
 * This class represents a template parameter that defines a statement list
 * directly expressed in Java (no returns).
 *
 * 

* To define a new statement list template parameter, you must subclass this * class and implement the {@link #statement()} method, which actually defines * the Java statements. It corresponds to a * {@link spoon.reflect.code.CtStatementList}. */ public abstract class StatementTemplate extends AbstractTemplate { /** * Creates a new statement list template parameter. */ public StatementTemplate() { } @Override public CtStatement apply(CtType targetType) { CtClass c = Substitution.getTemplateCtClass(targetType.getFactory(), this); // we substitute the first statement of method statement CtStatement patternModel = c.getMethod("statement").getBody().getStatements().get(0); List statements = TemplateBuilder.createTemplateBuilder(patternModel, this) .setAddGeneratedBy(isAddGeneratedBy()) .substituteList(c.getFactory(), targetType, CtStatement.class); if (statements.size() != 1) { throw new IllegalStateException(); } return statements.get(0); } public Void S() { return null; } /** * This method must be implemented to define the template statement list. */ public abstract void statement() throws Throwable; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy