/** * Copyright (C) 2006-2017 INRIA and contributors * Spoon - http://spoon.gforge.inria.fr/ * * This software is governed by the CeCILL-C License under French law and * abiding by the rules of distribution of free software. You can use, modify * and/or redistribute the software under the terms of the CeCILL-C license as * circulated by CEA, CNRS and INRIA at http://www.cecill.info. * * This program 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 CeCILL-C License for more details. * * The fact that you are presently reading this means that you have had * knowledge of the CeCILL-C license and that you accept its terms. */ package spoon.support.reflect.code; import spoon.reflect.code.CtAssignment; import spoon.reflect.code.CtExpression; import spoon.reflect.code.CtRHSReceiver; import spoon.reflect.declaration.CtElement; import spoon.reflect.declaration.CtTypedElement; import spoon.reflect.reference.CtTypeReference; import spoon.reflect.visitor.CtVisitor; import spoon.support.reflect.declaration.CtElementImpl; import java.util.ArrayList; import java.util.List; import static spoon.reflect.ModelElementContainerDefaultCapacities.CASTS_CONTAINER_DEFAULT_CAPACITY; public class CtAssignmentImpl<T, A extends T> extends CtStatementImpl implements CtAssignment<T, A> { private static final long serialVersionUID = 1L; CtExpression<T> assigned; CtExpression<A> assignment; CtTypeReference<T> type; List<CtTypeReference<?>> typeCasts = emptyList(); @Override public void accept(CtVisitor visitor) { visitor.visitCtAssignment(this); } @Override public CtExpression<T> getAssigned() { return assigned; } @Override public CtExpression<A> getAssignment() { return assignment; } @Override public CtTypeReference<T> getType() { return type; } @Override public List<CtTypeReference<?>> getTypeCasts() { return typeCasts; } @Override public <C extends CtAssignment<T, A>> C setAssigned(CtExpression<T> assigned) { if (assigned != null) { assigned.setParent(this); } this.assigned = assigned; return (C) this; } @Override public <C extends CtRHSReceiver<A>> C setAssignment(CtExpression<A> assignment) { if (assignment != null) { assignment.setParent(this); } this.assignment = assignment; return (C) this; } @Override public <C extends CtTypedElement> C setType(CtTypeReference<T> type) { if (type != null) { type.setParent(this); } this.type = type; return (C) this; } @Override public <C extends CtExpression<T>> C setTypeCasts(List<CtTypeReference<?>> casts) { if (casts == null || casts.isEmpty()) { this.typeCasts = CtElementImpl.emptyList(); return (C) this; } if (this.typeCasts == CtElementImpl.<CtTypeReference<?>>emptyList()) { this.typeCasts = new ArrayList<>(CASTS_CONTAINER_DEFAULT_CAPACITY); } this.typeCasts.clear(); for (CtTypeReference<?> cast : casts) { addTypeCast(cast); } return (C) this; } @Override public <C extends CtExpression<T>> C addTypeCast(CtTypeReference<?> type) { if (type == null) { return (C) this; } if (typeCasts == CtElementImpl.<CtTypeReference<?>>emptyList()) { typeCasts = new ArrayList<>(CASTS_CONTAINER_DEFAULT_CAPACITY); } type.setParent(this); typeCasts.add(type); return (C) this; } @Override public <E extends T> void replace(CtExpression<E> element) { replace((CtElement) element); } @Override public T S() { return null; } @Override public CtAssignment<T, A> clone() { return (CtAssignment<T, A>) super.clone(); } }