Installation aus den Quelldateien

Die Installation aus dem Quellcode ist erforderlich, wenn Sie die neuesten Funktionen nutzen möchten, wenn die vorherige Version veraltet ist, wenn Sie an der Verbesserung von Siril teilnehmen möchten oder nicht alle Abhängigkeiten verwenden möchten.

Beschaffung der Quelldateien

Die Quelldateien werden in einem Git-Repository gespeichert, das Sie beim ersten Mal mit diesem Befehl herunterladen können:

git clone --recurse-submodules https://gitlab.com/free-astro/siril.git

Aktualisieren Sie es regelmäßig durch Eingabe von git pull im Siril-Basisverzeichnis:

git pull
git submodule update --recursive

Abhängigkeiten

Siril ist auf eine Reihe von Bibliotheken angewiesen, von denen die meisten in der Linux-Distribution oder im Paketmanager Ihrer Wahl verfügbar sein sollten. Die Namen der betriebssystemspezifischen Pakete sind in den einzelnen Abschnitten unten aufgeführt. Obligatorische Abhängigkeiten sind:

  • gtk+3 (Bibliothek für die grafische Benutzeroberfläche), mindestens Version 3.20

  • adwaita-icon-theme (Icons) um das "look and feel" der Benutzeroberfläche zu unterstützen.

  • cfitsio (Unterstützung des FITS-Dateiformats).

  • fftw (Bibliothek zur diskreten Fourier Transformation).

  • gsl (The GNU Scientific Library), Version 1 oder 2 beginnend mit Siril 0.9.1 or SVN Revision 1040.

  • OpenCV und ein C++ Compiler für einige Funktionen der Bildbearbeitung.

  • Little CMS ein Open-Source Farbverwaltungssystem

  • wcslib für die Verarbeitung des Welt-Koordinatensystems (WCS), Objektnamen und photometrische Farbkalibrierung.

  • gtksourceview4 for multiline text editing. GtkSourceView adds support for syntax highlighting, undo/redo, file loading and saving, search and replace, a completion system, printing, displaying line numbers, and other features typical of a source code editor.

Bemerkung

Auch wenn Siril seit Version 0.9.9 in der Konsole laufen kann, ist es immer noch gegen die grafischen Bibliotheken gelinkt, so dass Sie immer noch GTK++ benötigen, um es zu kompilieren und auszuführen.

Optionale Abhängigkeiten sind:

  • openmp für Multithreading. Obwohl optional, wird diese Abhängigkeit dringend empfohlen, da die Leistung dadurch wesentlich besser ist. Das Flag dieser Option ist standardmäßig auf true gesetzt. Das heißt, wenn openmp nicht auf Ihrem Computer installiert ist, müssen Sie „-Dopenmp=false“ im Meson-Setup hinzufügen.

  • libtiff,

  • libraw, libtiff, libXISF, libjpeg, libjxl, libpng, libheif für die Unterstützung des lesens und schreibens von RAW, TIFF, XISF, JPEG, JPEG XL, PNG und HEIF Bildformaten. Die Bibliotheken werden zur Kompilierungszeit erkannt.

  • libraw, libXISF, libheif für den Import von RAW, XISF, HEIF und AVIF Bilddateien. Die Bibliothek wird zur Kompilierungszeit erkannt.

  • FFMS2 für die native Unterstützung von Videodateien als Bildsequenzen. Es ermöglicht auch die Extraktion von Einzelbildern aus vielen Arten von Videodateien, auch für andere Zwecke als Astronomie. Versionen <2.20 haben einen lästigen Fehler. Es wird empfohlen, die neueste Version zu installieren.

  • ffmpeg (or libav), providing libavformat, libavutil (>= 55.20), libavcodec, libswscale und libswresample für die Unterstützung des Exports von MP4-Sequenzen.

  • wcslib für die Verarbeitung des Welt-Koordinatensystems (WCS), Objektnamen und photometrische Farbkalibrierung.

  • Exiv2 um Metadaten der Bilder zu verwalten.

  • libcurl für Astrometrie und photometrische Anfragen.

  • libgit2 um einen lokalen Klon des Siril-Scripts-Repositorys zu verwalten.

Build-Abhängigkeiten

Für die Installation aus dem Quellcode müssen Sie die Basisentwicklungspakete installieren:

git, autoconf, automake, libtool, intltool, pkg-tools, make, cmake, gcc, g++

Die Compiler gcc und g++ aus dieser Liste können durch clang und clang++ ersetzt werden (wir verwenden sie für die Entwicklung), wahrscheinlich auch durch andere.

The autotools packages (autoconf, automake, probably some others) can be replaced by meson.

Grundsätzlicher Build-Prozess

Siril kann entweder mit autotools oder mit meson kompliert werden.

Meson

Der empfohlene Weg ist es, meson und ninja zu verwenden:

meson setup _build --buildtype release

cd _build
ninja
ninja install

Um einige Abhängigkeiten oder Funktionen zu deaktivieren, verwenden Sie je nach Fall die Meson-Optionen „-Dfeature=false“ oder „-Denable-feature=yes“.

Die folgende Tabelle listet alle konfigurierbaren Optionen auf.

Option

Typ

Wert

Auswahl

Beschreibung

relocatable-bundle

combo

platform-default

[ 'yes', 'no', 'platform-default' ]

bauen mit Ressourcen, die unter demselben Präfix gebündelt werden

openmp

Boolean

true

Unbekannt

bauen mit OpenMP-Support

exiv2

Boolean

true

Unbekannt

bauen mit exiv2-Support

libgit2

Boolean

true

Unbekannt

bauen mit libgit2 Git-Integration

libraw

Boolean

true

Unbekannt

bauen mit LibRaw-Support

libtiff

Boolean

true

Unbekannt

bauen mit TIFF-Support

libjpeg

Boolean

true

Unbekannt

bauen mit JPEG-Support

libjxl

Boolean

true

Unbekannt

bauen mit JPEG-XL-Support

libpng

Boolean

true

Unbekannt

bauen mit PNG-Support

libheif

Boolean

true

Unbekannt

bauen mit HEIF-Support

libXISF

Boolean

true

Unbekannt

bauen mit XISF-Support

ffms2

Boolean

true

Unbekannt

bauen mit FFMS2-Support

ffmpeg

Boolean

true

Unbekannt

Bauen mit FFmpeg-Support

libcurl

Boolean

true

Unbekannt

Benutze libcurl für Webzugriffe

criterion

Boolean

false

Unbekannt

bauen mit Criterion-Support

flatpak-id

Zeichenkette

Unbekannt

set by flatpak-builder if building a flatpak

Autotools

Die Autotools-Methode ist in der Unix-Welt bekannt. Sobald der Quellcode heruntergeladen und die Voraussetzungen installiert wurden, ist die allgemeine Methode zum Erstellen wie folgt:

./autogen.sh
make
make install

Für die letzte Zeile benötigen Sie möglicherweise Superuser-Rechte.

Es kann sein, dass Sie dem Compiler bestimmte Optionen übergeben möchten, z.B. wenn Sie die Optimierung und die Installation in /opt anstelle des Standardverzeichnisses /usr/local wünschen:

CFLAGS='-mtune=native -O3' ./autogen.sh --prefix=/opt

Um Siril zu starten, lautet der Befehlsname siril oder siril-cli.

Installation auf Debian-ähnlichen Systemen

Es kann sein, dass Sie ein .deb-Paket bauen möchten, anstatt eine nicht-paketierte Version zu benutzen. In diesem Fall lesen Sie diese Hilfe. Insbesondere, um die Abhängigkeiten zu installieren, können Sie diesen Befehl verwenden:

apt build-dep siril

Ansonsten finden Sie hier die Liste der Pakete für die aktuelle Version:

  • Für das Build-System benötigte Pakete:

autoconf automake make gcc g++ libtool intltool pkg-config cmake
  • Liste der Pakete für obligatorische Abhängigkeiten:

libgtk-3-dev libcfitsio-dev libfftw3-dev libgsl-dev libopencv-dev
liblcms2-dev wcslib-dev libgtksourceview-4-dev
  • Liste der Pakete für optionale Abhängigkeiten:

libcurl4-gnutls-dev libpng-dev libjpeg-dev libtiff5-dev
libraw-dev gnome-icon-theme libavformat-dev libavutil-dev libavcodec-dev
libswscale-dev libswresample-dev libgit2-dev libheif-dev
libexiv2-dev libjxl-dev liblz4-dev libpugixml-dev libxisf-dev

für die Unterstützung von Videodateien (AVI und andere):

libffms2-dev

Installation auf Arch Linux

Zwei Pakete sind im AUR verfügbar: siril und siril-git. Laden Sie PKGBUILD oder das Repository herunter, installieren Sie die Abhängigkeiten, lassen Sie makepkg laufen, um das Paket zu bauen und pacman -U, um es zu installieren.

Abhängigkeiten (obligatorisch und einige optional):

pacman -S base-devel cmake git intltool gtk3 fftw cfitsio gsl opencv
exiv2 libraw wcslib gtksourceview4

LittleCMS version

Siril benötigt zum Erstellen lcms2 >= 2.14. Diese Version ist erforderlich, um eine Optimierung des Farbmanagementcodes zu ermöglichen. Eine ausreichende Version ist in Debian Testing und Ubuntu 23.04 verfügbar, die aktuelle Ubuntu LTS-Version bietet jedoch eine ältere Version und andere Betriebssystemdistributionen möglicherweise auch. Wenn Sie ein älteres Betriebssystem verwenden, das lcms2 >= 2.14 nicht bereitstellt, können Sie Pakete entweder manuell von einer neueren Version Ihrer Distribution installieren oder lcms2 aus dem Quellcode erstellen und installieren. Die lcms2-Quelle ist in „ihrem Git-Repository <https://github.com/mm2/Little-CMS>“ verfügbar.

Fehler beim Erstellen

Jeder Commit für Siril Git wird automatisch in einer Standard-Build-Umgebung für Linux, Windows und MacOS mithilfe der Gitlab-CI-Infrastruktur erstellt. Dies bedeutet, dass wir sehr zuversichtlich sind, dass der Master-Zweig sowie getaggte Releases erfolgreich erstellt werden, sofern eine korrekt eingerichtete Build-Umgebung mit den erforderlichen installierten Abhängigkeiten vorhanden ist.

Wenn ein Build-Fehler auftritt, deutet dies wahrscheinlich auf ein Problem mit Ihrer Build-Umgebung oder falsch installierte Abhängigkeiten hin. Denken Sie daran, dass viele Distributionen eine separate Installation von Entwicklungspaketen erfordern, die die erforderlichen Header-Dateien enthalten. Überprüfen Sie den CI-Bericht für den Git-Commit, den Sie erstellen möchten. Für den unwahrscheinlichen Fall, dass ein Build-Fehler angezeigt wird, können Sie sicher sein, dass das Team daran arbeitet, das Problem zu beheben. Andernfalls, wenn die CI-Pipeline grüne Häkchen anzeigt, müssen Sie alle Probleme mit Ihrer eigenen Build-Umgebung überprüfen und beheben.

Wenn Sie immer noch der Meinung sind, dass Sie ein Build-Problem gefunden haben, das von der CI-Pipeline nicht gemeldet wurde – beispielsweise wenn Sie auf einer anderen Plattform wie BSD bauen, die die Entwickler nicht regelmäßig verwenden –, können Sie gerne ein Problem melden auf gitlab.

Beachten Sie, dass Probleme nur für den Master-Zweig oder getaggte Releases gemeldet werden sollten. Wenn Sie neue Funktionen in Merge-Requests testen, geben Sie bitte Feedback in den Kommentaren zum entsprechenden Merge-Request.

System Python

If you are building Siril yourself you need to ensure you have a working system Python installation including pip and venv. Note the last point because on some systems (at least Debian / Ubuntu based systems, possibly others) Python is split into many packages and you must ensure the packages that provide pip and venv are installed.