ZealOS Charter * The vision is the same usage model and niche as the Commodore 64 -- a simple machine where programming was the goal, not just a means to an end. However, it is modern, 64-bit and multi-cored. It is special purpose, not general purpose, so some things it will not do. Also, it's a kayak, not a Titanic. The priority is user developers, not 3rd party developers. * We don't think twice about breaking compatibility. We do not put any hooks for future changes. "Perfect" means we always act as though it is final, for all time. Microsoft allowed the Windows BMP file format to adapt to the future and it became grotesque. * Low line count and code complexity is the highest good, so it is easy to learn the whole thing. Users should see the light at the end of the tunnel. One file system, for example, is better than many file systems. * There is a limit of 100,000 lines of code for all time, not including applications and demos. Currently, there are 95,255 lines of code. 3rd party libraries are banned because they circumvent the intent of this limit. The vision is a Commodore 64 ROM -- a fixed core API that is the only dependency of applications. Dependency on components and libraries creates a hell that is no longer blissful. * The metric for resolving all ZealOS code governance issues is how fast the compiler compiles itself and the kernel with BootHDIns(). The CosmiC language should be changed to optimize this metric, as Terry Davis did when he changed type casting from prefix standard C to postfix CosmiC, but we need a rule to prevent degenerating into a brainfuck language. * Minimal abstraction is a goal. Sheep are fools. They always respect a design that is more complicated than another. Any genius can make it complicated. Like in physics, it takes a supra-genius to make it simple. * It is for one platform -- x86_64 desktop PC compatibles, more like super-computers than battery efficient wimpy mobiles. * One driver for each class of device. Limited exceptions are allowed. With divergent device capabilities, it is a nightmare for user applications and what is gained? * Ring-0-only. Everything runs in kernel mode, including user applications. * No wireless communications. Only wired communications like Ethernet and Serial IO will be used. * No GPU. We want one processing platform, the CPU, for everything. * Full access to everything. All memory, I/O ports, instructions, and similar things must never be off limits. All functions, variables and class members will be accessible. There are no C++ public/private protections and all functions, even secondary ones in the kernel, can be called. * Single-address-map as though paging is not used. Long mode requires paging, however, so the nearest thing is keeping all memory identity-mapped. * Free and public domain. * 100% open source with all source included. * Documents are not for printing. They're dynamic, intended for the screen. * Just one 8x8 fixed-width font. No Unicode, just Extended ASCII. Other countries can make their own versions. The versions should be just for one language and platform. * No multimedia. Sounds and images will be primarily calculated in real-time, not fetched from storage. * "Commodore 64" is a trademark owned by Polabe Holding NV. * "Windows" is a trademark owned by MicroSoft Corp. Possible Amendments The compiler's parser makes RISC code which it optimizes to CISC. Terry Davis discovered this does not matter because the CPU converts it back to RISC and schedules it, internally. A ZealOS zealot with more zeal might say we should save lines-of-code by removing the CISC optimizing.