Correct spelling.
[SquirrelJME.git] / assets / developer-notes / stephanie-gawroriski / 2016 / 01 / 14.mkd
blob3836db5dfe057543c2dd0663a7e8b53d4309c596
1 # 2016/01/14
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 ## 08:48
11 Time to do the refactor. First thing to do I say would be to cache the binary
12 and source contents based on dates.
14 ## 09:00
16 Ok, so using a cache for PackageContents did not take very long.
18 ## 09:01
20 I can also probably change how PackageInfo is done and lazily cache that too
21 because package information might only be used once before it is redone. The
22 information on the actual information stored in the packages does not need to
23 be in memory at all times and with the build process is only used a few times.
25 ## 09:05
27 However, that would have to wait until after PackageContents is refactored
28 because I can then use that instead.
30 ## 09:15
32 I can also remove the hardcoded requirement of forcing the source to always
33 be in a directory, so that now it can be in a ZIP so to speak, at least for
34 getting package contents. If it is a file then it is treated as a ZIP,
35 otherwise it is treated as a directory.
37 ## 12:32
39 I can also make PackageInfo cached so that the JSON data does not have to
40 be loaded at all times. Then after this I suppose I will streamline KBF
41 writing. Then once KBFs are written- well I suppose I should make the CPU
42 and machine configurations cached and then move onto removing the need for
43 inherited `ArchitectureData` with services and instead just have it all in a
44 base architecture data package where the packages using it (for example
45 PowerPC) will just contain the manifests which I already have. I would however
46 have to dump the Java stuff, however I must prepare to eat now.
48 ## 13:11
50 And I ate. So I will continue refactoring. Now I will make PackageInfo cached.
51 However since PackageStatus uses it, I will need a kind of bind or similar on
52 the package contents.
54 ## 13:18
56 Then using these changes I can support source code in the source path in the
57 form of ZIP files.
59 ## 13:27
61 This will also reduce duplicate code and such.
63 ## 13:29
65 This also removes the need for binary and source directories, however the
66 source directory may be read only so cannot remove that. However searching can
67 be done in both locations.
69 ## 14:02
71 The code looks much better and easier to read too.
73 ## 14:06
75 And now that refactor is done, just going to build every package to get to
76 where I am at to make sure it is correct and it works. Then I have to check it
77 in Wine to make sure it works also. These new changes are much better because
78 there is potential for less memory to be used now because the `PackageInfo` is
79 now on demand. The unification of having sources and binaries in the same
80 potential locations also makes things easier to use.
82 ## 14:14
84 And it works.
86 ## 15:50
88 I actually need reference counting for the package contents so that I do not
89 accidently close it while it is being read since the contents are shared
90 between multiple threads potentially.
92 ## 16:37
94 So now to move into streamlined KBF file output, then after that removing
95 the gigantic instruction enumerations so only databases are used instead.
97 ## 16:47
99 Using `AutoCloseable` on the KBF to write data and then finish with the table
100 of contents at the end can work out nicely. The table of contents must always
101 be written last so this can help ensure that it is actually written.
103 ## 17:55
105 Well my refactor still works in Wine.