Indentations break the feed.
[SquirrelJME.git] / assets / developer-notes / stephanie-gawroriski / 2016 / 04 / 13.mkd
blob3165c1e7adaa5c5ea1e61bcf2835e4f5a269d858
1 # 2016/04/13
3 ## 07:58
5 I can actually use GCJ to compile the stuff to byte code interestingly. GCJ
6 appears to just completely ignore the version identifier. However, since
7 Java ME is essentially Java 5 in that it has nothing that makes it require
8 Java 7, it works regardless. Language features such as `AutoCloseable` and
9 such are just syntactic sugar on top of the byte code.
11 ## 08:01
13 Thus potentially, GCJ could be used in the initial stages and would essentially
14 currently just support Linux for now. Following that then, I could develop the
15 main library and then also have the interpreter laid out on top of that for
16 example. This way I can develop the main library. I could also then reverse
17 engineer the output binaries to figure out how certain code is generated and
18 such.
20 ## 08:35
22 One thing though, it seems that GCJ when given my class files is not including
23 any code at all even when specifying shared and such.
25 ## 08:42
27 This might be because it is an interface, which has no code.
29 ## 09:02
31 However, GCJ is heavily tied into GNU classpath and since Java ME lacks some
32 things, there are some impossible means of doing things. The only way to get
33 it to work on GCJ would be to rename all of my classes with a prefix and then
34 use a bridge of sorts so it runs on an existing VM. So this would just be
35 plain Java support. So that is, all of the byte codes and such would remain
36 the same, however instead stuff such as `java.lang.Object` would become instead
37 `__squirreljme.java.lang.Object`, then any references in the class would also
38 just become referenced as such. In reality, having this code run on an existing
39 VM would be quite simple when it comes to code generation. Note that a VM on
40 the VM would also need the compiler code to exist too so that JARs ran by the
41 user can be cross compiled and ran.
43 ## 09:14
45 So an eventual JVM on JVM could eventually be compiled with GCJ anyway so
46 that it would be native for the most part. However thinking about this and the
47 SSA class program code. I believe that I will have the class program code not
48 use SSA and instead have the SSA functionality and layout elsewhere. Thus the
49 classprogram will strictly handle Java byte code.
51 ## 09:17
53 From what I started writing at _09:02_, `Class.forName()` would be wrapped so
54 even if it sends it `"java.lang.Object"`, the method that would be called is:
55 `__squirreljme.java.lang.Class.forName()`.
57 ## 10:04
59 The interpreter could then just use the bytecodes mostly directly and become a
60 pure intrepreter which would be simpler to implement. Then I can develop the
61 main library. Once that is developed, I will have enough base to have actual
62 native compilation without hitting TODOs all the time.
64 ## 14:10
66 What if for the class file consants, instead of having all of it be in the same
67 class, I split the entries apart. These would be a bit easier to type and the
68 entry code would be slightly smaller.