Cluttering of your $HOME
directory by third party programs is the norm with a standard linux distribution usage. Try to execute ls -A | wc -l
in your $HOME
folder. If you never took steps to de-clutter your $HOME
, chances are that your file count will be relatively high. This is because every program you use creates its own folder under your $HOME
directory and uses it to store all the files it needs for its execution.
Even though making some order through this maze of directories may seem like a useless aesthetic non-problem, I (and other people) think that there is more to it. For example, while setting up a backup system with borgBackup [1], I wanted to save only configuration files, while excluding cache files or other unnecessary files in order to save disk space. However this is hard to implement with a standard cluttered $HOME
folder, since for each program you have to understand which files are configuration, which logs, which cache, etc.
That's where the XDG Base Directory specification [2] comes in. This specification lists a set of directories and default locations, assigning a specific purpose to each one of them. Here is the full official specification [3] if you are interested in the details. The main directories defined in there are:
$XDG_DATA_HOME
which defines the location of data files (defaults to$HOME/.local/share
).$XDG_CONFIG_HOME
which defines the location of configuration files (defaults to$HOME/.config
).$XDG_STATE_HOME
which defines the location of state files (defaults to$HOME/.local/state
).$XDG_CACHE_HOME
which defines the location of non-essential cache files (defaults to$HOME/.cache
).
One may ask, what is the difference between DATA
and STATE
? DATA
is generic information that is not tied to the specific machine (e.g. fonts, downloaded files, etc.), while STATE
is for information related to the program execution on this specific machine (e.g. logs).
The XDG specification is very well done in my opinion, however the majority of programs do not follow it by default. Often times you have to set some environment variable to force the app to behave properly; this process is different for each application and can be very tedious. Thankfully there are a couple of resources that can help us out:
- The xdg-ninja [4], a little script that analyzes your
$HOME
directory and points you to the actions needed to make your programs follow the XDG specification. The "database" used by the script is crowdsourced so if you find it useful make sure to contribute to it! - The XDG Base Directory page on the arch linux wiki [5], which lists ways to make app follow the specification.
If you are developing an application, consider following the XDG Base Directory specification, as it makes things easier for your users.
After using the xdg-ninja and doing a bit of manual work, I managed to reduce my $HOME
file count from 75 to 16. That's an improvement :)