I have been looking into the source code of some fantasy consoles and even though they are a good learning resource, I feel I'm missing something.
Aren't there any blog posts or academic studies to help us start ?
I'm new here but in the middle of making my console. Generally speaking you have to choose your host system, i.e. language, libraries for graphics, audio, etc. And you have to decide what is your console language/interpreter/simulator you want to give for creators. All interacions with PC (like drawing on canvas, playing sound, read input, write to output) you have to code on your host. Host should be able to evaluate console code and gather results/interactions. Eg. calling `spr(...)` in your console should call host function you write. The same for executing init, draw loop, etc.
Examples:
The most important thing is sandboxing console language, ie separate from host functions. You don't want to allow anyone to access PC directly.
Amazing response, thank you for taking the time :)
One thing I still can't grasp is the concept of creating a "VM"... adding virtual components like BIOS, RAM, GPU. That's what makes me excited with creating a FC is implementing restrictions like RAM scarcity or visual limitations.
I'm really liking the LIKO-12 way of doing things, I have way to much to learn :P
RAM/visual limitations are quite easy to make in my opinion. 8-bit computers like ZX Spectrum had RAM bound to screen, settings, code etc. Implementation could be simulated by byte array. Console code puts data there, host code interprets it. You can have part of code which reads specific range of array data as pixels and display it on screen (GPU), the other range is sound (Sound chip), the other sprites, palette, etc. ROM can be set of sprites, letters, maybe some global parameters like palette. I think the hardest restriction is console language and sandboxing