| Blender Documentation Volume I - User Guide: Last modified September 01 2004 S68 | ||
|---|---|---|
| <<< Previous | Installation | Next >>> | 
Relevant to Blender v2.31
This document describes the tools necessary to build Blender from source, either from CVS or from a source package. Building from CVS requires the use of more tools. While this may be a bit more troublesome than building from a source package, this may be necessary for some people. For example, when you want to build Blender for an unsupported platform or when you want to implement some new features.
This is a very early version of this document. This means that it is incomplete and that some procedures or concepts might be incorrect for your system. Please keep this in mind when reading this. Also keep in mind Blender is a complex product which will require you to create the right environment for.
The following paragraphs will describe how and where to get the sources needed for building Blender.
The sources are available on CDROM accompanying this book. You can also download it from the website, http://www.blender3d.org/Download/?sub=Source
CVS stands for Concurrent Versioning System. It is a software configuration tool that keeps the various source files in a central repository. CVS enables developers to quickly update to the latest state of the repository and commit changes. The tool keeps track of the changes between each version of a file. To get the current state of the repository, you don't need to have a username for accessing the sources. This feature is optional, but in an opensource development, it's almost a requirement. To commit changes to the repository, however, you need to have developer access. Since this document only describes how to get the latest state of the sources, the commit procedures are not described here.
To get the latest state of the sources use:
export CVSROOT=:pserver:anonymous@cvs.blender.org:/cvs01
cvs login
password: Enter
cvs -z3 co blender
Please do not use a higher level of compression for accessing the Blender server.
If you already have a working set of files obtained from the server, you can use the update command to update the sources to the current state of the repository. cd to the blender source tree on your system and type in the following command:
cvs -z3 update .
Blender is a package that uses a lot of external packages for expanding its functionality. Each of these packages have, just as Blender, a history of changes. Newer versions of such a package will probably have more features and less known problems. As a developer it is exciting to work with the latest features available to get the most out of the tool. However, the number of developers out there is much lower than the number of end-users who are not interested in the latest feature, these users want an application that works. Since Blender has to run on multiple platforms, all those platforms have to have the same minimum functionality available in the external packages.
The table below displays the packages needed and the minimum version of those packages. Over time it is possible that those minimum versions are increased as the demand for the newer features is high.
Table 1. Minimum version external libraries
| Library | Version | 
|---|---|
| glibc | 2.2.4 | 
| libjpeg | 6b | 
| libpng | 1.0.14 | 
| libsdl | 1.0 | 
| libz | 1.1.4 | 
| mesa | 3.4.2 | 
| openAL | N/A | 
| openGL | 1.1 (1.2 for engine) | 
| python | 2.2 | 
Not all libraries apply to all platforms. The following table gives an overview of the currently supported platforms and the required libraries. An 'X' means that it is needed, a '-' means that it is not needed and an 'O' means that it is optional.
Having the necessary libraries installed and the Blender sources downloaded to your system means that you're now able to build Blender. The entire build process requires some tools to be available on your system. In the table below, the list of tools along with the minimum version is shown. The third column shows if the tool is required for CVS only ('X'). If the tool is not required for a source package build, a '-' is shown.
Table 3. Minimum version tools
| Tool | Version | CVS | Note | 
|---|---|---|---|
| autoconf | 2.53 | X | |
| automake | 1.6.2 | X | |
| cvs | 1.11.1p1 | X | |
| docbook | 3.1 | O | |
| doxygen | N/A | O | |
| gawk | 3.1.0 | X | |
| gcc | 2.96 | - | |
| gettext | 0.11 | - | |
| gmake | 3.79.1 | - | |
| m4 | 1.4 | X | |
| sed | 3.02 | X | |
| sh | 2.05.1 | - | |
| Visual C++ | 6.0 SP5 | - | Windows only | 
|  | Python | 
|---|---|
| Python is not included in this table although it is used to build Blender. The reason that it is not included is because Python is also needed as an external library and thus has to be installed already as has been written in the previous section. | 
There are two build systems for using gcc or cc compilers; regular Makefiles, which stem from the period Blender was developed in the company NaN, and the automake/autoconf "configure" style one. Using "configure" can write over the NaN Makefiles, so you have to choose either one.
For Windows MSVC, Blender supports usage of project files and workspaces.
The files describing detailed build information are located in the blender root directory:
INSTALL: general information, download links for libraries
INSTALL.AUTO: using autoconf and configure scripts
INSTALL.MAKE: using regular makefiles
INSTALL.MSVC: using Microsoft Visual C project files
| <<< Previous | Home | Next >>> | 
| Installation | Up | Understanding the interface |