2 * Copyright (c) 2017 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
9 package org.opendaylight.mdsal.binding.javav2.java.api.generator;
11 import com.google.common.annotations.Beta;
12 import org.opendaylight.mdsal.binding.javav2.java.api.generator.renderers.BuilderRenderer;
13 import org.opendaylight.mdsal.binding.javav2.model.api.CodeGenerator;
14 import org.opendaylight.mdsal.binding.javav2.model.api.GeneratedTransferObject;
15 import org.opendaylight.mdsal.binding.javav2.model.api.GeneratedType;
16 import org.opendaylight.mdsal.binding.javav2.model.api.GeneratedTypeForBuilder;
17 import org.opendaylight.mdsal.binding.javav2.model.api.Type;
18 import org.opendaylight.mdsal.binding.javav2.model.api.UnitName;
19 import org.opendaylight.mdsal.binding.javav2.spec.structural.Augmentable;
20 import org.opendaylight.mdsal.binding.javav2.spec.structural.Augmentation;
21 import org.opendaylight.yangtools.concepts.Identifier;
24 * Transformer of the data from the virtual form to JAVA programming language.
25 * The result source code represent java class. For generation of the source
26 * code is used the template written in Twirl (Scala based) language.
29 public final class BuilderGenerator implements CodeGenerator {
32 * Constant used as suffix for builder name.
34 public static final String BUILDER = "Builder";
37 public String generate(Type type) {
38 if (type instanceof GeneratedTypeForBuilder) {
39 final GeneratedType genType = (GeneratedType) type;
40 return new BuilderRenderer(genType).generateTemplate();
47 public boolean isAcceptable(Type type) {
48 return type instanceof GeneratedTypeForBuilder;
52 public Identifier getUnitName(Type type) {
53 return new UnitName(type.getName() + BUILDER);