Correct spelling.
[SquirrelJME.git] / assets / developer-notes / stephanie-gawroriski / 2016 / 07 / 27.mkd
blobd4632817ba6bfbb07f862a12d2adfbd99d41c894
1 # 2016/07/27
3 ## 11:17
5 I need a namespace format that is simple to use and can be directly executed
6 in memory. So I suppose I should keep a table of contents and write that at
7 the end. I will need a shared string table also. Similar to before. I should
8 aim for everything to be aligned as possible, so all details in a class can
9 just be treated as an integer array for the most part. Methods will need a
10 global binding table, although this could be shared among all methods in a
11 single namespace. When a namespace is loaded, the function table can be called
12 in. The entire table could just be function pointers to other methods and
13 called as such. So get of a field just changes to a function call which can
14 check for correctness and determine if a class needs to be initialized. This
15 way the only thing that needs to be initialized is the actual table itself for
16 each namespace. I would want to avoid duplicating static structures elsewhere
17 in memory. Although there would be some speed loss from using many functions,
18 it would simplify things because the code would not need to check for special
19 conditions at all. So translate everything to a method call for simplicity.
20 When an interned String constant is requested that would be treated as a method
21 call also. It would have to create a `String` object if one was not set, but
22 that could be done with a volatile. The initial bootstrap would completely
23 have to avoid using objects for the most part because it would have to setup
24 the memory management routines, basic stack, and the heap. Classes and objects
25 would not be initialized. However, I could just setup a basic heap at first and
26 setup the initial tables with binding handlers. Generally the first thing I
27 need is allocation and a stack. So I just need to think about class
28 initialization in the early boot stage process.
30 ## 11:26
32 When a method call is performed, there will need to be a pointer to the
33 namespace table for the current process for usage. This way each process can
34 have their own unique set which does not collide with other usages. For the
35 early initilization stage, these pointers can be initialized as usual. So
36 then all the calls should be the same for the most part. Since classes are
37 also used, I will need an actual class table also along with the string table.
38 Because I need to refer to classes for initialization before `String`s may
39 even exist. So `ldc` (`Foo.class`) of a class returns a `Class`. So then the
40 call to the function table would be then:
42         ftable[vtableindex](classid)
44 Where the C equivalent prototype would be:
46         Object* getClass(int __classid);
48 I may need an extra pointer to the classpath or namespace setup however and to
49 remember it in every method. So this would be a global virtual machine pointer.
50 The bootstrap would setup this virtual machine.
52 ## 11:35
54 The function table could just be a reference from the VM table. Possibly the
55 best way to do this would be to have the VM structure not be a Java object. It
56 would have a raw representation and exist outside of the virtual machine. Then
57 this way I do not need to worry about initializing classes and objects for it
58 since that would completely complicate the bootstrap process. There would
59 however be method which can manage access to the internal VM structure.
61 ## 18:04
63 The Creator CI40 will be shipping around next week, very exciting.
65 ## 19:58
67 Manually converting my mascot to SVG, this will take awhile but it should be
68 optimized!
70 ## 20:19
72 Inkscape is not too bad.
74 ## 22:33
76 Right now I just have the ears and the head hair done for the most part.
77 However it does look really nice.
79 ## 23:03
81 Did the ears, eyes, the head hair, and part of the face. So far it looks well.