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 94,698 
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.
* "The Simpsons" is a trademark owned by Fox.
* "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.