/** * 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.declaration; import spoon.reflect.declaration.CtConstructor; import spoon.reflect.declaration.CtFormalTypeDeclarer; import spoon.reflect.declaration.CtModifiable; import spoon.reflect.declaration.CtNamedElement; import spoon.reflect.declaration.CtShadowable; import spoon.reflect.declaration.CtType; import spoon.reflect.declaration.CtTypeParameter; import spoon.reflect.declaration.CtTypedElement; import spoon.reflect.declaration.ModifierKind; import spoon.reflect.reference.CtTypeParameterReference; import spoon.reflect.reference.CtTypeReference; import spoon.reflect.visitor.CtVisitor; import spoon.support.DerivedProperty; import spoon.support.UnsettableProperty; import java.util.ArrayList; import java.util.EnumSet; import java.util.List; import java.util.Set; import static spoon.reflect.ModelElementContainerDefaultCapacities.TYPE_TYPE_PARAMETERS_CONTAINER_DEFAULT_CAPACITY; public class CtConstructorImpl<T> extends CtExecutableImpl<T> implements CtConstructor<T> { private static final long serialVersionUID = 1L; List<CtTypeParameterReference> formalTypeParameters = emptyList(); List<CtTypeParameter> formalCtTypeParameters = emptyList(); Set<ModifierKind> modifiers = CtElementImpl.emptySet(); @Override public void accept(CtVisitor visitor) { visitor.visitCtConstructor(this); } @Override @UnsettableProperty public <C extends CtNamedElement> C setSimpleName(String simpleName) { return (C) this; } @Override public String getSimpleName() { return "<init>"; } @Override @SuppressWarnings("unchecked") public CtType<T> getDeclaringType() { return (CtType<T>) parent; } @Override @DerivedProperty public CtTypeReference<T> getType() { if (getDeclaringType() == null) { return null; } return getDeclaringType().getReference(); } @Override @UnsettableProperty public <C extends CtTypedElement> C setType(CtTypeReference<T> type) { // unsettable property return (C) this; } @Override public List<CtTypeParameter> getFormalCtTypeParameters() { return formalCtTypeParameters; } @Override public <C extends CtFormalTypeDeclarer> C setFormalCtTypeParameters(List<CtTypeParameter> formalTypeParameters) { if (formalTypeParameters == null || formalTypeParameters.isEmpty()) { this.formalCtTypeParameters = CtElementImpl.emptyList(); return (C) this; } if (this.formalCtTypeParameters == CtElementImpl.<CtTypeParameter>emptyList()) { this.formalCtTypeParameters = new ArrayList<>(TYPE_TYPE_PARAMETERS_CONTAINER_DEFAULT_CAPACITY); } this.formalCtTypeParameters.clear(); for (CtTypeParameter formalTypeParameter : formalTypeParameters) { addFormalCtTypeParameter(formalTypeParameter); } return (C) this; } @Override public <C extends CtFormalTypeDeclarer> C addFormalCtTypeParameter(CtTypeParameter formalTypeParameter) { if (formalTypeParameter == null) { return (C) this; } if (formalCtTypeParameters == CtElementImpl.<CtTypeParameter>emptyList()) { formalCtTypeParameters = new ArrayList<>(TYPE_TYPE_PARAMETERS_CONTAINER_DEFAULT_CAPACITY); } formalTypeParameter.setParent(this); formalCtTypeParameters.add(formalTypeParameter); return (C) this; } @Override public boolean removeFormalCtTypeParameter(CtTypeParameter formalTypeParameter) { return formalCtTypeParameters.contains(formalTypeParameter) && formalCtTypeParameters.remove(formalTypeParameter); } @Override public Set<ModifierKind> getModifiers() { return modifiers; } @Override public boolean hasModifier(ModifierKind modifier) { return getModifiers().contains(modifier); } @Override public <C extends CtModifiable> C setModifiers(Set<ModifierKind> modifiers) { if (modifiers.size() > 0) { this.modifiers = EnumSet.copyOf(modifiers); } return (C) this; } @Override public <C extends CtModifiable> C addModifier(ModifierKind modifier) { if (modifiers == CtElementImpl.<ModifierKind>emptySet()) { this.modifiers = EnumSet.noneOf(ModifierKind.class); } modifiers.add(modifier); return (C) this; } @Override public boolean removeModifier(ModifierKind modifier) { return !modifiers.isEmpty() && modifiers.remove(modifier); } @Override public <C extends CtModifiable> C setVisibility(ModifierKind visibility) { if (modifiers == CtElementImpl.<ModifierKind>emptySet()) { this.modifiers = EnumSet.noneOf(ModifierKind.class); } getModifiers().remove(ModifierKind.PUBLIC); getModifiers().remove(ModifierKind.PROTECTED); getModifiers().remove(ModifierKind.PRIVATE); getModifiers().add(visibility); return (C) this; } @Override public ModifierKind getVisibility() { if (getModifiers().contains(ModifierKind.PUBLIC)) { return ModifierKind.PUBLIC; } if (getModifiers().contains(ModifierKind.PROTECTED)) { return ModifierKind.PROTECTED; } if (getModifiers().contains(ModifierKind.PRIVATE)) { return ModifierKind.PRIVATE; } return null; } boolean isShadow; @Override public boolean isShadow() { return isShadow; } @Override public <E extends CtShadowable> E setShadow(boolean isShadow) { this.isShadow = isShadow; return (E) this; } @Override public CtConstructor<T> clone() { return (CtConstructor<T>) super.clone(); } }