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.slf4j.Logger;
import org.slf4j.LoggerFactory;
-public class GeneratorJavaFile {
+public final class GeneratorJavaFile {
private static final Logger log = LoggerFactory
.getLogger(GeneratorJavaFile.class);
private final CodeGenerator interfaceGenerator;
private final ClassCodeGenerator classGenerator;
+ private final EnumGenerator enumGenerator;
+
private final Set<GeneratedType> genTypes;
private final Set<GeneratedTransferObject> genTransferObjects;
+ private final Set<Enumeration> enumerations;
public GeneratorJavaFile(final CodeGenerator codeGenerator,
final Set<GeneratedType> types) {
this.interfaceGenerator = codeGenerator;
this.genTypes = types;
- this.genTransferObjects = new HashSet<GeneratedTransferObject>();
- classGenerator = new ClassCodeGenerator();
+ this.genTransferObjects = new HashSet<>();
+ this.enumerations = new HashSet<>();
+ this.classGenerator = new ClassCodeGenerator();
+ this.enumGenerator = new EnumGenerator();
}
public GeneratorJavaFile(final Set<GeneratedType> types,
- final Set<GeneratedTransferObject> genTransferObjects) {
+ final Set<GeneratedTransferObject> genTransferObjects,
+ final Set<Enumeration> enumerations) {
this.interfaceGenerator = new InterfaceGenerator();
this.classGenerator = new ClassCodeGenerator();
+ this.enumGenerator = new EnumGenerator();
+
this.genTypes = types;
this.genTransferObjects = genTransferObjects;
+ this.enumerations = enumerations;
}
- @Deprecated
- public List<File> generateToFile(String path) throws IOException {
- final List<File> result = new ArrayList<File>();
-
- for (GeneratedType genType : genTypes) {
- final String parentPath = generateParentPath(path,
- genType.getPackageName());
-
- final File directory = new File(parentPath);
- final File genFile = generateTypeToJavaFile(directory, genType,
+ public List<File> generateToFile(final File parentDirectory) throws IOException {
+ final List<File> result = new ArrayList<>();
+ for (GeneratedType type : genTypes) {
+ final File genFile = generateTypeToJavaFile(parentDirectory, type,
interfaceGenerator);
-
+
if (genFile != null) {
result.add(genFile);
}
}
-
for (GeneratedTransferObject transferObject : genTransferObjects) {
- final String parentPath = generateParentPath(path,
- transferObject.getPackageName());
-
- final File directory = new File(parentPath);
- final File genFile = generateTypeToJavaFile(directory,
+ final File genFile = generateTypeToJavaFile(parentDirectory,
transferObject, classGenerator);
if (genFile != null) {
result.add(genFile);
}
}
- return result;
- }
-
- public List<File> generateToFile(final File parentDirectory) throws IOException {
- final List<File> result = new ArrayList<File>();
- for (GeneratedType type : genTypes) {
- final File genFile = generateTypeToJavaFile(parentDirectory, type,
- interfaceGenerator);
-
- if (genFile != null) {
- result.add(genFile);
- }
- }
- for (GeneratedTransferObject transferObject : genTransferObjects) {
+
+ for (Enumeration enumeration : enumerations) {
final File genFile = generateTypeToJavaFile(parentDirectory,
- transferObject, classGenerator);
+ enumeration, enumGenerator);
if (genFile != null) {
result.add(genFile);
}
}
+
return result;
}
}
if (type == null) {
log.error("Cannot generate Type into Java File because " +
- "Generated Type is NULL!");
+ "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!");
+ "Code Generator instance is NULL!");
throw new IllegalArgumentException("Code Generator Cannot be NULL!");
}
final File packageDir = packageToDirectory(parentDir,
}
return new File(parentDirectory, dirPathBuilder.toString());
}
-
- @Deprecated
- private String generateParentPath(String path, String pkg) {
- List<String> dirs = new ArrayList<String>();
- String pkgPath = "";
- if (pkg != null) {
- if (pkg.length() > 0) {
- if (pkg.contains(".")) {
- String[] split = pkg.split("\\.");
- for (String dir : split) {
- dirs.add(dir);
- }
- } else {
- dirs.add(pkg);
- }
- for (int i = 0; i < dirs.size(); i++) {
- if (i == 0) {
- pkgPath += dirs.get(i);
- } else {
- pkgPath += File.separator + dirs.get(i);
- }
- }
- }
- }
- String fullPath = "";
- if (path != null) {
- if (path.endsWith(File.separator)) {
- fullPath = path + pkgPath;
- } else {
- fullPath = path + File.separator + pkgPath;
- }
- } else {
- fullPath = pkgPath;
- }
- return fullPath;
- }
}