X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fsal%2Fyang-prototype%2Fcode-generator%2Fbinding-java-api-generator%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fsal%2Fjava%2Fapi%2Fgenerator%2FGeneratorJavaFile.java;h=1d2e60f511fc970b4ad931e521fe4cdeffba002f;hb=2f14a41bbd09010114116aef1499641f7251bf83;hp=ab103b471e8fc076609308078aa1bba98b3f3a11;hpb=37ff82351675cc5c279dfe88c6daf10cbbf9f48b;p=controller.git diff --git a/opendaylight/sal/yang-prototype/code-generator/binding-java-api-generator/src/main/java/org/opendaylight/controller/sal/java/api/generator/GeneratorJavaFile.java b/opendaylight/sal/yang-prototype/code-generator/binding-java-api-generator/src/main/java/org/opendaylight/controller/sal/java/api/generator/GeneratorJavaFile.java index ab103b471e..1d2e60f511 100644 --- a/opendaylight/sal/yang-prototype/code-generator/binding-java-api-generator/src/main/java/org/opendaylight/controller/sal/java/api/generator/GeneratorJavaFile.java +++ b/opendaylight/sal/yang-prototype/code-generator/binding-java-api-generator/src/main/java/org/opendaylight/controller/sal/java/api/generator/GeneratorJavaFile.java @@ -7,53 +7,45 @@ */ package org.opendaylight.controller.sal.java.api.generator; -import java.io.BufferedWriter; -import java.io.File; -import java.io.FileWriter; -import java.io.IOException; -import java.io.Writer; +import java.io.*; import java.util.ArrayList; import java.util.HashSet; import java.util.List; import java.util.Set; -import org.opendaylight.controller.sal.binding.model.api.CodeGenerator; -import org.opendaylight.controller.sal.binding.model.api.Enumeration; -import org.opendaylight.controller.sal.binding.model.api.GeneratedTransferObject; -import org.opendaylight.controller.sal.binding.model.api.GeneratedType; -import org.opendaylight.controller.sal.binding.model.api.Type; +import org.opendaylight.controller.sal.binding.model.api.*; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public final class GeneratorJavaFile { - private static final Logger log = LoggerFactory - .getLogger(GeneratorJavaFile.class); + private static final Logger log = LoggerFactory.getLogger(GeneratorJavaFile.class); private final CodeGenerator interfaceGenerator; private final ClassCodeGenerator classGenerator; private final EnumGenerator enumGenerator; - + private final BuilderGenerator builderGenerator; + private final Set genTypes; private final Set genTransferObjects; - private final Set enumerations; + private final Set enumerations; - public GeneratorJavaFile(final CodeGenerator codeGenerator, - final Set types) { + public GeneratorJavaFile(final CodeGenerator codeGenerator, final Set types) { this.interfaceGenerator = codeGenerator; this.genTypes = types; this.genTransferObjects = new HashSet<>(); this.enumerations = new HashSet<>(); this.classGenerator = new ClassCodeGenerator(); this.enumGenerator = new EnumGenerator(); + this.builderGenerator = new BuilderGenerator(); } - public GeneratorJavaFile(final Set types, - final Set genTransferObjects, + public GeneratorJavaFile(final Set types, final Set genTransferObjects, final Set enumerations) { this.interfaceGenerator = new InterfaceGenerator(); this.classGenerator = new ClassCodeGenerator(); this.enumGenerator = new EnumGenerator(); - + this.builderGenerator = new BuilderGenerator(); + this.genTypes = types; this.genTransferObjects = genTransferObjects; this.enumerations = enumerations; @@ -62,57 +54,56 @@ public final class GeneratorJavaFile { public List generateToFile(final File parentDirectory) throws IOException { final List result = new ArrayList<>(); for (GeneratedType type : genTypes) { - final File genFile = generateTypeToJavaFile(parentDirectory, type, - interfaceGenerator); + final File genFile = generateTypeToJavaFile(parentDirectory, type, interfaceGenerator, ""); + final File genBuilderFile = generateTypeToJavaFile(parentDirectory, type, builderGenerator, + BuilderGenerator.FILE_NAME_SUFFIX); if (genFile != null) { result.add(genFile); } + if (genBuilderFile != null) { + result.add(genBuilderFile); + } } for (GeneratedTransferObject transferObject : genTransferObjects) { - final File genFile = generateTypeToJavaFile(parentDirectory, - transferObject, classGenerator); + final File genFile = generateTypeToJavaFile(parentDirectory, transferObject, classGenerator, ""); if (genFile != null) { result.add(genFile); } } - + for (Enumeration enumeration : enumerations) { - final File genFile = generateTypeToJavaFile(parentDirectory, - enumeration, enumGenerator); + final File genFile = generateTypeToJavaFile(parentDirectory, enumeration, enumGenerator, ""); if (genFile != null) { result.add(genFile); } } - + return result; } - private File generateTypeToJavaFile(final File parentDir, final Type type, - final CodeGenerator generator) throws IOException { + private File generateTypeToJavaFile(final File parentDir, final Type type, final CodeGenerator generator, String fileNameSuffix) + throws IOException { if (parentDir == null) { log.warn("Parent Directory not specified, files will be generated " + "accordingly to generated Type package path."); } if (type == null) { - log.error("Cannot generate Type into Java File because " + - "Generated Type is NULL!"); + log.error("Cannot generate Type into Java File because " + "Generated Type is NULL!"); throw new IllegalArgumentException("Generated Type Cannot be NULL!"); } if (generator == null) { - log.error("Cannot generate Type into Java File because " + - "Code Generator instance is NULL!"); + log.error("Cannot generate Type into Java File because " + "Code Generator instance is NULL!"); throw new IllegalArgumentException("Code Generator Cannot be NULL!"); } - final File packageDir = packageToDirectory(parentDir, - type.getPackageName()); + final File packageDir = packageToDirectory(parentDir, type.getPackageName()); if (!packageDir.exists()) { packageDir.mkdirs(); } - final File file = new File(packageDir, type.getName() + ".java"); + final File file = new File(packageDir, type.getName() + fileNameSuffix + ".java"); try (final FileWriter fw = new FileWriter(file)) { file.createNewFile(); @@ -127,8 +118,7 @@ public final class GeneratorJavaFile { return file; } - private File packageToDirectory(final File parentDirectory, - final String packageName) { + private File packageToDirectory(final File parentDirectory, final String packageName) { if (packageName == null) { throw new IllegalArgumentException("Package Name cannot be NULL!"); }