2 * Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
8 package org.opendaylight.controller.binding.generator.util.generated.type.builder;
10 import org.opendaylight.controller.binding.generator.util.AbstractBaseType;
11 import org.opendaylight.controller.sal.binding.model.api.AccessModifier;
12 import org.opendaylight.controller.sal.binding.model.api.Constant;
13 import org.opendaylight.controller.sal.binding.model.api.Type;
14 import org.opendaylight.controller.sal.binding.model.api.type.builder.*;
16 import java.util.ArrayList;
17 import java.util.List;
19 abstract class AbstractGeneratedTypeBuilder extends AbstractBaseType implements GeneratedTypeBuilder {
21 private final String packageName;
22 private String comment = "";
23 private final String name;
25 private final List<AnnotationTypeBuilder> annotationBuilders = new ArrayList<>();
26 private final List<Type> implementsTypes = new ArrayList<>();
27 private final List<EnumBuilder> enumDefinitions = new ArrayList<>();
28 private final List<Constant> constants = new ArrayList<>();
29 private final List<MethodSignatureBuilder> methodDefinitions = new ArrayList<>();
30 private final List<GeneratedTypeBuilder> enclosedTypes = new ArrayList<>();
31 private final List<GeneratedTOBuilder> enclosingTransferObjects = new ArrayList<>();
32 private boolean isAbstract;
34 public AbstractGeneratedTypeBuilder(final String packageName, final String name) {
35 super(packageName, name);
36 if (packageName == null) {
37 throw new IllegalArgumentException("Package Name for Generated Type cannot be null!");
40 throw new IllegalArgumentException("Name of Generated Type cannot be null!");
42 this.packageName = packageName;
46 protected String getComment() {
50 protected List<AnnotationTypeBuilder> getAnnotations() {
51 return annotationBuilders;
54 protected boolean isAbstract() {
58 protected List<Type> getImplementsTypes() {
59 return implementsTypes;
62 protected List<EnumBuilder> getEnumerations() {
63 return enumDefinitions;
66 protected List<Constant> getConstants() {
70 protected List<MethodSignatureBuilder> getMethodDefinitions() {
71 return methodDefinitions;
74 protected List<GeneratedTypeBuilder> getEnclosedTypes() {
78 protected List<GeneratedTOBuilder> getEnclosedTransferObjects() {
79 return enclosingTransferObjects;
83 public GeneratedTypeBuilder addEnclosingType(String name) {
85 throw new IllegalArgumentException("Name for Enclosing Generated Type cannot be null!");
87 GeneratedTypeBuilder builder = new GeneratedTOBuilderImpl(getFullyQualifiedName(), name);
88 enclosedTypes.add(builder);
93 public GeneratedTOBuilder addEnclosingTransferObject(String name) {
95 throw new IllegalArgumentException("Name for Enclosing Generated Transfer Object cannot be null!");
97 GeneratedTOBuilder builder = new GeneratedTOBuilderImpl(getFullyQualifiedName(), name);
98 enclosingTransferObjects.add(builder);
103 public void addEnclosingTransferObject(final GeneratedTOBuilder genTOBuilder) {
104 if (genTOBuilder == null) {
105 throw new IllegalArgumentException("Parameter genTOBuilder cannot be null!");
107 enclosingTransferObjects.add(genTOBuilder);
111 public void addComment(String comment) {
112 this.comment = comment;
116 public AnnotationTypeBuilder addAnnotation(final String packageName, final String name) {
117 if (packageName == null) {
118 throw new IllegalArgumentException("Package Name for Annotation Type cannot be null!");
121 throw new IllegalArgumentException("Name of Annotation Type cannot be null!");
124 final AnnotationTypeBuilder builder = new AnnotationTypeBuilderImpl(packageName, name);
125 annotationBuilders.add(builder);
130 public void setAbstract(boolean isAbstract) {
131 this.isAbstract = isAbstract;
135 public boolean addImplementsType(Type genType) {
136 if (genType == null) {
137 throw new IllegalArgumentException("Type cannot be null");
139 return implementsTypes.add(genType);
143 public Constant addConstant(Type type, String name, Object value) {
145 throw new IllegalArgumentException("Returning Type for Constant cannot be null!");
148 throw new IllegalArgumentException("Name of constant cannot be null!");
151 final Constant constant = new ConstantImpl(this, type, name, value);
152 constants.add(constant);
157 public EnumBuilder addEnumeration(String name) {
159 throw new IllegalArgumentException("Name of enumeration cannot be null!");
161 final EnumBuilder builder = new EnumerationBuilderImpl(getFullyQualifiedName(), name);
162 enumDefinitions.add(builder);
167 public MethodSignatureBuilder addMethod(String name) {
169 throw new IllegalArgumentException("Name of method cannot be null!");
171 final MethodSignatureBuilder builder = new MethodSignatureBuilderImpl(name);
172 builder.setAccessModifier(AccessModifier.PUBLIC);
173 builder.setAbstract(true);
174 methodDefinitions.add(builder);
179 public boolean containsMethod(String name) {
181 throw new IllegalArgumentException("Parameter name can't be null");
183 for (MethodSignatureBuilder methodDefinition : methodDefinitions) {
184 if (name.equals(methodDefinition.getName())) {
192 public int hashCode() {
193 final int prime = 31;
195 result = prime * result + ((getName() == null) ? 0 : getName().hashCode());
196 result = prime * result + ((getPackageName() == null) ? 0 : getPackageName().hashCode());
201 public boolean equals(Object obj) {
208 if (getClass() != obj.getClass()) {
211 AbstractGeneratedTypeBuilder other = (AbstractGeneratedTypeBuilder) obj;
212 if (getName() == null) {
213 if (other.getName() != null) {
216 } else if (!getName().equals(other.getName())) {
219 if (getPackageName() == null) {
220 if (other.getPackageName() != null) {
223 } else if (!getPackageName().equals(other.getPackageName())) {