This page describes the AppDir format. AppDirs are the “source” of AppImages. When building an AppImage, a file system image is built from such a directory, to which a runtime is prepended.
The AppDir format has first been described by ROX Filer, and has since been extended by the AppImage project to suit their needs.
As the name intends, AppDirs are normal directories with some special contents:
A file (executable, script, etc.) or symlink, serving as the “entry point” for a specific application. It is located in the root directory that makes up an AppDir, so it can be used to calculate paths relative to the (later mounted) AppDir.
Symlink to an icon, normally located in the root directory. Can be used by e.g., thumbnailers, to display application icons rather than a generic filetype symbol.
These two entries have been re-used from ROX Filer’s specification. ROX Filer actually specifies additional (but optional) entries, however, AppImage doesn’t use these. Instead, the following ones have been introduced:
A desktop file located in the root directory, describing the payload application. As AppImage is following the principle one app = one file, one desktop file is enough to describe the entire AppImage. There MUST NOT be more than one desktop file in the root directory. The name of the file doesn’t matter, as long as it carries the
.desktopextension. Can be a symlink to subdirectories such as
Application’s icon in the best available quality, ideally a vector graphic. Can be a symlink to subdirectories such as
usr/share/icons/hicolor/.... In most cases, ref-diricon is a symlink to this file. The filename must be equal to what is set in the
Icon=entry in the desktop file. It is recommended by AppImage and also the XDG icon specifications to use a lower-case filename which is equal to the desktop file’s name.
Icon=entry SHOULD NOT contain the file extension, the actual file’s filename however SHOULD carry the extension.
These four types of entries MUST be contained in the AppDir to conform to this specification.
In contrary to the rules in the previous section, the ones introduced in this section are no basic requirement. However, this is the recommended structure to put applications into AppDirs. It’s picking up ideas from well-known, widely spread Linux standards such as the Filesystem Hierarchy Standard (part of the Linux Standards Base).
A very good summary of the FHS can be found on Wikipedia.
Analog to the FHS, most AppDirs, especially the ones created by the official tools such as linuxdeploy, contain a
usr originally abbreviated unix system resources. According to the FHS, it contains shared, read-only data, which perfectly suits AppImage’s needs, as AppImages are read-only, too.
The directory contains applications, (shared) libraries, desktop files, icons etc., in separate directories. Only a few of them are useful for AppDirs:
Executables that can be called by a user.
(Shared) libraries used by applications in
Architecture-independent (shared) data. Inside this directory, some special directories are commonly placed:
Contains desktop files for applications in
bin. Normally, there’s just one desktop file in this directory, which is symlinked in the root directory.
Directory containing so-called icon themes. Contains at least one, but often a set of icons for the main application. The icons are referred to by the root desktop file, which means the same constraints apply. Example path:
<root>/usr/share/icons/hicolor/256x256/apps/myapp.pngIcon themes placed in this directory are copied to the system during so-called desktop integration.