Update the API generation code and code generation sample
[controller.git] / opendaylight / sal / yang-prototype / code-generator / yang-model-parser-impl / src / main / java / org / opendaylight / controller / yang / model / parser / impl / YangModelParserListenerImpl.java
index 6e6206594cc419acab737c26fa281868386d3046..6ff69eee516986dce0b02b26c9ef56c43c65f566 100644 (file)
@@ -13,6 +13,7 @@ import java.net.URI;
 import java.text.DateFormat;\r
 import java.text.ParseException;\r
 import java.text.SimpleDateFormat;\r
+import java.util.ArrayList;\r
 import java.util.Collections;\r
 import java.util.Date;\r
 import java.util.List;\r
@@ -21,7 +22,6 @@ import java.util.TreeMap;
 \r
 import org.antlr.v4.runtime.tree.ParseTree;\r
 import org.opendaylight.controller.antlrv4.code.gen.YangParser;\r
-import org.opendaylight.controller.antlrv4.code.gen.YangParser.Argument_stmtContext;\r
 import org.opendaylight.controller.antlrv4.code.gen.YangParser.Base_stmtContext;\r
 import org.opendaylight.controller.antlrv4.code.gen.YangParser.Contact_stmtContext;\r
 import org.opendaylight.controller.antlrv4.code.gen.YangParser.Container_stmtContext;\r
@@ -47,6 +47,7 @@ import org.opendaylight.controller.antlrv4.code.gen.YangParser.Revision_stmtCont
 import org.opendaylight.controller.antlrv4.code.gen.YangParser.Revision_stmtsContext;\r
 import org.opendaylight.controller.antlrv4.code.gen.YangParser.Status_stmtContext;\r
 import org.opendaylight.controller.antlrv4.code.gen.YangParser.Type_body_stmtsContext;\r
+import org.opendaylight.controller.antlrv4.code.gen.YangParser.Union_specificationContext;\r
 import org.opendaylight.controller.antlrv4.code.gen.YangParser.Yang_version_stmtContext;\r
 import org.opendaylight.controller.antlrv4.code.gen.YangParserBaseListener;\r
 import org.opendaylight.controller.yang.common.QName;\r
@@ -81,7 +82,7 @@ final class YangModelParserListenerImpl extends YangParserBaseListener {
     private String moduleName;\r
     private URI namespace;\r
     private String yangModelPrefix;\r
-    private Date revision;\r
+    private Date revision = new Date(0L);\r
 \r
     private final DateFormat simpleDateFormat = new SimpleDateFormat(\r
             "yyyy-mm-dd");\r
@@ -122,7 +123,8 @@ final class YangModelParserListenerImpl extends YangParserBaseListener {
     @Override\r
     public void enterModule_header_stmts(final Module_header_stmtsContext ctx) {\r
         super.enterModule_header_stmts(ctx);\r
-\r
+        \r
+        String yangVersion = null;\r
         for (int i = 0; i < ctx.getChildCount(); ++i) {\r
             final ParseTree treeNode = ctx.getChild(i);\r
             if (treeNode instanceof Namespace_stmtContext) {\r
@@ -133,10 +135,14 @@ final class YangModelParserListenerImpl extends YangParserBaseListener {
                 yangModelPrefix = stringFromNode(treeNode);\r
                 moduleBuilder.setPrefix(yangModelPrefix);\r
             } else if (treeNode instanceof Yang_version_stmtContext) {\r
-                final String yangVersion = stringFromNode(treeNode);\r
-                moduleBuilder.setYangVersion(yangVersion);\r
+                yangVersion = stringFromNode(treeNode);\r
             }\r
         }\r
+        \r
+        if (yangVersion == null) {\r
+            yangVersion = "1";\r
+        }\r
+        moduleBuilder.setYangVersion(yangVersion);\r
     }\r
 \r
     @Override\r
@@ -168,36 +174,37 @@ final class YangModelParserListenerImpl extends YangParserBaseListener {
 \r
     @Override\r
     public void enterRevision_stmts(Revision_stmtsContext ctx) {\r
-        TreeMap<Date, Revision_stmtContext> revisions = new TreeMap<Date, Revision_stmtContext>();\r
-\r
-        for (int i = 0; i < ctx.getChildCount(); ++i) {\r
-            final ParseTree treeNode = ctx.getChild(i);\r
-            if (treeNode instanceof Revision_stmtContext) {\r
-                final String revisionDateStr = stringFromNode(treeNode);\r
-                try {\r
-                    Date revision = simpleDateFormat.parse(revisionDateStr);\r
-                    revisions.put(revision, (Revision_stmtContext)treeNode);\r
-\r
-                } catch (ParseException e) {\r
-                    final String message = "Failed to parse revision string: "+ revisionDateStr;\r
-                    logger.warn(message);\r
+        if (ctx != null) {\r
+            for (int i = 0; i < ctx.getChildCount(); ++i) {\r
+                final ParseTree treeNode = ctx.getChild(i);\r
+                if (treeNode instanceof Revision_stmtContext) {\r
+                    updateRevisionForRevisionStatement(treeNode);\r
                 }\r
             }\r
         }\r
-        if(revisions.size() > 0) {\r
-            Revision_stmtContext revisionCtx = revisions.firstEntry().getValue();\r
-            moduleBuilder.setRevision(revisions.firstKey());\r
-            revision = revisions.firstKey();\r
-\r
-            for(int i = 0; i < revisionCtx.getChildCount(); i++) {\r
-                ParseTree child = revisionCtx.getChild(i);\r
-                if(child instanceof Reference_stmtContext) {\r
-                    moduleBuilder.setReference(stringFromNode(child));\r
+    }\r
+\r
+    private void updateRevisionForRevisionStatement(final ParseTree treeNode) {\r
+        final String revisionDateStr = stringFromNode(treeNode);\r
+        try {\r
+            final Date revision = simpleDateFormat.parse(revisionDateStr);\r
+            if ((revision != null) && (this.revision.compareTo(revision) < 0)) {\r
+                this.revision = revision;\r
+                moduleBuilder.setRevision(this.revision);\r
+                for (int i = 0; i < treeNode.getChildCount(); ++i) {\r
+                    ParseTree child = treeNode.getChild(i);\r
+                    if (child instanceof Reference_stmtContext) {\r
+                        moduleBuilder.setReference(stringFromNode(child));\r
+                    }\r
                 }\r
             }\r
+        } catch (ParseException e) {\r
+            final String message = "Failed to parse revision string: "\r
+                    + revisionDateStr;\r
+            logger.warn(message);\r
         }\r
     }\r
-\r
+    \r
     @Override\r
     public void enterImport_stmt(Import_stmtContext ctx) {\r
         super.enterImport_stmt(ctx);\r
@@ -253,23 +260,10 @@ final class YangModelParserListenerImpl extends YangParserBaseListener {
 \r
     @Override\r
     public void enterExtension_stmt(YangParser.Extension_stmtContext ctx) {\r
-        String extName = stringFromNode(ctx);\r
-        QName qname = new QName(namespace, revision, yangModelPrefix, extName);\r
+        String argument = stringFromNode(ctx);\r
+        QName qname = new QName(namespace, revision, yangModelPrefix, argument);\r
         ExtensionBuilder builder = moduleBuilder.addExtension(qname);\r
         parseSchemaNodeArgs(ctx, builder);\r
-\r
-        String argument = null;\r
-        boolean yin = false;\r
-        for(int i = 0; i < ctx.getChildCount(); i++) {\r
-            ParseTree child = ctx.getChild(i);\r
-            if(child instanceof Argument_stmtContext) {\r
-                argument = stringFromNode(child);\r
-                yin = parseYinValue((Argument_stmtContext)child);\r
-                break;\r
-            }\r
-        }\r
-        builder.setArgument(argument);\r
-        builder.setYinElement(yin);\r
     }\r
 \r
     @Override\r
@@ -296,7 +290,20 @@ final class YangModelParserListenerImpl extends YangParserBaseListener {
     @Override\r
     public void enterType_stmt(YangParser.Type_stmtContext ctx) {\r
         String typeName = stringFromNode(ctx);\r
-        QName typeQName = parseQName(typeName);\r
+        QName typeQName;\r
+        if (typeName.contains(":")) {\r
+            String[] splittedName = typeName.split(":");\r
+            String prefix = splittedName[0];\r
+            String name = splittedName[1];\r
+            if (prefix.equals(yangModelPrefix)) {\r
+                typeQName = new QName(namespace, revision, prefix, name);\r
+            } else {\r
+                typeQName = new QName(null, null, prefix, name);\r
+            }\r
+        } else {\r
+            typeQName = new QName(namespace, revision, yangModelPrefix,\r
+                    typeName);\r
+        }\r
 \r
         TypeDefinition<?> type = null;\r
         Type_body_stmtsContext typeBody = null;\r
@@ -315,6 +322,16 @@ final class YangModelParserListenerImpl extends YangParserBaseListener {
                 moduleBuilder.setType(type, actualPath);\r
             } else {\r
                 if(typeName.equals("union")) {\r
+                    List<String> types = new ArrayList<String>();\r
+                    for(int i = 0; i < typeBody.getChildCount(); i++) {\r
+                        ParseTree unionSpec = typeBody.getChild(i);\r
+                        if(unionSpec instanceof Union_specificationContext) {\r
+                            for(int j = 0; j < unionSpec.getChildCount(); j++) {\r
+                                ParseTree typeSpec = unionSpec.getChild(j);\r
+                                types.add(stringFromNode(typeSpec));\r
+                            }\r
+                        }\r
+                    }\r
                     moduleBuilder.addUnionType(actualPath);\r
                 } else {\r
                     type = parseTypeBody(typeName, typeBody, actualPath, namespace, revision, yangModelPrefix);\r
@@ -329,24 +346,7 @@ final class YangModelParserListenerImpl extends YangParserBaseListener {
         }\r
 \r
         updatePath(typeName);\r
-    }\r
 \r
-    private QName parseQName(String typeName) {\r
-        QName typeQName;\r
-        if (typeName.contains(":")) {\r
-            String[] splittedName = typeName.split(":");\r
-            String prefix = splittedName[0];\r
-            String name = splittedName[1];\r
-            if (prefix.equals(yangModelPrefix)) {\r
-                typeQName = new QName(namespace, revision, prefix, name);\r
-            } else {\r
-                typeQName = new QName(null, null, prefix, name);\r
-            }\r
-        } else {\r
-            typeQName = new QName(namespace, revision, yangModelPrefix,\r
-                    typeName);\r
-        }\r
-        return typeQName;\r
     }\r
 \r
     @Override\r
@@ -695,5 +695,5 @@ final class YangModelParserListenerImpl extends YangParserBaseListener {
     private List<String> getActualPath() {\r
         return Collections.unmodifiableList(actualPath);\r
     }\r
-
-}
+\r
+}\r