X Desktop Group

XDG (frequently referred to in the context of the XDG Base Directory Specification) stands for “X Desktop Group”, which was a name previously associated with the freedesktop.org project. The term XDG has come to represent a set of standards and specifications for desktop environments and applications to enhance consistency and interoperability on Linux and other Unix-like operating systems.

One of the most widely implemented parts of XDG is the XDG Base Directory Specification, which standardizes file and directory locations to simplify configuration, reduce clutter and promote consistency.

The XDG Base Directory Specification defines a set of standard environment variables that applications can use to determine where to read or store various types of data. The specification organizes files into three main categories:

Configuration Files ($XDG_CONFIG_HOME) stores user-specific configuration files. The default location is one of the hidden files of your home directory, ~/.config. For example: A text editor might store its settings in ~/.config/editor/settings.conf.

Data Files ($XDG_DATA_HOME) stores user-specific data files (e.g., saved games, application data, downloaded files). The default is, ~/.local/share. A music player might store playlists in ~/.local/share/musicplayer/playlists/.

Cache Files ($XDG_CACHE_HOME) store non-essential, user-specific cached files (e.g., temporary data, thumbnails). Default, ~/.cache. A web browser might cache page resources in ~/.cache/browser/cache.

In addition, there are environment variables for system-wide files:

Configuration Directories ($XDG_CONFIG_DIRS) specifies system-wide configuration directories. The default location is, /etc/xdg. Applications might look for fallback configuration files here if user-specific ones are unavailable.

Data Directories ($XDG_DATA_DIRS) specifies system-wide data directories. It’s default location is, /usr/local/share:/usr/share. Global application data (e.g., icons or fonts) might reside in these directories.

How XDG Works in Practice

Applications should first check the relevant XDG environment variables (e.g., $XDG_CONFIG_HOME, $XDG_DATA_HOME). If the variable is set, the application uses the specified directory. If the variable is unset, the application falls back to the default directory (e.g., ~/.config for configuration files).

The directories specified by $XDG_CONFIG_DIRS or $XDG_DATA_DIRS may contain multiple paths separated by colons (:). Applications should search these paths in order, using the first one where a relevant file is found.

Users can customize the behavior of applications by setting these environment variables in their shell configuration files (e.g., .bashrc, .zshrc). For example,
bash export XDG_CONFIG_HOME="$HOME/my_custom_config" export XDG_DATA_HOME="$HOME/my_custom_data".

If a directory does not exist, applications should create it as needed. If a required file is not found in the user-specific directories, applications may look in the system-wide directories for defaults.

Benefits of XDG Compliance

Prior to the XDG specification, applications would store configuration files directly in the home directory (e.g., ~/.appname). XDG-compliant applications centralize such files under well-defined directories, making the home directory cleaner.

By adhering to a common standard, applications ensure a predictable and organized structure for configuration, data and cache files. Users can easily override default directories by setting the appropriate environment variables, allowing flexibility. Users can back up specific directories (~/.config, ~/.local/share) to preserve configurations or data, simplifying migration to new systems.

XDG in Action

Suppose an application named “MyApp” needs to store a configuration file. The application checks if $XDG_CONFIG_HOME is set (e.g., /home/user/myconfigs). If set, it saves its configuration in $XDG_CONFIG_HOME/MyApp/config. If $XDG_CONFIG_HOME is not set, it defaults to ~/.config and stores the configuration in ~/.config/MyApp/config. For data files, the process is similar but uses $XDG_DATA_HOME instead.

While many modern applications follow the XDG Base Directory Specification, some legacy applications and scripts still store files directly in the home directory (e.g., ~/.appname), leading to mixed practices. Encouraging developers to transition older software to XDG compliance is an ongoing process.

Resources

  • Official documentation: XDG Base Directory Specification
  • Community guides and FAQs: Various Linux and Unix forums provide user-friendly explanations and tutorials for working with XDG-compliant applications.