Files
CMake/Help/cpack_gen/appimage.rst

131 lines
3.8 KiB
ReStructuredText

CPack AppImage Generator
------------------------
.. versionadded:: 4.2
CPack `AppImage`_ generator allows to bundle an application into
AppImage format. It uses ``appimagetool`` to pack the application,
and ``patchelf`` to set the application ``RPATH`` to a relative path
based on where the AppImage will be mounted.
.. _`AppImage`: https://appimage.org
The ``appimagetool`` does not scan for libraries dependencies it only
packs the installed content and check if the provided ``.desktop`` file
was properly created. For best compatibility it's recommended to choose
some old LTS distro and built it there, as well as including most
dependencies on the generated file.
The snipped below can be added to your ``CMakeLists.txt`` file
replacing ``my_application_target`` with your application target,
it will do a best effort to scan and copy the libraries your
application links to and copy to install location.
.. code-block:: cmake
install(CODE [[
file(GET_RUNTIME_DEPENDENCIES
EXECUTABLES $<TARGET_FILE:my_application_target>
RESOLVED_DEPENDENCIES_VAR resolved_deps
)
foreach(dep ${resolved_deps})
# copy the symlink
file(COPY ${dep} DESTINATION ${CMAKE_INSTALL_PREFIX}/lib)
# Resolve the real path of the dependency (follows symlinks)
file(REAL_PATH ${dep} resolved_dep_path)
# Copy the resolved file to the destination
file(COPY ${resolved_dep_path} DESTINATION ${CMAKE_INSTALL_PREFIX}/lib)
endforeach()
]])
For Qt based projects it's recommended to call
``qt_generate_deploy_app_script()`` or ``qt_generate_deploy_qml_app_script()``
and install the files generated by the script, this will install
Qt module's plugins.
You must also set :variable:`CPACK_PACKAGE_ICON` with the same value
listed in the Desktop file.
Variables Specific to CPack AppImage Generator
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
.. variable:: CPACK_APPIMAGE_TOOL_EXECUTABLE
Name of the ``appimagetool`` executable, might be located in the build dir,
full path or reachable in ``PATH``.
:Default: ``appimagetool`` :variable:`CPACK_PACKAGE_FILE_NAME`
.. variable:: CPACK_APPIMAGE_PATCHELF_EXECUTABLE
Name of the ``patchelf`` executable, might be located in the build dir,
full path or reachable in ``PATH``.
:Default: ``patchelf`` :variable:`CPACK_APPIMAGE_PATCHELF_EXECUTABLE`
.. variable:: CPACK_APPIMAGE_DESKTOP_FILE
Name of freedesktop.org desktop file installed.
:Mandatory: Yes
:Default: :variable:`CPACK_APPIMAGE_DESKTOP_FILE`
.. variable:: CPACK_APPIMAGE_UPDATE_INFORMATION
Embed update information STRING; if zsyncmake is installed,
generate zsync file.
:Default: :variable:`CPACK_APPIMAGE_UPDATE_INFORMATION`
.. variable:: CPACK_APPIMAGE_GUESS_UPDATE_INFORMATION
Guess update information based on GitHub or GitLab environment variables.
:Default: :variable:`CPACK_APPIMAGE_GUESS_UPDATE_INFORMATION`
.. variable:: CPACK_APPIMAGE_COMPRESSOR
Squashfs compression.
:Default: :variable:`CPACK_APPIMAGE_COMPRESSOR`
.. variable:: CPACK_APPIMAGE_MKSQUASHFS_OPTIONS
Arguments to pass through to mksquashfs.
:Default: :variable:`CPACK_APPIMAGE_MKSQUASHFS_OPTIONS`
.. variable:: CPACK_APPIMAGE_NO_APPSTREAM
Do not check AppStream metadata.
:Default: :variable:`CPACK_APPIMAGE_NO_APPSTREAM`
.. variable:: CPACK_APPIMAGE_EXCLUDE_FILE
Uses given file as exclude file for mksquashfs,
in addition to .appimageignore.
:Default: :variable:`CPACK_APPIMAGE_EXCLUDE_FILE`
.. variable:: CPACK_APPIMAGE_RUNTIME_FILE
Runtime file to use, if not set a bash script will be generated.
:Default: :variable:`CPACK_APPIMAGE_RUNTIME_FILE`
.. variable:: CPACK_APPIMAGE_SIGN
Sign with gpg[2].
:Default: :variable:`CPACK_APPIMAGE_SIGN`
.. variable:: CPACK_APPIMAGE_SIGN_KEY
Key ID to use for gpg[2] signatures.
:Default: :variable:`CPACK_APPIMAGE_SIGN_KEY`