2 * Copyright (c) 2014 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.mdsal.binding.java.api.generator;
10 import com.google.common.annotations.VisibleForTesting;
11 import org.opendaylight.mdsal.binding.model.api.CodeGenerator;
12 import org.opendaylight.mdsal.binding.model.api.GeneratedTransferObject;
13 import org.opendaylight.mdsal.binding.model.api.GeneratedType;
14 import org.opendaylight.mdsal.binding.model.api.JavaTypeName;
15 import org.opendaylight.mdsal.binding.model.api.MethodSignature;
16 import org.opendaylight.mdsal.binding.model.api.Type;
17 import org.opendaylight.mdsal.binding.model.ri.generated.type.builder.CodegenGeneratedTOBuilder;
18 import org.opendaylight.mdsal.binding.model.ri.generated.type.builder.CodegenGeneratedTypeBuilder;
19 import org.opendaylight.yangtools.yang.binding.Augmentable;
20 import org.opendaylight.yangtools.yang.binding.Augmentation;
21 import org.opendaylight.yangtools.yang.binding.YangData;
22 import org.opendaylight.yangtools.yang.binding.contract.Naming;
25 * Transformator of the data from the virtual form to JAVA programming language. The result source code represent java
26 * class. For generation of the source code is used the template written in XTEND language.
28 public final class BuilderGenerator implements CodeGenerator {
29 private static final JavaTypeName AUGMENTABLE = JavaTypeName.create(Augmentable.class);
30 private static final JavaTypeName AUGMENTATION = JavaTypeName.create(Augmentation.class);
31 private static final JavaTypeName YANG_DATA = JavaTypeName.create(YangData.class);
34 * Passes via list of implemented types in <code>type</code>.
36 * @param type JAVA <code>Type</code>
37 * @return boolean value which is true if any of implemented types is of the type <code>Augmentable</code>.
40 public boolean isAcceptable(final Type type) {
41 if (type instanceof GeneratedType generated && !(type instanceof GeneratedTransferObject)) {
42 for (Type t : generated.getImplements()) {
43 // "rpc" and "grouping" elements do not implement Augmentable
44 final JavaTypeName name = t.getIdentifier();
45 if (name.equals(AUGMENTABLE) || name.equals(AUGMENTATION) || name.equals(YANG_DATA)) {
54 * Generates JAVA source code for generated type <code>Type</code>. The code is generated according to the template
55 * source code template which is written in XTEND language.
58 public String generate(final Type type) {
59 if (type instanceof GeneratedType generated && !(type instanceof GeneratedTransferObject)) {
60 return templateForType(generated).generate();
66 public String getUnitName(final Type type) {
67 return type.getName() + Naming.BUILDER_SUFFIX;
71 static BuilderTemplate templateForType(final GeneratedType type) {
72 final JavaTypeName origName = type.getIdentifier();
73 final JavaTypeName builderName = origName.createSibling(origName.simpleName() + Naming.BUILDER_SUFFIX);
75 return new BuilderTemplate(new CodegenGeneratedTypeBuilder(builderName)
76 .addEnclosingTransferObject(new CodegenGeneratedTOBuilder(
77 builderName.createEnclosed(origName.simpleName() + "Impl"))
78 .addImplementsType(type)
80 .build(), type, getKey(type));
83 private static Type getKey(final GeneratedType type) {
84 for (MethodSignature m : type.getMethodDefinitions()) {
85 if (Naming.IDENTIFIABLE_KEY_NAME.equals(m.getName())) {
86 return m.getReturnType();