meillo@37: \chapter{About \freesw\ projects} meillo@26: meillo@37: There are several differences between \freesw\ projects and projects about proprietary software. To understand \freesw\ projects, one needs to understand \freesw\ itself first. meillo@37: meillo@37: \section{About \freesw} meillo@37: The term ``Free Software'' was coined by the \name{Free Software Foundation} (short: \NAME{FSF}), founded by Richard M. Stallman (known as ``RMS'') in 1985. %FIXME: check date meillo@37: Although various licenses make software free, none of them represents the thinking of \freesw\ like the the \GNU\ \gpl\ (short: \GPL), which was written by Stallman in 1983. One could say, the \GPL\ ``powered'' the \name{Free Software movement}. meillo@37: meillo@37: But after all, the \GPL\ was not the first \freesw\ license used. The \name{BSD License} for example is much older; with first occurences around 19xx. %FIXME: insert date meillo@37: However, nobody talked about ``Free Software'' back then. meillo@37: meillo@37: \freesw\ gives freedoms to its users. In contrast to proprietary software restricting the users freedom. The freedoms (or rights) the user has are stated in %FIXME where? meillo@37: . Namely these are: meillo@37: \begin{enumerate} meillo@37: \item The freedom to use meillo@37: \item The freedom to copy and share meillo@37: \item The freedom to study the source code meillo@37: \item The freedom to modify meillo@37: \item The freedom to redistribute (granting the same freedom) meillo@37: \end{enumerate} meillo@37: meillo@37: meillo@37: \section{The term ``Open Source''} meillo@37: \name{Open Source Software} often stands for the same as \freesw. But there is an essential difference: \name{Open Source} focuses on the availability of source code, while \freesw\ is about freedoms for people. meillo@37: meillo@43: \name{Open Source Software} is a subset of \freesw, meaning: All \freesw\ is \name{Open Source}, but there exists \name{Open Source Software} that is not free. meillo@37: meillo@37: meillo@37: \section{Development of \freesw} meillo@43: Having source code available and the right to modify it, encouridges programmers to actually do so. Their modifications are manifoldly. Some tailor the software to their needs. Some add features. Some do it just for fun. There are no limitations---whoever wants to, may work on it. meillo@37: meillo@37: Since the boom of the internet, \freesw\ typically is developed by an open community of programmers interested in the software. The process of development is watchable by everyone. meillo@37: meillo@37: The other, now less common, method is a more closed group, developing in a ``sealed'' room, but releasing finished versions to the public. meillo@37: meillo@37: Eric S. Raymond discusses about these methods, which he named \name{the bazaar} and \name{the cathedral}. %FIXME: add reference meillo@37: meillo@38: The following text will focus on the ``bazaar'' model. meillo@38: meillo@37: meillo@37: \section{The role of the community} meillo@37: \freesw\ projects rise and fall with their community! meillo@37: meillo@37: Most \freesw\ programs are developed by a very small group of programmers, often only one person. But they are used by many people. In between the programmers and the users, are people located who are a bit of both. These are the ones that write documentation, find bugs and probably even fix it. They discuss on mailing lists, bulletin boards and \NAME{IRC} chats. The program is often spread by their ``advertising''. meillo@37: meillo@37: The \emph{community} consists of the actual developers and all users that contribute to the program. Contribution can be one of the described ways, or others like providing a server for the project website for example. meillo@37: meillo@37: \emph{Community} is everyone who is in contact through the project. Be it on the mailing list, the discussion board, or by telling the developers about a new feature wanted. meillo@37: meillo@37: There will hardly be a community if no communication channels are available. If the development team does not provide them, there is a chance that enthusiastic %FIXME: better word meillo@37: users set them up on their own. But this is rare and the program needs to be very popular. %TODO: maybe include an example here (w3m?) meillo@37: meillo@37: Projects without a good community tend to die sooner or later. meillo@37: meillo@37: meillo@37: \section{Evolution of a community} meillo@37: Let us look at the process a community establishes: In most times it's only one who has an idea, in the beginning. He starts developing. When others get in contact with the project, there may be some who are so much interested that they start co-developing. Others report bugs, and some only use the program. meillo@37: meillo@43: After some time, one will find a small group of core developers, a larger group of contributers (bugs, patches, documentation) and a very large group of users. The size ratio of the groups vary by type of project. meillo@37: meillo@37: One should have that in mind, when starting a \freesw\ project. meillo@37: meillo@37: meillo@37: \section{Creating a strong community} meillo@37: Building up a good community needs some effort of the main developers. meillo@38: %TODO: search for documents about this topic meillo@37: meillo@37: First communication channels need to be set up, to enable the growth of a community. meillo@37: meillo@38: Second, development should be visible by everyone who is interested in it. Time between work done on the project and its visibility to the public should be kept short. This makes it interesting for other developers to join. Developers are the core of a community. meillo@37: meillo@38: Third, there is a rule of thumb that should be followed: ``Release early, release often!'' %FIXME: add reference meillo@38: Releases are (more) stable versions, primary for users. They should be created, frequently. People will more likely use programs of active projects. meillo@37: meillo@38: Fourth, the developers should try to get the users ``in the boat''. Good communities have a large group of users that do not only receive, but also give something back to the project. The project leaders should motivate users to contribute. This unlocks a big work force and gets lot of unexiting work done. meillo@38: meillo@38: Fifth, documentation matters. Good documentation makes it easy for users and developers to start. And it helps to avoid a lot of unsatisfaction. Documentation is something that shows quality and that people care about the project. meillo@38: meillo@38: And sixth, project leaders should be good %FIXME: ``herrscher'' meillo@38: . Never should they forget what %FIXME: who was it? meillo@38: said: ``%FIXME: Die Könige sind die Sklaven des Volkes. (something like that) meillo@38: ''. They should try to be fair, to motivate, be visionaires and try to put power and work on many shoulders. meillo@38: meillo@38: Not to forget: Every work that was done, every contribution that was made and every idea received needs to be honored in an appropriate way! Voluntier %FIXME: how is it spelled? meillo@38: work lives by acknowledgement of the effort spent.