Correct spelling.
[SquirrelJME.git] / assets / developer-notes / stephanie-gawroriski / 2019 / 03 / 10.mkd
blob3ef3e82a284893a2617783b6c2598eaf169dbbf9
1 # 2019/03/10
3 ## 16:15
5 Well thinking of things, using the class file and all of the other such this
6 is going to really depend on many things and will not be that light where
7 it could easily be made into RatufaCoat. I think what I need here is a
8 minimizer of sorts that takes an input class file and turns it into a tinier
9 format for easier loading and usage. Then I just use these minimized classes
10 and such for running things. At least initially I do not have to go crazy in
11 what I am doing, literally just making a mini format. I can read the class
12 file although it would be a bit more complex of a format to parse especially
13 considering the constant pool and all the variable length data. I can keep
14 this in the classfile stuff, but I can have a convert to minified format which
15 uses the same format as the class file except with alternative constant pools.
16 It would be a proprietary format used for SquirrelJME. I mean all of the stuff
17 uses the constant pool. In this case I would really just be using an optimized
18 constant pool for things. I think this will be the first case, at least
19 something that can output a lighter format for this reason. I do not need to
20 go that far for things. Of course minified classes would be completely not
21 compatible with standard JVMs but I could just reuse the format and such. But
22 to signify mini classes, I can have a different major and minor version that
23 is not normaly class file compatible but SquirrelJME knows about it. At least
24 according to the version used. Of course what I think I need first is
25 something which can output the same input classes and such.
27 ## 16:33
29 So the `ClassFile` class is great for things, but it is not something that
30 would result in a performant format for execution since it is expected that
31 the JVM will do all the optimization itself. So I think even using this
32 format is just going to needlessly complicate and slow things down. I
33 definitely do though want a pre-mapped constant pool reference thing so that
34 when a class is loaded those things are resolved as needed, at least after
35 the base class structure has been loaded.
37 ## 16:36
39 I do know what I need exactly to run a virtual machine and the current
40 format just adds too much information for that. At least initialy for code I
41 do not need to perform much translation for the byte code, it will just be
42 for optimizing things essentially so it can be more easily used by the
43 VM. Of course the end result as a guess should end up being faster with most
44 of the cruft and checks in the format removed.
46 ## 17:02
48 I should make a test for the actual class file parsing and such just to be
49 sure that it works properly.