You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

47 lines
2.2 KiB
Markdown

### Calamares: Distribution-Independent Installer Framework
10 years ago
---------
11 years ago
10 years ago
| [![Build Status](http://calamares.io/ci/buildStatus/icon?job=calamares-master)](http://calamares.io/ci/job/calamares-master/) | [Report a Bug](http://calamares.io/bugs/) | [Contribute](https://github.com/calamares/calamares/blob/master/HACKING.md) | [Translate](https://www.transifex.com/projects/p/calamares/) | Freenode (IRC): #calamares |
|:-----------------------------------------:|:--------------------------:|:--------------------------:|:--------------------------:|:--------------------------:|
11 years ago
### Dependencies
10 years ago
| Main | Welcome module | Partitioning module | Bootloader module |
10 years ago
|:----:|:--------------:|:-------------------:|:-----------------:|
10 years ago
| CMake >= 2.8.12 | NetworkManager | extra-cmake-modules | gummiboot or GRUB2 |
10 years ago
| Qt >= 5.3 | UPower | kconfig (part of KF5) | sgdisk |
10 years ago
| yaml-cpp >= 0.5.1 | | solid (part of KF5) | |
10 years ago
| Python >= 3.3 | | kcoreaddons (part of KF5) | |
| Boost.Python >= 1.55.0 | | ki18n (part of KF5) | |
10 years ago
| dmidecode | | sgdisk | |
11 years ago
10 years ago
### Deployment
10 years ago
[__Setting up branding__](https://github.com/calamares/calamares/blob/master/src/branding/README.md)
10 years ago
10 years ago
[__Working with modules__](https://github.com/calamares/calamares/blob/master/src/modules/README.md)
10 years ago
11 years ago
### Building
10 years ago
Clone Calamares from GitHub and `cd` into the calamares directory, then:
11 years ago
```
$ git submodule init
$ git submodule update
11 years ago
$ mkdir build
$ cd build
10 years ago
$ cmake -DCMAKE_BUILD_TYPE=Debug -DWITH_PARTITIONMANAGER=1 ..
11 years ago
$ make
```
10 years ago
### Design Notes
10 years ago
Calamares is currently split as follows:
10 years ago
1. __libcalamares__ - The back-end library.
* Only depends on QtCore, yaml-cpp, Python and Boost.Python.
* Provides a job queue and generic jobs.
* Comes with 3 job interfaces: C++, Python and process (the latter is very limited).
2. __libcalamaresui__ - The front-end library.
* Same dependencies as libcalamares, plus QtWidgets and other Qt modules.
* Comes with a module loading system, for different kinds of plugins.
10 years ago
* Supports branding components.
10 years ago
* Presents a bunch of pages in a scripted order, enqueues jobs in the back-end library.
3. __calamares__ - The main executable.
* A thin wrapper around libcalamaresui; starts up and plugs together all the parts.