Flatpak
Flatpak is software for deploying and virtualising desktop apps on Linux. It provides a sandboxed environment, so application software runs in partial isolation from other apps and the operating system. Software written with Lazarus and Free Pascal can be adapted for Flatpak.
Instructions
- Assume an application called App with Flatpak ID: com.domain.App
- Create a file named com.domain.App.metainfo.xml:
- More information for metainfo file specification: MetaInfo guidelines.
- The list of supported categories: Registered Categories.
- Brand color preview
<?xml version="1.0" encoding="UTF-8"?>
<component type="desktop-application">
<id>com.domain.App</id>
<name>App</name>
<summary>Example application</summary>
<developer id="org.example">
<name>Developer name</name>
</developer>
<url type="homepage">https://domain.com/App/</url>
<metadata_license>CC0-1.0</metadata_license>
<project_license>CC0-1.0</project_license>
<description>
<p>
A description of the App.
</p>
</description>
<launchable type="desktop-id">com.domain.App.desktop</launchable>
<branding>
<color type="primary" scheme_preference="light">#ff00ff</color>
<color type="primary" scheme_preference="dark">#993d3d</color>
</branding>
<screenshots>
<screenshot type="default">
<caption>Main screenshot</caption>
<image>https://domain.com/Screenshot.jpg</image>
</screenshot>
<screenshot>
<caption>Another screenshot</caption>
<image>https://domain.com/Screenshot2.jpg</image>
</screenshot>
</screenshots>
<releases>
<release version="1.0.0" date="2024-01-01">
<url type="details">https://domain.com/Release_notes.txt</url>
<description>
<ul>
<li>Added new.</li>
<li>Changed existing.</li>
<li>Fixed bug.</li>
</ul>
</description>
</release>
</releases>
<categories>
<category>Games</category>
</categories>
<content_rating type="oars-1.1"/>
</component>
- Create a file named com.domain.App.yml:
app-id: com.domain.App
runtime: org.kde.Platform
runtime-version: '5.15-24.08'
sdk: org.kde.Sdk
sdk-extensions:
- org.freedesktop.Sdk.Extension.freepascal
command: App
finish-args:
- --share=ipc
- --socket=fallback-x11
- --socket=wayland
- --device=dri
modules:
- name: qt5pas
buildsystem: qmake
config-opts:
- -after
- target.path=/app/lib
sources:
- type: shell
commands:
- cp -r /usr/lib/sdk/freepascal/share/lazarus/lcl/interfaces/qt5/cbindings/. .
- name: App
sources:
- type: svn
url: https://domain.com/App/trunk
revision: r1
buildsystem: simple
build-commands:
- |
. /usr/lib/sdk/freepascal/enable.sh
lazbuild --build-mode=Release --ws=qt5 App.lpi
- install -Dm755 App -t $FLATPAK_DEST/share/App
- install -d $FLATPAK_DEST/bin
- ln -s $FLATPAK_DEST/share/App/App $FLATPAK_DEST/bin/App
- install -Dm644 ${FLATPAK_ID}.desktop -t $FLATPAK_DEST/share/applications
- install -Dm644 App.png $FLATPAK_DEST/share/icons/hicolor/256x256/apps/${FLATPAK_ID}.png
- install -Dm644 ${FLATPAK_ID}.metainfo.xml $FLATPAK_DEST/share/metainfo/${FLATPAK_ID}.metainfo.xml
- Create a file com.domain.App.desktop:
[Desktop Entry]
Encoding=UTF-8
Name=App
Comment=Example application
Exec=App
Icon=com.domain.App.png
Terminal=false
Type=Game
Categories=Game
StartupNotify=true
MimeType=application/type1;application/type2
Keywords=keyword1;keyword1;keyword3
- Create a build script named build.sh:
#!/bin/bash
BUILD_DIR=build
REPO_DIR=repo
FLATPAK_ID=com.domain.App
# Install dependencies
flatpak install --system flathub org.kde.Sdk//5.15-24.08
flatpak install --system flathub org.kde.Platform//5.15-24.08
flatpak install --system flathub org.freedesktop.Sdk.Extension.freepascal//24.08
flatpak install --system flathub org.flatpak.Builder
# Build
flatpak run org.flatpak.Builder --force-clean --sandbox --user --install --ccache --mirror-screenshots-url=https://dl.flathub.org/media/ --repo=$REPO_DIR $BUILD_DIR $FLATPAK_ID.yml
# Run
flatpak run $FLATPAK_ID
# Linter
flatpak run --command=flatpak-builder-lint org.flatpak.Builder manifest $FLATPAK_ID.yml
flatpak run --command=flatpak-builder-lint org.flatpak.Builder repo $REPO_DIR
- Run the build.sh script and test the application.
- Follow the submission process to submit your app to Flathub.
Gtk2
Flatpak supports both Qt and Gtk toolkits. To use legacy Gtk2 toolkit which is needed to run many Lazarus apps use the following yml file example:
app-id: com.domain.App
runtime: org.freedesktop.Platform
runtime-version: '24.08'
sdk: org.freedesktop.Sdk
sdk-extensions:
- org.freedesktop.Sdk.Extension.freepascal
command: App
finish-args:
- --share=ipc
- --socket=fallback-x11
- --socket=wayland
- --device=dri
modules:
- shared-modules/gtk2/gtk2.json
- name: App
sources:
- type: svn
url: https://domain.com/App/trunk
revision: r1
buildsystem: simple
build-commands:
- |
. /usr/lib/sdk/freepascal/enable.sh
lazbuild --build-mode=Release --ws=gtk2 App.lpi
- install -Dm755 App -t $FLATPAK_DEST/share/App
- install -d $FLATPAK_DEST/bin
- ln -s $FLATPAK_DEST/share/App/App $FLATPAK_DEST/bin/App
- install -Dm644 ${FLATPAK_ID}.desktop -t $FLATPAK_DEST/share/applications
- install -Dm644 App.png $FLATPAK_DEST/share/icons/hicolor/256x256/apps/${FLATPAK_ID}.png
- install -Dm644 ${FLATPAK_ID}.metainfo.xml $FLATPAK_DEST/share/metainfo/${FLATPAK_ID}.metainfo.xml
- Add shared-modules submodule to your git repository:
git submodule add https://github.com/flathub/shared-modules.git
- On Flathub page the app built with Gtk2 will be marked as "Legacy windowing system - Uses a legacy windowing system".
Debugging
Normally flatpak-builder removes debug symbols from the executable and moves them to the extra $FLATPAK_ID.Debug package. If you want to build your application with debug symbols you need to add the following option to your yml file:
build-options:
no-debuginfo: true
and rebuild your project with debug build mode if defined:
lazbuild --build-mode=Debug --ws=qt5 App.lpi
To run installed flatpak in shell mode use:
flatpak run --command=sh --devel com.domain.App
Run the app:
/app/bin/App
See also Flatpak Debugging