Implemented use of ChildOf interface in generated classes.
[yangtools.git] / code-generator / binding-java-api-generator / src / main / java / org / opendaylight / yangtools / sal / java / api / generator / GeneratorJavaFile.java
index 895b1972c8bdcaa5f504d33d4fa10177d4b32d25..085fd1b018692b347cbd266bda4b56f1f95cd98a 100644 (file)
@@ -20,46 +20,100 @@ import org.opendaylight.yangtools.sal.binding.model.api.Type;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 
+/**
+ * Generates files with JAVA source codes for every specified type.
+ *
+ */
 public final class GeneratorJavaFile {
 
-    private static final Logger log = LoggerFactory.getLogger(GeneratorJavaFile.class);
+    private static final Logger LOG = LoggerFactory.getLogger(GeneratorJavaFile.class);
+
+    /**
+     * List of <code>CodeGenerator</code> instances.
+     */
     private final List<CodeGenerator> generators = new ArrayList<>();
 
+    /**
+     * Set of <code>Type</code> instances for which the JAVA code is generated.
+     */
     private final Set<? extends Type> types;
 
+    /**
+     * Creates instance of this class with the set of <code>types</code> for
+     * which the JAVA code is generated.
+     *
+     * The instances of concrete JAVA code generator are created.
+     *
+     * @param types
+     *            set of types for which JAVA code should be generated
+     */
     public GeneratorJavaFile(final Set<? extends Type> types) {
-       this.types = types;
-       generators.add(new InterfaceGenerator());
-       generators.add(new TOGenerator());
-       generators.add(new EnumGenerator());
-       generators.add(new BuilderGenerator());
+        this.types = types;
+        generators.add(new InterfaceGenerator());
+        generators.add(new TOGenerator());
+        generators.add(new EnumGenerator());
+        generators.add(new BuilderGenerator());
     }
 
+    /**
+     * Generates list of files with JAVA source code. Only the suitable code
+     * generator is used to generate the source code for the concrete type.
+     *
+     * @param parentDirectory
+     *            directory to which the output source codes should be generated
+     * @return list of output files
+     * @throws IOException
+     *             if the error during writting to the file occures
+     */
     public List<File> generateToFile(final File parentDirectory) throws IOException {
         final List<File> result = new ArrayList<>();
         for (Type type : types) {
-            for (CodeGenerator generator : generators) {
-                File generatedJavaFile = generateTypeToJavaFile(parentDirectory, type, generator);
-                if (generatedJavaFile != null) {
-                    result.add(generatedJavaFile);
+            if (type != null) {
+                for (CodeGenerator generator : generators) {
+                    File generatedJavaFile = generateTypeToJavaFile(parentDirectory, type, generator);
+                    if (generatedJavaFile != null) {
+                        result.add(generatedJavaFile);
+                    }
                 }
             }
         }
         return result;
     }
 
+    /**
+     * Generates <code>File</code> for <code>type</code>. All files are stored
+     * to subfolders of base directory <code>parentDir</code>. Subdirectories
+     * are generated according to packages to which the type belongs (e. g. if
+     * type belongs to the package <i>org.pcg</i> then in <code>parentDir</code>
+     * is created directory <i>org</i> which contains <i>pcg</i>).
+     *
+     * @param parentDir
+     *            directory where should be the new file generated
+     * @param type
+     *            JAVA <code>Type</code> for which should be JAVA source code
+     *            generated
+     * @param generator
+     *            code generator which is used for generating of the source code
+     * @return file which contains JAVA source code
+     * @throws IOException
+     *             if the error during writting to the file occures
+     * @throws IllegalArgumentException
+     *             if <code>type</code> equals <code>null</code>
+     * @throws IllegalStateException
+     *             if string with generated code is empty
+     */
     private File generateTypeToJavaFile(final File parentDir, final Type type, final CodeGenerator generator)
             throws IOException {
         if (parentDir == null) {
-            log.warn("Parent Directory not specified, files will be generated "
+            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());
@@ -67,7 +121,7 @@ public final class GeneratorJavaFile {
         if (!packageDir.exists()) {
             packageDir.mkdirs();
         }
-        
+
         if (generator.isAcceptable(type)) {
             String generatedCode = generator.generate(type);
             if (generatedCode.isEmpty()) {
@@ -80,14 +134,27 @@ public final class GeneratorJavaFile {
                     bw.write(generatedCode);
                 }
             } catch (IOException e) {
-                log.error(e.getMessage());
-                throw new IOException(e.getMessage());
+                LOG.error(e.getMessage());
+                throw new IOException(e);
             }
             return file;
         }
         return null;
     }
-    
+
+    /**
+     * Creates the package directory path as concatenation of
+     * <code>parentDirectory</code> and parsed <code>packageName</code>. The
+     * parsing of <code>packageName</code> is realized as replacement of the
+     * package name dots with the file system separator.
+     *
+     * @param parentDirectory
+     *            <code>File</code> object with reference to parent directory
+     * @param packageName
+     *            string with the name of the package
+     * @return <code>File</code> object which refers to the new directory for
+     *         package <code>packageName</code>
+     */
     private File packageToDirectory(final File parentDirectory, final String packageName) {
         if (packageName == null) {
             throw new IllegalArgumentException("Package Name cannot be NULL!");