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.ClassRenderer;
13 import org.opendaylight.mdsal.binding.javav2.java.api.generator.renderers.UnionBuilderRenderer;
14 import org.opendaylight.mdsal.binding.javav2.java.api.generator.renderers.UnionRenderer;
15 import org.opendaylight.mdsal.binding.javav2.model.api.CodeGenerator;
16 import org.opendaylight.mdsal.binding.javav2.model.api.GeneratedTransferObject;
17 import org.opendaylight.mdsal.binding.javav2.model.api.Type;
18 import org.opendaylight.mdsal.binding.javav2.model.api.UnitName;
19 import org.opendaylight.yangtools.concepts.Identifier;
22 * Transformer of the data from the virtual form to JAVA source code. The
23 * result source code represents JAVA class. For generating of the source code
24 * is used the template written in Twirl (Scala based) language.
27 public class TOGenerator implements CodeGenerator {
30 public String generate(Type type) {
31 if (type instanceof GeneratedTransferObject) {
32 final GeneratedTransferObject genTO = (GeneratedTransferObject) type;
33 if(genTO.isUnionType()) {
34 return new UnionRenderer(genTO).generateTemplate();
35 } else if (genTO.isUnionTypeBuilder()) {
36 return new UnionBuilderRenderer(genTO).generateTemplate();
38 return new ClassRenderer(genTO).generateTemplate();
45 public boolean isAcceptable(Type type) {
46 return type instanceof GeneratedTransferObject;
50 public Identifier getUnitName(Type type) {
51 return new UnitName(type.getName());