Software/Goals

From OLPC
< Software
Revision as of 00:07, 6 January 2007 by Xavi (talk | contribs) (categorization)
Jump to: navigation, search

Our project goal

To create a solid operating system base for the OLPC hardware which anyone can deploy, requires no administration and provides a clear platform on which to build applications for educational computing.

Along with any goal, we must have rules of the game

Children must be allowed to play

Remember that this is a laptop that is designed for children, not for system administrators or programmers. We hope that children will be allowed to play with the base operating system as well as the programs that run on top of it. But at the same time, if they break it it must be very easy to fix and anyone should be able to fix it.

What this means is that the base operating system is something that can be replaced at any time, in a matter of minutes, and without damaging the child's data or the applications that happen to be installed. Simply put, replacing the operating system should not be scary.

Deployment is more important than development

Remember that how you build the operating system is very different than how it will be put into children's hands in the field. The tools that we use to build the operating system - package managers, compilers, installers - are not useful during the deployment of the operating system. This is because we know what the operating system will be and even more importantly we know what the hardware will be.

These two central facts mean we can make certain assumptions about deployment and can create an incredibly easy way to install and update the base operating system.

The platform is not the same as the applications that use it

In the classic Linux world we have the strange tendency to merge our ideas of what the platform is and what the applications are that sit on top of it. If you ask "what is the Linux platform" from 50 people in the community you will get 50 different answers. Because of the small size of this platform, we have to make choices about what the platform will be and how we enable applications to be written.

If you think about it you will realize that package managers are the result of one simple problem in Linux: we have so much software that we never know what our platform is. A program that's installed must be able to ask for everything it needs instead of assuming what is available. Because we've had to make choices about what the operating system is, and we know what's there, applications can make certain assumptions and we don't need to use package managers. Instead we will focus on how to enable people building applications for this platform.

Remember that this is not a classic linux distribution so when we don't have a package manager, you should ignore your screaming sysadmin hindbrain.