CutefishOS Installer.
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.
 
 
 
 
 
 
Teo Mrnjavac cd9d09569c Update submodule. 9 years ago
.tx Add Transifex repo config. 10 years ago
CMakeModules Make Boost.Python3 cmake script work properly on Debian again 9 years ago
ci Fix permissions. 9 years ago
data/images New icon, PNG. 9 years ago
hacking Update RELEASE.md 9 years ago
lang Automatic merge of Transifex translations 9 years ago
src Yank out gzip stuff. 9 years ago
thirdparty Update submodule. 9 years ago
.editorconfig Added .editorconfig 9 years ago
.gitattributes Add testmodule.py and globalStorage.yaml to export-ignore for tarballs. 9 years ago
.gitignore Update .gitignore. 9 years ago
.gitmodules Add libcrashreporter-qt submodule. 9 years ago
AUTHORS AUTHORS file. 10 years ago
CMakeLists.txt Set THIRDPARTY_DIR 9 years ago
CalamaresAddBrandingSubdirectory.cmake Rely on CMake if the branding component has a CMakeLists.txt. 10 years ago
CalamaresAddLibrary.cmake Add proper QResrouce system to libcalamaresui, finish up prepare checks 10 years ago
CalamaresAddModuleSubdirectory.cmake Allow and glob multiple .conf files in module subdirectory. 9 years ago
CalamaresAddPlugin.cmake Allow and glob multiple .conf files in module subdirectory. 9 years ago
CalamaresBuildTreeSettings.cmake.in CMake skeleton. 11 years ago
CalamaresConfig.cmake.in We have a Python API for jobmodules! 10 years ago
CalamaresConfigVersion.cmake.in CMake skeleton. 11 years ago
CalamaresUse.cmake.in New CalamaresAddBrandingSubdirectory macro. 10 years ago
HACKING.md Update HACKING.md 9 years ago
LICENSE Update LICENSE 11 years ago
README.md Update README.md 9 years ago
calamares.desktop Use pkexec to execute calamares with the right permissions 10 years ago
cmake_uninstall.cmake.in CMake skeleton. 11 years ago
com.github.calamares.calamares.policy Rename pkexec policy file to .policy extension. 10 years ago
settings.conf Update settings defaults. 9 years ago

README.md

Calamares: Distribution-Independent Installer Framework


GitHub release Build Status Coverity Scan Build Status GitHub license

Report a Bug Contribute Translate Freenode (IRC): #calamares

Dependencies

Main:

  • Compiler with C++11 support: GCC >= 4.9.0 or Clang >= 3.5.1
  • CMake >= 2.8.12
  • Qt >= 5.3
  • yaml-cpp >= 0.5.1
  • Python >= 3.3
  • Boost.Python >= 1.55.0
  • dmidecode

Modules:

  • welcome:
  • NetworkManager
  • UPower
  • partition:
  • extra-cmake-modules
  • KF5: KCoreAddons, KConfig, KI18n, KIconThemes, KIO, KService
  • KPMcore >= 2.1
  • sgdisk
  • bootloader:
  • systemd-boot or GRUB
  • sgdisk
  • unpackfs:
  • squashfs-tools
  • rsync

Deployment

Setting up branding

Working with modules

Building

Clone Calamares from GitHub and cd into the calamares directory, then:

$ git submodule init
$ git submodule update
$ mkdir build
$ cd build
$ cmake -DCMAKE_BUILD_TYPE=Debug ..
$ make

Supported variables for CMake

  • WITH_PYTHON - if this is set to false, the Python module interface will not be built. Default is true.
  • SKIP_MODULES - takes a space-separated list of module names that should not be built even if present in src/modules (e.g. cmake -DSKIP_MODULES="partition mount umount welcome" ..). Default is empty.

Design Notes

Calamares is currently split as follows:

  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).
  1. 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.
  • Supports branding components.
  • Presents a bunch of pages in a scripted order, enqueues jobs in the back-end library.
  1. calamares - The main executable.
  • A thin wrapper around libcalamaresui; starts up and plugs together all the parts.