From 6030682400e6db1bbd569529136a9581939cf445 Mon Sep 17 00:00:00 2001 From: JanUlrich Date: Wed, 27 May 2015 12:53:47 +0200 Subject: [PATCH] =?UTF-8?q?Test=20f=C3=BCr=20Bytecode=20anf=C3=BCgen.=20Be?= =?UTF-8?q?ispielhaft=20generateBytecode-Methode=20in=20MyCompiler=20imple?= =?UTF-8?q?mentiert?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/de/dhbwstuttgart/core/MyCompiler.java | 18 +++++++++ src/de/dhbwstuttgart/core/MyCompilerAPI.java | 4 +- test/bytecode/EmptyClass.jav | 2 + test/bytecode/EmptyClass.java | 42 ++++++++++++++++++++ 4 files changed, 65 insertions(+), 1 deletion(-) create mode 100644 test/bytecode/EmptyClass.jav create mode 100644 test/bytecode/EmptyClass.java diff --git a/src/de/dhbwstuttgart/core/MyCompiler.java b/src/de/dhbwstuttgart/core/MyCompiler.java index 4304e55a..1b776429 100755 --- a/src/de/dhbwstuttgart/core/MyCompiler.java +++ b/src/de/dhbwstuttgart/core/MyCompiler.java @@ -36,6 +36,7 @@ import de.dhbwstuttgart.syntaxtree.type.ITypeContainer; import de.dhbwstuttgart.syntaxtree.type.RefType; import de.dhbwstuttgart.syntaxtree.type.Type; import de.dhbwstuttgart.syntaxtree.type.TypePlaceholder; +import de.dhbwstuttgart.typeinference.ByteCodeResult; import de.dhbwstuttgart.typeinference.FunNInterface; import de.dhbwstuttgart.typeinference.Pair; import de.dhbwstuttgart.typeinference.ResultSet; @@ -852,5 +853,22 @@ public class MyCompiler implements MyCompilerAPI this.m_AbstractSyntaxTree.add(ret); return ret; } + + @Override + public ByteCodeResult generateBytecode() { + /* + * TODO Für das Bytecode-Team: + * - generateBytecode-Methode implementieren + * - Sich einen passenden Container für den Bytecode überlegen + * - Dieser wird von generateBytecode zurückgeliefert und sollte die Möglichkeit zum schreiben von Bytecode in eine Datei bieten. + * - wird der Rückgabetyp von generateBytecode in MyCompiler geändert, so muss auch der Rückgabetyp im Interface MyCompilerAPI geändert werden + */ + try { + return this.m_AbstractSyntaxTree.firstElement().KlassenVektor.firstElement().genByteCode(); + } catch (IOException e) { + e.printStackTrace(); + return null; + } + } } // ino.end diff --git a/src/de/dhbwstuttgart/core/MyCompilerAPI.java b/src/de/dhbwstuttgart/core/MyCompilerAPI.java index 760c1929..2898b3ba 100755 --- a/src/de/dhbwstuttgart/core/MyCompilerAPI.java +++ b/src/de/dhbwstuttgart/core/MyCompilerAPI.java @@ -6,12 +6,13 @@ package de.dhbwstuttgart.core; import java.io.File; import java.io.FileNotFoundException; import java.io.IOException; -import de.dhbwstuttgart.typeinference.Menge; +import de.dhbwstuttgart.typeinference.Menge; import de.dhbwstuttgart.myexception.CTypeReconstructionException; import de.dhbwstuttgart.myexception.JVMCodeException; import de.dhbwstuttgart.parser.JavaParser; import de.dhbwstuttgart.syntaxtree.SourceFile; +import de.dhbwstuttgart.typeinference.ByteCodeResult; import de.dhbwstuttgart.typeinference.ResultSet; import de.dhbwstuttgart.typeinference.TypeinferenceResultSet; import de.dhbwstuttgart.typeinference.exceptions.ParserError; @@ -121,5 +122,6 @@ public interface MyCompilerAPI */ public SourceFile parse(String sourceCode) throws ParserError; + public ByteCodeResult generateBytecode(); } // ino.end diff --git a/test/bytecode/EmptyClass.jav b/test/bytecode/EmptyClass.jav new file mode 100644 index 00000000..29d3c626 --- /dev/null +++ b/test/bytecode/EmptyClass.jav @@ -0,0 +1,2 @@ +class EmptyClass{ +} \ No newline at end of file diff --git a/test/bytecode/EmptyClass.java b/test/bytecode/EmptyClass.java new file mode 100644 index 00000000..44c78d50 --- /dev/null +++ b/test/bytecode/EmptyClass.java @@ -0,0 +1,42 @@ +package bytecode; + +import static org.junit.Assert.*; + +import java.io.File; +import java.io.IOException; + +import junit.framework.TestCase; + +import org.junit.Test; + +import plugindevelopment.TypeInsertTester; +import de.dhbwstuttgart.core.MyCompiler; +import de.dhbwstuttgart.core.MyCompilerAPI; +import de.dhbwstuttgart.logger.LoggerConfiguration; +import de.dhbwstuttgart.parser.JavaParser.yyException; +import de.dhbwstuttgart.typeinference.ByteCodeResult; +import de.dhbwstuttgart.typeinference.Menge; +import de.dhbwstuttgart.typeinference.TypeinferenceResultSet; +import de.dhbwstuttgart.typeinference.typedeployment.TypeInsertSet; + +public class EmptyClass { + + public final static String rootDirectory = System.getProperty("user.dir")+"/test/bytecode/"; + public final static String testFile = "EmptyClass.jav"; + + @Test + public void test() { + LoggerConfiguration logConfig = new LoggerConfiguration(); + MyCompilerAPI compiler = MyCompiler.getAPI(logConfig); + try { + compiler.parse(new File(rootDirectory + testFile)); + compiler.typeReconstruction(); + ByteCodeResult bytecode = compiler.generateBytecode(); + System.out.println(bytecode); + } catch (IOException | yyException e) { + e.printStackTrace(); + TestCase.fail(); + } + } + +}