com.speedment.common.codegen.internal.model.ClassOrInterfaceImpl Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of generator-deploy Show documentation
Show all versions of generator-deploy Show documentation
A Speedment bundle that shades all dependencies into one jar. This is
useful when deploying an application on a server.
The newest version!
/*
*
* Copyright (c) 2006-2019, 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.HasClasses;
import java.lang.reflect.Type;
import java.util.*;
import static java.util.Objects.requireNonNull;
/**
* This is the abstract base implementation used by the classes {@link ClassImpl},
* {@link EnumImpl} and {@link InterfaceImpl} to share functionality.
*
* @author Emil Forslund
* @param The extending type
*/
public abstract class ClassOrInterfaceImpl>
implements ClassOrInterface {
private HasClasses parent;
private String name;
private Javadoc javadoc;
private final List imports;
private final List annotations;
private final List generics;
private final List interfaces;
private final List fields;
private final List methods;
private final List initalizers;
private final List> classes;
private final Set modifiers;
/**
* Initializes this model.
*
* @param name the name
*/
ClassOrInterfaceImpl(String name) {
this.name = requireNonNull(name);
this.javadoc = null;
this.imports = new ArrayList<>();
this.annotations = new ArrayList<>();
this.generics = new ArrayList<>();
this.interfaces = new ArrayList<>();
this.fields = new ArrayList<>();
this.methods = new ArrayList<>();
this.initalizers = new ArrayList<>();
this.classes = new ArrayList<>();
this.modifiers = EnumSet.noneOf(Modifier.class);
}
/**
* Copy constructor.
*
* @param prototype the prototype
*/
ClassOrInterfaceImpl(ClassOrInterface prototype) {
name = requireNonNull(prototype).getName();
javadoc = prototype.getJavadoc().map(Copier::copy).orElse(null);
imports = Copier.copy(prototype.getImports());
annotations = Copier.copy(prototype.getAnnotations());
generics = Copier.copy(prototype.getGenerics());
interfaces = new ArrayList<>(prototype.getInterfaces());
fields = Copier.copy(prototype.getFields());
methods = Copier.copy(prototype.getMethods());
initalizers = Copier.copy(prototype.getInitializers());
classes = Copier.copy(prototype.getClasses(), c -> c.copy());
modifiers = Copier.copy(prototype.getModifiers(), c -> c.copy(), EnumSet.noneOf(Modifier.class));
}
@Override
@SuppressWarnings("unchecked")
public T setParent(HasClasses parent) {
this.parent = parent;
return (T) this;
}
@Override
public Optional> getParent() {
return Optional.ofNullable(parent);
}
@Override
@SuppressWarnings("unchecked")
public T setName(String name) {
this.name = requireNonNull(name);
return (T) this;
}
@Override
public String getName() {
return name;
}
@Override
@SuppressWarnings("unchecked")
public T set(Javadoc doc) {
javadoc = doc.setParent(this);
return (T) this;
}
@Override
public Optional getJavadoc() {
return Optional.ofNullable(javadoc);
}
@Override
public List getImports() {
return imports;
}
@Override
public List getMethods() {
return methods;
}
@Override
public List getFields() {
return fields;
}
@Override
public List getInterfaces() {
return interfaces;
}
@Override
public Set getModifiers() {
return modifiers;
}
@Override
public List getGenerics() {
return generics;
}
@Override
public List getAnnotations() {
return annotations;
}
@Override
public List> getClasses() {
return classes;
}
@Override
public List getInitializers() {
return initalizers;
}
@Override
public int hashCode() {
int hash = 7;
hash = 37 * hash + Objects.hashCode(this.name);
hash = 37 * hash + Objects.hashCode(this.javadoc);
hash = 37 * hash + Objects.hashCode(this.annotations);
hash = 37 * hash + Objects.hashCode(this.generics);
hash = 37 * hash + Objects.hashCode(this.interfaces);
hash = 37 * hash + Objects.hashCode(this.fields);
hash = 37 * hash + Objects.hashCode(this.methods);
hash = 37 * hash + Objects.hashCode(this.initalizers);
hash = 37 * hash + Objects.hashCode(this.classes);
hash = 37 * hash + Objects.hashCode(this.modifiers);
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 ClassOrInterfaceImpl other = (ClassOrInterfaceImpl) obj;
if (!Objects.equals(this.name, other.name)) {
return false;
}
if (!Objects.equals(this.javadoc, other.javadoc)) {
return false;
}
if (!Objects.equals(this.annotations, other.annotations)) {
return false;
}
if (!Objects.equals(this.generics, other.generics)) {
return false;
}
if (!Objects.equals(this.interfaces, other.interfaces)) {
return false;
}
if (!Objects.equals(this.fields, other.fields)) {
return false;
}
if (!Objects.equals(this.methods, other.methods)) {
return false;
}
if (!Objects.equals(this.initalizers, other.initalizers)) {
return false;
}
if (!Objects.equals(this.classes, other.classes)) {
return false;
}
return Objects.equals(this.modifiers, other.modifiers);
}
}