X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=TestGen.hs;h=c8cd0ef3c91578696e3db0355efc384f76225343;hb=b3a837825f029bf7940368564d32fc6003ccde14;hp=900a422dd5778892483b970457018cfd32094ad0;hpb=22d4ad212c27135cea11b577c62f7d133d392d4e;p=hs-java.git diff --git a/TestGen.hs b/TestGen.hs index 900a422..c8cd0ef 100644 --- a/TestGen.hs +++ b/TestGen.hs @@ -6,12 +6,21 @@ import JVM.ClassFile import JVM.Converter import JVM.Assembler import JVM.Builder +import Java.ClassPath import qualified Java.Lang import qualified Java.IO test :: Generate () test = do + withClassPath $ do + -- Add current directory (with Hello.class) to ClassPath + addDirectory "." + + -- Load method signature: Hello.hello() + helloJava <- getClassMethod "./Hello" "hello" + + -- Initializer method. Just calls java.lang.Object. newMethod [ACC_PUBLIC] "" [] ReturnsVoid $ do setStackSize 1 @@ -19,6 +28,7 @@ test = do invokeSpecial Java.Lang.object Java.Lang.objectInit i0 RETURN + -- Declare hello() method and bind it's signature to hello. hello <- newMethod [ACC_PUBLIC, ACC_STATIC] "hello" [IntType] ReturnsVoid $ do setStackSize 8 @@ -35,18 +45,22 @@ test = do invokeStatic Java.Lang.integer Java.Lang.valueOfInteger aastore invokeVirtual Java.IO.printStream Java.IO.printf + invokeStatic "Hello" helloJava pop i0 RETURN + -- Main class method. newMethod [ACC_PUBLIC, ACC_STATIC] "main" [arrayOf Java.Lang.stringClass] ReturnsVoid $ do setStackSize 1 iconst_5 + -- Call previously declared method invokeStatic "Test" hello i0 RETURN return () +main :: IO () main = do testClass <- generate [] "Test" test B.writeFile "Test.class" (encodeClass testClass)