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

com.speedment.common.codegen.internal.model.MethodImpl Maven / Gradle / Ivy

/*
 *
 * Copyright (c) 2006-2020, Speedment, Inc. All Rights Reserved.
 *
 * Licensed under the Apache License, Version 2.0 (the "License"); You may not
 * use this file except in compliance with the License. You may obtain a copy of
 * the License at:
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 * License for the specific language governing permissions and limitations under
 * the License.
 */
package com.speedment.common.codegen.internal.model;

import com.speedment.common.codegen.internal.util.Copier;
import com.speedment.common.codegen.model.*;
import com.speedment.common.codegen.model.modifier.Modifier;
import com.speedment.common.codegen.model.trait.HasMethods;

import java.lang.reflect.Type;
import java.util.*;

import static java.util.Objects.requireNonNull;

/**
 * This is the default implementation of the {@link Method} interface. This
 * class should not be instantiated directly. Instead you should call the
 * {@link Method#of(String, Type)} method to get an instance. In that way, you
 * can later change the implementing class without modifying the using code.
 *
 * @author Emil Forslund
 * @see Method
 */
public final class MethodImpl implements Method {

    private HasMethods parent;
    private String name;
    private Type type;
    private Javadoc javadoc;
    private final List annotations;
    private final List imports;
    private final List generics;
    private final List params;
    private final List code;
    private final Set modifiers;
    private final Set exceptions;

    /**
     * Initializes this method using a name and a type.
     * 

* Warning! This class should not be instantiated directly but using * the {@link Method#of(String, Type)} method! * * @param name the name * @param type the type */ public MethodImpl(String name, Type type) { this.name = requireNonNull(name); this.type = requireNonNull(type); this.javadoc = null; this.annotations = new ArrayList<>(); this.imports = new ArrayList<>(); this.generics = new ArrayList<>(); this.params = new ArrayList<>(); this.code = new ArrayList<>(); this.modifiers = EnumSet.noneOf(Modifier.class); this.exceptions = new HashSet<>(); } /** * Copy constructor. * * @param prototype the prototype */ protected MethodImpl(final Method prototype) { parent = prototype.getParent().orElse(null); name = requireNonNull(prototype).getName(); type = requireNonNull(prototype.getType()); javadoc = prototype.getJavadoc().map(Copier::copy).orElse(null); annotations = Copier.copy(prototype.getAnnotations()); imports = Copier.copy(prototype.getImports()); generics = Copier.copy(prototype.getGenerics()); params = Copier.copy(prototype.getFields()); code = Copier.copy(prototype.getCode(), s -> s); modifiers = Copier.copy(prototype.getModifiers(), Modifier::copy, EnumSet.noneOf(Modifier.class)); exceptions = new HashSet<>(prototype.getExceptions()); } @Override public Method setParent(HasMethods parent) { this.parent = parent; return this; } @Override public Optional> getParent() { return Optional.ofNullable(parent); } @Override public String getName() { return name; } @Override public Method setName(String name) { this.name = requireNonNull(name); return this; } @Override public List getImports() { return imports; } @Override public Type getType() { return type; } @Override public Method set(Type type) { this.type = requireNonNull(type); return this; } @Override public List getFields() { return params; } @Override public List getCode() { return code; } @Override public Set getModifiers() { return modifiers; } @Override public Method set(Javadoc doc) { javadoc = doc.setParent(this); return this; } @Override public Optional getJavadoc() { return Optional.ofNullable(javadoc); } @Override public List getAnnotations() { return annotations; } @Override public List getGenerics() { return generics; } @Override public Set getExceptions() { return exceptions; } @Override public MethodImpl copy() { return new MethodImpl(this); } @Override public int hashCode() { int hash = 7; hash = 71 * hash + HashUtil.identityHashForParent(this); hash = 71 * hash + Objects.hashCode(this.name); hash = 71 * hash + Objects.hashCode(this.type); hash = 71 * hash + Objects.hashCode(this.javadoc); hash = 71 * hash + Objects.hashCode(this.annotations); hash = 71 * hash + Objects.hashCode(this.imports); hash = 71 * hash + Objects.hashCode(this.generics); hash = 71 * hash + Objects.hashCode(this.params); hash = 71 * hash + Objects.hashCode(this.code); hash = 71 * hash + Objects.hashCode(this.modifiers); hash = 71 * hash + Objects.hashCode(this.exceptions); return hash; } @Override public boolean equals(Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (getClass() != obj.getClass()) { return false; } final MethodImpl other = (MethodImpl) obj; if (!Objects.equals(this.parent, other.parent)) { return false; } if (!Objects.equals(this.name, other.name)) { return false; } if (!Objects.equals(this.type, other.type)) { return false; } if (!Objects.equals(this.javadoc, other.javadoc)) { return false; } if (!Objects.equals(this.annotations, other.annotations)) { return false; } if (!Objects.equals(this.imports, other.imports)) { return false; } if (!Objects.equals(this.generics, other.generics)) { return false; } if (!Objects.equals(this.params, other.params)) { return false; } if (!Objects.equals(this.code, other.code)) { return false; } if (!Objects.equals(this.modifiers, other.modifiers)) { return false; } return Objects.equals(this.exceptions, other.exceptions); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy