From 40ba5fb6217142f38acfcd4820cd4fce9e8e35ae Mon Sep 17 00:00:00 2001 From: JanUlrich Date: Thu, 15 Dec 2016 16:28:12 +0100 Subject: [PATCH] =?UTF-8?q?Beispiel=20f=C3=BCr=20ANTLR=20Parser?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/de/dhbwstuttgart/parser/RunParser.java | 5 ++-- .../parser/SyntaxTreeGenerator.java | 29 +++++++++++++++++++ 2 files changed, 31 insertions(+), 3 deletions(-) create mode 100644 src/de/dhbwstuttgart/parser/SyntaxTreeGenerator.java diff --git a/src/de/dhbwstuttgart/parser/RunParser.java b/src/de/dhbwstuttgart/parser/RunParser.java index 9b1c8653..9489ca6c 100644 --- a/src/de/dhbwstuttgart/parser/RunParser.java +++ b/src/de/dhbwstuttgart/parser/RunParser.java @@ -22,9 +22,8 @@ public class RunParser{ CommonTokenStream tokens = new CommonTokenStream(lexer); Java8Parser parser = new Java8Parser(tokens); ParserRuleContext tree = parser.compilationUnit(); - ParseTreeWalker walker = new ParseTreeWalker(); - CompilationUnitEvaluator eval = new CompilationUnitEvaluator(); - walker.walk(eval, tree); + SyntaxTreeGenerator generator = new SyntaxTreeGenerator(null); + generator.convert((Java8Parser.CompilationUnitContext) tree); } catch(Exception e){ System.out.println("An exception occured which is unknown and on our TODO list."); diff --git a/src/de/dhbwstuttgart/parser/SyntaxTreeGenerator.java b/src/de/dhbwstuttgart/parser/SyntaxTreeGenerator.java new file mode 100644 index 00000000..78694e38 --- /dev/null +++ b/src/de/dhbwstuttgart/parser/SyntaxTreeGenerator.java @@ -0,0 +1,29 @@ +package de.dhbwstuttgart.parser; + +import de.dhbwstuttgart.syntaxtree.SourceFile; +import de.dhbwstuttgart.syntaxtree.Class; +import de.dhbwstuttgart.typecheck.JavaClassRegistry; + +import java.util.ArrayList; +import java.util.List; + +public class SyntaxTreeGenerator { + + public SyntaxTreeGenerator(JavaClassRegistry nameReg){ + //TODO: Implement + } + + public SourceFile convert(Java8Parser.CompilationUnitContext ctx){ + List classes = new ArrayList<>(); + for(Java8Parser.TypeDeclarationContext typeDecl : ctx.typeDeclaration()){ + Class newClass = convert(typeDecl.classDeclaration()); + classes.add(newClass); + } + return new SourceFile(classes); + } + + private Class convert(Java8Parser.ClassDeclarationContext ctx) { + //TODO: Implement + return null; + } +}