Indentations break the feed.
[SquirrelJME.git] / assets / developer-notes / stephanie-gawroriski / 2014 / 11 / 23.mkd
blob9da2c5e7805c56efd8a4df8790e1ca5c89102d85
1 # 2014/11/23
3 ***DISCLAIMER***: _These notes are from the defunct k8 project which_
4 _precedes SquirrelJME. The notes for SquirrelJME start on 2016/02/26!_
5 _The k8 project was effectively a Java SE 8 operating system and as such_
6 _all of the notes are in the context of that scope. That project is no_
7 _longer my goal as SquirrelJME is the spiritual successor to it._
9 ## 04:02
11 Well this new building code is much lighter, instead of 355 lines across 5
12 files and having stuff in util, this consists of a single file now. This is
13 for at least what I did before.
15 ## 20:29
17 Limiting planet creation to before comets exist is a rather poor idea because
18 that complicates things. And splitting fields and memory into both volatile
19 and optimized form makes things a bit better because it adds multiple ways the
20 code generator can work with fields or memory addresses. Volatile is a never
21 cache as usual while optimized caches the result so while sets are truly set
22 the gets are from the cache. The optimized version has concurrency issues in
23 that if another thread or a submethod messes with the value of the field then
24 it will not be seen by the current method, it is a local optimization only. I
25 am only pretty much going to use volatile only where the optimized version
26 will be in rare use cases and in protected code cases.
28 ## 23:17
30 OK, the SSA is going well but the Java byte code decoder is very ugly and
31 messy currently. Well the main thing is that I do not know how it works based
32 on never running it before, there are the specs which I do know but not the
33 feel. So it might be better to just hold off the stuff for now and write an
34 interpreter so that it can run on the existing virtual machine abliet slowly.
35 Then once I get a feel for that I can then write the native compiler and will
36 know how the code acts as such.
38 ## 23:35
40 I believe the main thing is that I am having doubts about the Java compiler
41 code. So the best thing I should do is to clean up my language transformer and
42 make it actually better than it currently is. Right now it is a singleton
43 which means I need a special and junk like that, quite ugly. So the best
44 result would be to switch to a factory sort of setup which generates private
45 classes for usage. Ever since I started writing that code I have been uneasy
46 about it being a singleton, but it would be better as a factory.
48 ## 23:43
50 This should also then be capable of removing MachineCodec as translation can
51 be a bit more direct now.