XDG Base Directory

From ArchWiki
(Redirected from XDG Base Directory support)

This article summarizes the XDG Base Directory specification in #Specification and tracks software support in #Support.


Please read the full specification. This section will attempt to break down the essence of what it tries to achieve.

Only XDG_RUNTIME_DIR is set by default through pam_systemd(8). It is up to the user to explicitly define the other variables according to the specification.

See Environment variables#Globally for information on defining variables.

User directories

    • Where user-specific configurations should be written (analogous to /etc).
    • Should default to $HOME/.config.
    • Where user-specific non-essential (cached) data should be written (analogous to /var/cache).
    • Should default to $HOME/.cache.
    • Where user-specific data files should be written (analogous to /usr/share).
    • Should default to $HOME/.local/share.
    • Where user-specific state files should be written (analogous to /var/lib).
    • Should default to $HOME/.local/state.
    • Used for non-essential, user-specific data files such as sockets, named pipes, etc.
    • Not required to have a default value; warnings should be issued if not set or equivalents provided.
    • Must be owned by the user with an access mode of 0700.
    • Filesystem fully featured by standards of OS.
    • Must be on the local filesystem.
    • May be subject to periodic cleanup.
    • Modified every 6 hours or set sticky bit if persistence is desired.
    • Can only exist for the duration of the user's login.
    • Should not store large files as it may be mounted as a tmpfs.
    • pam_systemd sets this to /run/user/$UID.

System directories

    • List of directories separated by : (analogous to PATH).
    • Should default to /usr/local/share:/usr/share.
    • List of directories separated by : (analogous to PATH).
    • Should default to /etc/xdg.


Tango-view-fullscreen.pngThis article or section needs expansion.Tango-view-fullscreen.png

Reason: The current supported/partial/hardcoded split is not detailed enough and can be misleading. The tables could be merged into one (with more fields added on how the programs work with the specification) or differently named categories could be used. (Discuss in Talk:XDG Base Directory#Add description of support categories)

This section exists to catalog the growing set of software using the XDG Base Directory Specification introduced in 2003. This is here to demonstrate the viability of this specification by listing commonly found dotfiles and their support status. For those not currently supporting the Base Directory Specification, workarounds will be demonstrated to emulate it instead.

The workarounds will be limited to anything not involving patching the source, executing code stored in environment variables or compile-time options. The rationale for this is that configurations should be portable across systems and having compile-time options prevent that.

Hopefully this will provide a source of information about exactly what certain kinds of dotfiles are and where they come from.


When contributing make sure to use the correct section.

Nothing should require code evaluation (such as vim and VIMINIT), patches or compile-time options to gain support and anything which does must be deemed hardcoded. Additionally, if the process is error prone or difficult, it should also be classified as hardcoded.

  • The first column should be either a link to an internal article, a Template:Pkg or a Template:AUR.
  • The second column is for any legacy files and directories the project had (one per line), this is done so people can find them even if they are no longer read.
  • In the third, try to find the commit or version a project switched to XDG Base Directory or any open discussions and include them in the next two columns (two per line).
  • The last column should include any appropriate workarounds or solutions. Please verify that your solution is correct and functional.


Application Legacy Path Supported Since Discussion Notes
actAUR ~/.actrc 1656 [1] XDG_CONFIG_HOME/act/actrc

If the legacy path ~/.actr is present, it will take precedence.

ALSA ~/.asoundrc 577df36


[2] XDG_CONFIG_HOME/alsa/asoundrc
anacondaAUR ~/.conda/.condarc, ~/.conda/condarc, ~/.conda/condarc.d/, ~/.condarc 4.11.0 [3] [4] Previous versions required setting variables in condarc:
  # Replace /home/user/.local/share with your $XDG_DATA_HOME path, as the
    # `conda-build.root-dir` option does not support environment expansion
  root-dir: /home/user/.local/share/conda/conda-bld
  - ${XDG_DATA_HOME}/conda/envs
  - ${XDG_CACHE_HOME}/conda/pkgs
Android Studio ~/.AndroidStudioX.X Android Studio 4.1

Location overview by Google does not mention XDG - paths could be hardcoded instead of using the proper variable, though that is unlikely as Intellij IDEA, which Android Studio is based on, implements it properly as well

Anki ~/Anki, ~/Documents/Anki [5] [6] [7] Uses $XDG_DATA_HOME/Anki2 as default if no older location exists, can be changed by using anki -b <anki_dir>
antimicroxAUR ~/.antimicro, ~/.antimicrox edba864 [8]
apvlvAUR ~/.apvlvrc [9] [10] Uses XDG_CONFIG_HOME/apvlv/apvlvrc now if it exist.
aria2 ~/.aria2 8bc1d37 [11]
atuin ~/.config/atuin ~/.local/share/atuin 156893d
asunder ~/.asunder ~/.asunder_album_artist ~/.asunder_album_genre ~/.asunder_album_title 2.9.0[dead link 2021-05-17 ⓘ] [12][dead link 2021-05-17 ⓘ] Uses XDG_CONFIG_HOME/asunder/asunder for ~/.asunder and XDG_CACHE_HOME/asunder/asunder_album_... for the other 3 files. Legacy paths are not removed after migration, they have to be deleted manually.
audacity ~/.audacity-data/ 3.2.0 [13] Uses new locations if legacy do not exist:
binwalk ~/.binwalk 2051757 [14] XDG_CONFIG_HOME/binwalk
bitwarden-cli ~/.config/Bitwarden CLI 1.7.1 [15]

The BITWARDENCLI_APPDATA_DIR environment variable takes precedence.

Currently contains a single data.json file with all the vault data, so it ought to belong in XDG_DATA_HOME

Blender ~/.blender 4293f47 [16]
byobu ~/.byobu 4.17 [17]


Legacy path takes precedence if present, or if XDG_CONFIG_HOME is not set.

cabal ~/.cabal/ 9f7dc55 [18]
calcurse ~/.calcurse 04162d [19] [20]

If the legacy path ~/.calcurse is present, it will take precedence.

ccache ~/.ccache 4.0 [21]
citra-gitAUR ~/.citra-emu f7c3193 [22]
clangd ~/.clangd fdf7dcc[dead link 2022-09-23 ⓘ] [23] XDG_CONFIG_HOME/clangd/config.yml


Project specific configuration can be specified in proj/.clangd. Configuration is combined when this is sensible. In case of conflicts, user config has the highest precedence, then inner project, then outer project.

Composer ~/.composer 1.0.0-beta1 [24]
cURL ~/.curlrc 7.73.0 [25] XDG_CONFIG_HOME/.curlrc
CUPS ~/.cups/ 23b1be6 [26]
d-feet ~/.d-feet 7f6104b
Dolphin emulator ~/.dolphin-emu a498c68 [27]
dr14_tmeterAUR 7e777ca [28] XDG_CONFIG_HOME/dr14tmeter/
dunst 78b6e2b [29] XDG_CONFIG_HOME/dunst/
Emacs ~/.emacs ~/.emacs.d/init.el [30]



Legacy paths have precedence over XDG paths. Emacs will never create XDG_CONFIG_HOME/emacs/. Workaround for 26.3 or older: It's possible to set HOME, but it has unexpected side effects.

fltk ~/.fltk/ 7308bcd [31] [32] Only supported in version 1.4.0, which hasn't been released yet (as of 9-July-2022)
fontconfig ~/.fontconfig ~/.fonts 8c255fb, [33] Config goes in XDG_CONFIG_HOME/fontconfig/fonts.conf or XDG_CONFIG_HOME/fontconfig/conf.d/, fonts are stored in XDG_DATA_HOME/fonts/
fontforge ~/.FontForge ~/.PfaEdit e4c2cc7

[34] [35]

freecad ~/.FreeCAD e7e2994ba


[36] Defaults to

legacy path can be used with FreeCAD --keep-deprecated-paths

freerdp ~/.freerdp edf6e72
Gajim ~/.gajim 3e777ea [37]
gconfAUR ~/.gconf fc28caa [38]
GDB ~/.gdbinit, ~/.gdb_history 11.1 XDG_CONFIG_HOME/gdb/gdbinit, export GDBHISTFILE="$XDG_DATA_HOME"/gdb/history
GIMP ~/.gimp-x.y ~/.thumbnails

60e0cfe 483505f

[39] [40]

Git ~/.gitconfig 0d94427 XDG_CONFIG_HOME/git/config
gops 71c4255
gnuplot ~/.gnuplot_history a5562b1


goobookAUR ~/.goobookrc 3.5 [42] XDG_CONFIG_HOME/goobookrc
Godot Engine ~/.godot 73049d1


GStreamer ~/.gstreamer-0.10 4e36f93 [44]
helm ~/.helm 3.0.0
htop ~/.htoprc 93233a6
httpie ~/.httpie 5af0874 [45]
hunspell ~/.hunspell_default. [46]
i3 ~/.i3 7c130fb
i3blocks, i3blocks-gitAUR [47]
i3-gaps [48]
i3status ~/.i3status.conf c3f7fc4
IdeaVim ~/.ideavimrc 0.54.1-EAP [49] XDG_CONFIG_HOME/ideavim/ideavimrc
Inkscape ~/.inkscape 0.47 [50]
ipython ~/.ipython 8.0.0 [51] Checks if $XDG_CONFIG_HOME/ipython (or ~/.config/ipython if XDG_CONFIG_HOME is unset) exists, otherwise it uses ~/.ipython.
iwd / iwctl ~/.iwctl_history d3e00d7f
intellij-idea-community-edition / intellij-idea-ultimate-editionAUR ~/.IntelliJIdeaXXXX.X 2020.1 [52]
josm ~/.josm 11162 [53]
jupyter ~/.jupyter opt-in in 5.0, opt-out in 6.0, compulsory in 7.0 (changelog) XDG_CONFIG_HOME/jupyter
keynavAUR ~/.keynavrc XDG_CONFIG_HOME/keynav/keynavrc
less ~/.lesshst, ~/.lesskey 590

full support in 600

[54] The environment variables XDG_CONFIG_HOME and XDG_DATA_HOME must be set in version 590. This is no longer necessary when version 600 lands.
latexmk (in texlive-basic) ~/.latexmkrc


lftp ~/.lftp 21dc400 [55]
lgogdownloaderAUR ~/.gogdownloader d430af6 [56]

a6f56f7 25bd2ee

luarocks ~/.luarocks cd16cdd [58]

If the legacy path ~/.luarocks is present, it will take precedence.

NSS ~/.pki 3.42 (da45424) [59]
Haskell#Stack ~/.stack 2.9.3 [60] Defaults to legacy. Use export STACK_XDG=1 to make it compliant with the spec.

The old method of export STACK_ROOT="$XDG_DATA_HOME"/stack still works and takes priority [61].

Streamlink ~/.livestreamerrc ea80591 [62]
mc ~/.mc

1b99570 0b71156 ce401d7

Mercurial ~/.hgrc

3540200 4.2

msmtp ~/.msmtprc

af2f409 v1.6.7+

mesa 87ab26b XDG_CACHE_HOME/mesa
milkytracker ~/.milkytracker_config eb487c5 [64]
mozc ~/.mozc 91cc1e1 [65]
mpd ~/.mpdconf 87b7328
mpv ~/.mpv cb250d4 [66]
mutt ~/.mutt b17cd67 [67]
mypaint ~/.mypaint cf723b7
nano ~/.nano/ ~/.nanorc c16e79b [68]
ncmpcpp ~/.ncmpcpp

38d9f81 27cd86e

[69] [70]

ncmpcpp_directory should be set to avoid an error.log file in ~/.ncmpcpp.
Neovim ~/.nvim ~/.nvimlog ~/.nviminfo 1ca5646

[71] [72]

Nestopia UE ~/.nestopia/ 610c008 1.51.0 [73]
newsboat ~/.newsboat 3c57824 [74] It is required to create both directories [75]:

mkdir -p "$XDG_DATA_HOME"/newsboat "$XDG_CONFIG_HOME"/newsboat

node-gyp ~/.node-gyp 2b5ce52a [76]
np2kai-gitAUR ~/.config/np2kai ~/.config/xnp2kai 56a1cc2 [77]
notmuch ~/.notmuch-config [78] mkdir -p $XDG_CONFIG_HOME/notmuch/default; mv ~/.notmuch-config $XDG_CONFIG_HOME/notmuch/default/config
nteract-binAUR 4593e72 [79] [80] does not recognize workarounds for ipython/jupyter
OfflineIMAP ~/.offlineimaprc 5150de5 [81] XDG_CONFIG_HOME/offlineimap/config
openal ~/.alsoftrc 3c90ed9 XDG_CONFIG_HOME/alsoft.conf
opentyrianAUR ~/.opentyrian 39559c3 [82]
oscAUR ~/.oscrc ~/.osc_cookiejar 6bc2d3f




XDG_CONFIG_HOME/osc/oscrc XDG_STATE_HOME/osc/cookiejar

Legacy path takes precedence if it exists

pam-u2f ~/.config/Yubico/u2f_keys ad52dd8 [83] XDG_CONFIG_HOME/Yubico/u2f_keys
pandoc-cli ~/.pandoc/ 0bed0ab [84]
PCManFM ~/.thumbnails 1.3.2
pcsx2AUR ~/.pcsx2

87f1e8f a9020c6 3b22f0f 0a012ae

[85] [86]
pdfsamAUR ~/.openjfx export _JAVA_OPTIONS=-Djavafx.cachedir="$XDG_CACHE_HOME"/openjfx
Pry ~/.pryrc ~/.pry_history

a0be0cc7 15e1fc92 e9d1be0e

python-autoimportAUR ~/.config/autoimport/config.toml 1.2.0 [88] XDG_CONFIG_HOME/autoimport/config.toml
python-black ~/.config/black 21.4b0 [89] XDG_CONFIG_HOME/black, XDG_CACHE_HOME/black/<version>/
python-pylint ~/.pylint.d 2.10 [90] Formerly export PYLINTHOME="$XDG_CACHE_HOME"/pylint, global config still needs: export PYLINTRC="$XDG_CONFIG_HOME"/pylint/pylintrc
python-pip ~/.pip 6.0 [91]
python-pipx ~/.local/pipx c3d8de9 [92] For compatibility, pipx will revert to ~/.local/pipx if it exists. Implemented using python-platformdirs
python-poetry ~/.poetry [93] [94] Still creates ~/.poetry according to [95]
powershellAUR 6.0
ppsspp ~/.ppsspp 132fe47 [96]
procps-ng ~/.toprc af53e17

[97] [98]

pacman ~/.makepkg.conf 80eca94 [99]
panda3dAUR ~/.panda3d 2b537d2
PulseAudio ~/.pulse ~/.pulse-cookie

59a8618 87ae830 9ab510a 4c195bc

quodlibet ~/.quodlibet 3.10.0 [101]

fd8686e 66d704b 51cff01

[102] Some optional bar widgets can create files and directories in non-compliant paths, but most often these are still configurable.
rclone ~/.rclone.conf 9d36258 [103]
rrAUR ~/.rr 02e7d41 [104]
RSpec ~/.rspec 5e395e2 [105]
rTorrent ~/.rtorrent.rc 6a8d332
RuboCop ~/.rubocop.yml 6fe5956 [106]
Ruby#RubyGems ~/.gem 3.0.0 (5c6269c) [107]
sandboxd ~/.sandboxrc [108] [109] XDG_CONFIG_HOME/sandboxd/sandboxrc
scribus ~/.scribus 1.5.3
scummvm ~/.scummvmrc ~/.scummvm/ 7d014be [110] It is required to migrate data by hand.

mkdir "$XDG_CONFIG_HOME"/scummvm/ "$XDG_DATA_HOME"/scummvm mv ~/.scummvmrc "$XDG_CONFIG_HOME"/scummvm/scummvm.ini mv ~/.scummvm "$XDG_DATA_HOME"/scummvm/saves

sdcv ~/.stardict/ ~/.sdcv_history 958ec35 [111]
skypeforlinux-stable-binAUR ~/.Skype 8.0
snes9x ~/.snes9x 93b5f11 [112] By default, the configuration file is left blank with intention that the user will fill it at their will (through the gui or manually).
spectrwm ~/.spectrwm a30bbb [113]
sublime-text-devAUR build 4105 Prior to build 4105, the cache was placed in XDG_CONFIG_HOME/sublime-text-3/Cache.
surfraw ~/.surfraw.conf ~/.surfraw.bookmarks

3e4591d bd8c427 f57fc71

sway ~/.sway/config 614393c [114] XDG_CONFIG_HOME/sway/config
teeworlds ~/.teeworlds [115]
tig ~/.tigrc, ~/.tig_history 2.2 [116] ~/.local/share/tig directory must exist, writes to ~/.tig_history otherwise.
tmux ~/.tmux.conf 3.1 [117] 3.1 introduced ~/.config/tmux/tmux.conf and in 3.2 XDG_CONFIG_HOME/tmux/tmux.conf was added
tmuxp ~/.tmuxp 1.5.0 [118] Fixed in 1.5.2
tmuxinatorAUR ~/.tmuxinator 2636923 [119]
Transmission ~/.transmission b71a298
util-linux 570b321
Uzbl c6fd63a [120]
VirtualBox ~/.VirtualBox 4.3 [121]
vis ~/.vis

68a25c7 d138908

VLC ~/.vlcrc 16f32e1 [123]
warsow ~/.warsow-2.x 98ece3f [124]
WeeChat ~/.weechat [125]


[126] [127][dead link 2023-05-06 ⓘ]
Wireshark ~/.wireshark b0b53fa[dead link 2022-09-23 ⓘ]
wxWidgets [128]
Xsettingsd ~/.xsettingsd b4999f5
xmobar ~/.xmobarrc 7b0d6bf

9fc6b37 eaccf70



xmonad ~/.xmonad/ 40fc10b

[131] [132]

All of these must exist, otherwise it gives up and falls back to ~/.xmonad/ for each:

Alternatively, it always respects XMONAD_CACHE_DIR, XMONAD_CONFIG_DIR, and XMONAD_DATA_DIR.

xournalpp ~/.xournalpp

20db937f 1.1.0

[133] [134]

xsel ~/.xsel.log ee7b481 [135]
Zim e42b8b0
zoxide ~/.zo 0.3.0 [136]


Application Legacy Path Supported Since Discussion Notes
abookAUR ~/.abook abook --config "$XDG_CONFIG_HOME"/abook/abookrc --datafile "$XDG_DATA_HOME"/abook/addressbook
ack ~/.ackrc [137] export ACKRC="$XDG_CONFIG_HOME/ack/ackrc"
Ansible ~/.ansible 2.14 [138] [139] [140]
export ANSIBLE_HOME="${XDG_CONFIG_HOME}/ansible"
export ANSIBLE_CONFIG="${XDG_CONFIG_HOME}/ansible.cfg"
export ANSIBLE_GALAXY_CACHE_DIR="${XDG_CACHE_HOME}/ansible/galaxy_cache"

The remote's ~/.ansible/tmp can be moved by setting remote_tmp = ${XDG_CONFIG_HOME}/ansible/tmp in an appropriate ansible.cfg. [142] [143]

asdf-vmAUR ~/.asdfrc, ~/.asdf/ [144] export ASDF_CONFIG_FILE="${XDG_CONFIG_HOME}/asdf/asdfrc", export ASDF_DATA_DIR="${XDG_DATA_HOME}/asdf"
aspell ~/.aspell.conf [145] export ASPELL_CONF="per-conf $XDG_CONFIG_HOME/aspell/aspell.conf; personal $XDG_CONFIG_HOME/aspell/en.pws; repl $XDG_CONFIG_HOME/aspell/en.prepl"
Atom ~/.atom [146] export ATOM_HOME="$XDG_DATA_HOME"/atom
aws-cli ~/.aws 1.7.45 [147] export AWS_SHARED_CREDENTIALS_FILE="$XDG_CONFIG_HOME"/aws/credentials, export AWS_CONFIG_FILE="$XDG_CONFIG_HOME"/aws/config
bash-completion ~/.bash_completion export BASH_COMPLETION_USER_FILE="$XDG_CONFIG_HOME"/bash-completion/bash_completion
bashdbAUR ~/.bashdbinit, ~/.bashdb_hist Like documented at [148], you can specify a file to run commands from. Thus, move the init file to XDG_CONFIG_HOME/bashdb/bashdbinit and create an alias alias bashdb='bashdb -x ${XDG_CONFIG_HOME:-$HOME/.config}/bashdb/bashdbinit'. Unfortunately the history file is hardcoded [149].
bazaar ~/.bazaar, ~/.bzr.log 2.3.0 [150] Discussion in upstream bug states that bazaar will use ~/.config/bazaar if it exists. The logfile ~/.bzr.log might still be written.
bogofilter ~/.bogofilter 0.7.5 [151] export BOGOFILTER_DIR="$XDG_DATA_HOME"/bogofilter
btpd-gitAUR ~/.btpd/ [152] btpd -d "$XDG_DATA_HOME"/.btpd


bunAUR ~/.bun/ [153] Bun will prioritize using $XDG_CONFIG_HOME, $XDG_CACHE_HOME, and/or $XDG_DATA_HOME when these have explicitly been set. As an alternative, export BUN_INSTALL="$XDG_DATA_HOME"/bun can be used to set bun's main location for its directories.
calc ~/.calc_history
export CALCHISTFILE="$XDG_CACHE_HOME"/calc_history
Rust#Cargo ~/.cargo [154] [155] [156] [157] export CARGO_HOME="$XDG_DATA_HOME"/cargo
cataclysm-dda ~/.cataclysm-dda 0.D-1 [158] partial support due to required compile time option
cd-bookmark ~/.cdbookmark [159] export CD_BOOKMARK_FILE=$XDG_CONFIG_HOME/cd-bookmark/bookmarks

or use the fork that has native XDG support: [160]

cgdb ~/.cgdb [On master branch, but no release yet] [161] [162] Set export CGDB_DIR=$XDG_CONFIG_HOME/cgdb and move the config file to XDG_CONFIG_HOME/cgdb/cgdbrc
chez-schemeAUR ~/.chezscheme_history petite --eehistory "$XDG_DATA_HOME"/chezscheme/history
chktex in texlive-binextra ~/.chktexrc Move the config file to $XDG_CONFIG_HOME/chktex/.chktexrc (mind the leading dot) and export CHKTEXRC=$XDG_CONFIG_HOME/chktex
Chromium ~/.chromium, ~/.pki 23057 [163] [164] [165] Deliberatly (according to these sources) clobbers ~/.config by writing hundreds of megabytes of cache data into it. Quite unsupported.
cinelerra ~/.bcast5 [166] export CIN_CONFIG="$XDG_CONFIG_HOME"/bcast5
conky ~/.conkyrc 00481ee [167] conky --config="$XDG_CONFIG_HOME"/conky/conkyrc
claws-mail ~/.claws-mail [168] claws-mail --alternate-config-dir "$XDG_DATA_HOME"/claws-mail
coreutils ~/.dircolors eval $(dircolors "$XDG_CONFIG_HOME"/dircolors)
crawl ~/.crawl The trailing slash is required:

export CRAWL_DIR="$XDG_DATA_HOME"/crawl/

clusterssh ~/.clusterssh/ alias cssh="cssh --config-file '$XDG_CONFIG_HOME/clusterssh/config'"

Despite this, clusterssh will still create ~/.clusterssh/.

dict ~/.dictrc dict -c "$XDG_CONFIG_HOME"/dict/dictrc
discord ${XDG_CONFIG_HOME}/discord As of version 0.0.27:

Undocumented, though actively used: export DISCORD_USER_DATA_DIR="${XDG_DATA_HOME}"

Source: <discord_system_package_root>/resources/app.asar.

Docker ~/.docker export DOCKER_CONFIG="$XDG_CONFIG_HOME"/docker
docker-machine ~/.docker/machine export MACHINE_STORAGE_PATH="$XDG_DATA_HOME"/docker-machine
DOSBox ~/.dosbox/dosbox-0.74-2.conf [169] dosbox -conf "$XDG_CONFIG_HOME"/dosbox/dosbox.conf
dub ~/.dub v1.30.0-beta.1 Dub uses the ~/.dub directory for both user settings and caching downloaded packages. The directory can only be moved as a whole, using export DUB_HOME="path/to/new/dub".
Electrum Bitcoin Wallet ~/.electrum c121230 export ELECTRUMDIR="$XDG_DATA_HOME/electrum"
ELinks ~/.elinks export ELINKS_CONFDIR="$XDG_CONFIG_HOME"/elinks
elixir ~/.mix afaf889 [170] [171] Elixir do not fully conform to XDG specs, it will use XDG only if the environment variables are present, otherwise it will by default use legacy path.
Elm ~/.elm export ELM_HOME="$XDG_CONFIG_HOME"/elm
fceux ~/.fceux/ [172] export FCEUX_HOME="$XDG_CONFIG_HOME"/fceux. Fceux will create .fceux directory inside $FCEUX_HOME.
FFmpeg ~/.ffmpeg export FFMPEG_DATADIR="$XDG_CONFIG_HOME"/ffmpeg
flutterAUR ~/.flutter, ~/.flutter_settings, ~/.flutter_tool_state, ~/.pub-cache [173]
fzf-gitAUR ~/.fzf.bash, ~/.fzf.zsh [174] The shell init files will be installed to XDG_CONFIG_HOME/fzf if the installation script is called with --xdg for example /usr/local/opt/fzf/install --xdg.
emscripten ~/.emscripten, ~/.emscripten_sanity, ~/.emscripten_ports, ~/.emscripten_cache__last_clear [175] export EM_CONFIG="$XDG_CONFIG_HOME"/emscripten/config, export EM_CACHE="$XDG_CACHE_HOME"/emscripten/cache, export EM_PORTS="$XDG_DATA_HOME"/emscripten/cache, emcc --em-config "$XDG_CONFIG_HOME"/emscripten/config --em-cache "$XDG_CACHE_HOME"/emscripten/cache
get_iplayerAUR ~/.get_iplayer export GETIPLAYERUSERPREFS="$XDG_DATA_HOME"/get_iplayer
getmail ~/.getmail/getmailrc getmail --rcfile="$XDG_CONFIG_HOME/getmail/getmailrc" --getmaildir="$XDG_DATA_HOME/getmail"
ghc ~/.ghci [176] [177] Supported upstream from 9.4.1 [178], but as of 2022-09-24 Arch package is 9.0.2 and not yet up-to-date.
ghcup-hs-binAUR ~/.ghcup [179] [180] export GHCUP_USE_XDG_DIRS=true

The environment variable GHCUP_USE_XDG_DIRS can be set to any non-empty value. See [181].

glivAUR ~/.glivrc gliv --glivrc="$XDG_CONFIG_HOME"/gliv/glivrc
gnuradio ~/.gnuradio [182] GNU Radio:

export GR_PREFS_PATH="$XDG_CONFIG_HOME"/gnuradio

GNU Radio Companion: export GRC_PREFS_PATH="$XDG_CONFIG_HOME"/gnuradio/grc.conf

GnuPG ~/.gnupg [183] [184] export GNUPGHOME="$XDG_DATA_HOME"/gnupg, gpg2 --homedir "$XDG_DATA_HOME"/gnupg

Note that this currently does not work out-of-the-box using systemd user units and socket-based activation, since the socket directory changes based on the hash of $GNUPGHOME. You can get the new socket directory using gpgconf --dry-run --create-socketdir and have to modify the systemd user units to listen on the correct sockets accordingly.

Go ~/go [185] export GOPATH="$XDG_DATA_HOME"/go, export GOMODCACHE="$XDG_CACHE_HOME"/go/mod

If GOMODCACHE is not set, it defaults to $GOPATH/pkg/mod (see [186]). GOCACHE is supported and defaults to $XDG_CACHE_HOME/go-build (see [187]).

Google Earth ~/.googleearth Some paths can be changed with the KMLPath and CachePath options in ~/.config/Google/GoogleEarthPlus.conf
gopass ~/.password-store Override settings in ~/.config/gopass/config.yml:
path: gpgcli-gitcli-fs+file:///home/<userid>/.config/password-store
gpodder ~/gPodder GPODDER_DOWNLOAD_DIR sets the download folder. GPODDER_HOME - where config and database files are stored, downloads also if GPODDER_DOWNLOAD_DIR is not set.
GQ LDAP client ~/.gq, ~/.gq-state 1.51 export GQRC="$XDG_CONFIG_HOME"/gqrc, export GQSTATE="$XDG_DATA_HOME"/gq/gq-state, mkdir -p "$(dirname "$GQSTATE")"
Gradle ~/.gradle [188]


GTK 1 ~/.gtkrc export GTK_RC_FILES="$XDG_CONFIG_HOME"/gtk-1.0/gtkrc
GTK 2 ~/.gtkrc-2.0 export GTK2_RC_FILES="$XDG_CONFIG_HOME"/gtk-2.0/gtkrc
hledger ~/.hledger.journal [190] export LEDGER_FILE="$XDG_DATA_HOME"/hledger.journal
Houdini ~/houdiniMAJOR.MINOR) [191]



The value of this variable must include the substring __HVER__, which will be replaced at run time with the current MAJOR.MINOR version string.

imapfilterAUR ~/.imapfilter export IMAPFILTER_HOME="$XDG_CONFIG_HOME/imapfilter"
IPFS ~/.ipfs export IPFS_PATH="$XDG_DATA_HOME"/ipfs
irb ~/.irbrc
$ export IRBRC="$XDG_CONFIG_HOME"/irb/irbrc
IRB.conf[:SAVE_HISTORY] ||= 1000
IRB.conf[:HISTORY_FILE] ||= File.join(ENV["XDG_DATA_HOME"], "irb", "history")
irssi ~/.irssi [193] irssi --config="$XDG_CONFIG_HOME"/irssi/config --home="$XDG_DATA_HOME"/irssi
isync ~/.mbsyncrc [194] mbsync -c "$XDG_CONFIG_HOME"/isync/mbsyncrc
Java#OpenJDK ~/.java/.userPrefs [195] export _JAVA_OPTIONS=-Djava.util.prefs.userRoot="$XDG_CONFIG_HOME"/java
jupyter ~/.jupyter 5.0.0rc0 [196] [197] python-jupyter-core < v5.0.0:


v5.0.0 <= python-jupyter-core < v6.0.0:

export JUPYTER_PLATFORM_DIRS="1" (see [198])

python-jupyter-core >= v6.0.0: full support (via python-platformdirs) enabled by default

k9s ~/.k9s 0.20.4 [199] export K9SCONFIG="$XDG_CONFIG_HOME"/k9s
KDE ~/.kde, ~/.kde4 [200] export KDEHOME="$XDG_CONFIG_HOME"/kde
keychain ~/.keychain [201] [202] keychain --absolute --dir "$XDG_RUNTIME_DIR"/keychain
kodi ~/.kodi [203] [204] KODI_DATA=$XDG_DATA_HOME/kodi
kscriptAUR ~/.kscript [205] export KSCRIPT_CACHE_DIR="$XDG_CACHE_HOME"/kscript
ledger ~/.ledgerrc, ~/.pricedb [206] ledger --init-file "$XDG_CONFIG_HOME"/ledgerrc
Leiningen ~/.lein, ~/.m2 export LEIN_HOME="$XDG_DATA_HOME"/lein

to change the m2 repo location used by leiningen look here: Leiningen#m2_repo_location

libdvdcss ~/.dvdcss [207] export DVDCSS_CACHE="$XDG_DATA_HOME"/dvdcss
libice ~/.ICEauthority [208] export ICEAUTHORITY="$XDG_CACHE_HOME"/ICEauthority

Make sure XDG_CACHE_HOME is set beforehand to directory user running Xorg has write access to.

Do not use XDG_RUNTIME_DIR as it is available after login. Display managers that launch Xorg (like GDM) will repeatedly fail otherwise.

libx11 ~/.XCompose, ~/.compose-cache export XCOMPOSEFILE="$XDG_CONFIG_HOME"/X11/xcompose, export XCOMPOSECACHE="$XDG_CACHE_HOME"/X11/xcompose
ltrace ~/.ltrace.conf ltrace -F "$XDG_CONFIG_HOME"/ltrace/ltrace.conf
lynx /etc/lynx.cfg export LYNX_CFG_PATH="$XDG_CONFIG_HOME"/lynx.cfg
m17n-db ~/.m17n.d [209]
maptool-binAUR ~/.maptool-rptools [210]

However, no way to change the location of this configuration file.

maven ~/.m2 [211] mvn -gs "$XDG_CONFIG_HOME"/maven/settings.xml and set <localRepository> as appropriate in settings.xml
Mathematica ~/.Mathematica export MATHEMATICA_USERBASE="$XDG_CONFIG_HOME"/mathematica
maxima ~/.maxima export MAXIMA_USERDIR="$XDG_CONFIG_HOME"/maxima
mednafen ~/.mednafen export MEDNAFEN_HOME="$XDG_CONFIG_HOME"/mednafen
minikube ~/.minikube [212] export MINIKUBE_HOME="$XDG_DATA_HOME"/minikube

Creates a further .minikube directory in MINIKUBE_HOME for whatever reason.

mitmproxy ~/.mitmproxy alias mitmproxy="mitmproxy --set confdir=$XDG_CONFIG_HOME/mitmproxy", alias mitmweb="mitmweb --set confdir=$XDG_CONFIG_HOME/mitmproxy"
MOC ~/.moc mocp -M "$XDG_CONFIG_HOME"/moc, mocp -O MOCDir="$XDG_CONFIG_HOME"/moc
monero ~/.bitmonero monerod --data-dir "$XDG_DATA_HOME"/bitmonero
most ~/.mostrc export MOST_INITFILE="$XDG_CONFIG_HOME"/mostrc
MPlayer ~/.mplayer export MPLAYER_HOME="$XDG_CONFIG_HOME"/mplayer
mypy ~/.config/mypy/config, ~/.mypy.ini, ~/.mypy_cache v0.670 [213] [214] XDG_CONFIG_HOME/mypy/config, export MYPY_CACHE_DIR="$XDG_CACHE_HOME"/mypy
MySQL ~/.mysql_history, ~/.my.cnf , ~/.mylogin.cnf export MYSQL_HISTFILE="$XDG_DATA_HOME"/mysql_history

~/.my.cnf only supported for mysql-server, not mysql-client [215]

~/.mylogin.cnf unsupported

mysql-workbench ~/.mysql/workbench You can run MySQL Workbench with the ---configdir flag, such as mysql-workbench --configdir="$XDG_DATA_HOME/mysql/workbench". The directory needs to be created manually, since MySQL Workbench default location is $HOME/.mysql/workbench .
ncurses ~/.terminfo Precludes system path searching:

export TERMINFO="$XDG_DATA_HOME"/terminfo, export TERMINFO_DIRS="$XDG_DATA_HOME"/terminfo:/usr/share/terminfo

n /usr/local/n export N_PREFIX=$XDG_DATA_HOME/n
ncmpc ~/.ncmpc ncmpc -f "$XDG_CONFIG_HOME"/ncmpc/config
Netbeans ~/.netbeans [216] netbeans --userdir "${XDG_CONFIG_HOME}"/netbeans
Node.js ~/.node_repl_history [217] export NODE_REPL_HISTORY="$XDG_DATA_HOME"/node_repl_history
npm ~/.npm, ~/.npmrc [218] export NPM_CONFIG_USERCONFIG=$XDG_CONFIG_HOME/npm/npmrc

prefix is unnecessary (and unsupported) if Node.js is installed by nvmAUR.

If you want to configure this system-wide, the file to edit is /usr/etc/npmrc, not /etc/npmrc. You can confirm that the config is loaded by running npm config list

opam ~/.opam [219] export OPAMROOT="$XDG_DATA_HOME/opam"

Both configuration and state data are stored in OPAMROOT, so this solution is not fully compliant.

pnpm ~/.pnpm-store Add the line store-dir=${XDG_DATA_HOME}/pnpm-store to your npmrc.
PuTTY ~/.putty/ 9952b2d Will use $XDG_CONFIG_HOME/putty if it already exists. Creates ~/.putty if not. Prioritises $XDG_CONFIG_HOME/putty if both exist. Tested in 0.74
python-easyocrAUR ~/.EasyOCR export EASYOCR_MODULE_PATH="$XDG_CONFIG_HOME/EasyOCR"
nuget ~/.nuget/packages [220] export NUGET_PACKAGES="$XDG_CACHE_HOME"/NuGetPackages
NVIDIA ~/.nv Uses XDG_CACHE_HOME if set, otherwise improperly falls back to ~/.nv instead of ~/.cache.
nvidia-settings ~/.nvidia-settings-rc nvidia-settings --config="$XDG_CONFIG_HOME"/nvidia/settings
nvmAUR ~/.nvm export NVM_DIR="$XDG_DATA_HOME"/nvm
Octave ~/octave, ~/.octave_packages, ~/.octave_hist export OCTAVE_HISTFILE="$XDG_CACHE_HOME/octave-hsts", export OCTAVE_SITE_INITFILE="$XDG_CONFIG_HOME/octave/octaverc"
source /usr/share/octave/site/m/startup/octaverc;
pkg prefix ~/.local/share/octave/packages ~/.local/share/octave/packages;
pkg local_list /home/<your username>/.local/share/octave/octave_packages;

The local_list option must be given an absolute path.

omnisharp-roslyn-binAUR ~/.omnisharp/ [221] [222] export OMNISHARPHOME="$XDG_CONFIG_HOME/omnisharp"
openscad ~/.OpenSCAD 7c3077b0f [223] Does not fully honour XDG Base Directory Specification, see [224]

Currently it hard-codes ~/.local/share.

OpenSSL ~/.rnd Seeding file .rnd's location can be set with RANDFILE environment variable per FAQ.
parallel ~/.parallel 20170422 export PARALLEL_HOME="$XDG_CONFIG_HOME"/parallel
pass ~/.password-store export PASSWORD_STORE_DIR="$XDG_DATA_HOME"/pass
Pidgin ~/.purple [225] pidgin --config="$XDG_DATA_HOME"/purple
platformioAUR ~/.platformio [226] export PLATFORMIO_CORE_DIR="$XDG_DATA_HOME"/platformio
PostgreSQL ~/.psqlrc, ~/.psql_history, ~/.pgpass, ~/.pg_service.conf 9.2 [227] [228] export PSQLRC="$XDG_CONFIG_HOME/pg/psqlrc", export PSQL_HISTORY="$XDG_STATE_HOME/psql_history", export PGPASSFILE="$XDG_CONFIG_HOME/pg/pgpass", export PGSERVICEFILE="$XDG_CONFIG_HOME/pg/pg_service.conf"

It is required to create both directories: mkdir "$XDG_CONFIG_HOME/pg" && mkdir "$XDG_STATE_HOME"

PulseAudio ~/.esd_auth Very likely generated by the module-esound-protocol-unix.so module. It can be configured to use a different location but it makes much more sense to just comment out this module in /etc/pulse/default.pa or "$XDG_CONFIG_HOME"/pulse/default.pa.
pyenv ~/.pyenv [229] [230] export PYENV_ROOT=$XDG_DATA_HOME/pyenv
python-azure-cliAUR[broken link: package not found] ~/.azure export AZURE_CONFIG_DIR=$XDG_DATA_HOME/azure
python-gripAUR ~/.grip export GRIPHOME="$XDG_CONFIG_HOME/grip"
python-setuptools ~/.python-eggs export PYTHON_EGG_CACHE="$XDG_CACHE_HOME"/python-eggs
racket ~/.racketrc, ~/.racket [231] export PLTUSERHOME="$XDG_DATA_HOME"/racket
rbenvAUR ~/.rbenv [232] [233] export RBENV_ROOT="$XDG_DATA_HOME"/rbenv
nodenvAUR ~/.nodenv export NODENV_ROOT="$XDG_DATA_HOME"/nodenv
readline ~/.inputrc export INPUTRC="$XDG_CONFIG_HOME"/readline/inputrc
recoll ~/.recoll export RECOLL_CONFDIR="$XDG_CONFIG_HOME/recoll"
redis ~/.rediscli_history, ~/.redisclirc export REDISCLI_HISTFILE="$XDG_DATA_HOME"/redis/rediscli_history, export REDISCLI_RCFILE="$XDG_CONFIG_HOME"/redis/redisclirc
ripgrep [234] export RIPGREP_CONFIG_PATH=$XDG_CONFIG_HOME/ripgrep/config
rlwrap ~/.*_history [235] export RLWRAP_HOME="$XDG_DATA_HOME"/rlwrap
ruby-solargraphAUR ~/.solargraph/cache/ [236] export SOLARGRAPH_CACHE=$XDG_CACHE_HOME/solargraph
ruff .ruff_cache [237] export RUFF_CACHE_DIR=$XDG_CACHE_HOME/ruff
Rust#Rustup ~/.rustup [238] export RUSTUP_HOME="$XDG_DATA_HOME"/rustup
sbt ~/.sbt


[239] sbt -ivy "$XDG_DATA_HOME"/ivy2 -sbt-dir "$XDG_DATA_HOME"/sbt (beware [240])
SageMath ~/.sage export DOT_SAGE="$XDG_CONFIG_HOME"/sage
GNU Screen ~/.screenrc export SCREENRC="$XDG_CONFIG_HOME"/screen/screenrc
simplescreenrecorderAUR ~/.ssr/ 0.4.3 [241]


Will use $XDG_CONFIG_HOME/simplescreenrecorder/ ONLY if it already was created otherwise defaults to ~/.ssr

mv ~/.ssr "$XDG_CONFIG_HOME"/simplescreenrecorder

singularity-ceAUR ~/.singularity 3.11.4 export SINGULARITY_CONFIGDIR="$XDG_CONFIG_HOME/singularity", export SINGULARITY_CACHEDIR="$XDG_CACHE_HOME/singularity"
spacemacs ~/.spacemacs, ~/.spacemacs.d [243] [244] Move the ~/.spacemacs file.

export SPACEMACSDIR="$XDG_CONFIG_HOME"/spacemacs, mv ~/.spacemacs "$SPACEMACSDIR"/init.el

Other files need to be configured like Emacs.

starship ~/.config/starship, ~/.cache/starship [245] (v0.2.0), [246] (v0.45.0) [247] export STARSHIP_CONFIG="$XDG_CONFIG_HOME"/starship.toml, export STARSHIP_CACHE="$XDG_CACHE_HOME"/starship
subversion ~/.subversion [248] [249][250] alias svn="svn --config-dir \"$XDG_CONFIG_HOME\"/subversion"
sudo ~/.sudo_as_admin_successful 1.9.6 [251] [252] Only present when activated at compile-time (default none). An admin_flag parameter can be used in /etc/sudoers since 1.9.6.
task ~/.task, ~/.taskrc Fully supported in version 2.6 (note $XDG_CONFIG_HOME/task/taskrc must exist, otherwise taskwarrior will offer to create sample config in legacy $HOME/.taskrc location, even if $XDG_CONFIG_HOME is set [253][254])
Local TeX Live TeXmf tree, TeXmf caches and config ~/texmf, ~/.texlive/texmf-var, ~/.texlive/texmf-config export TEXMFHOME=$XDG_DATA_HOME/texmf, export TEXMFVAR=$XDG_CACHE_HOME/texlive/texmf-var, export TEXMFCONFIG=$XDG_CONFIG_HOME/texlive/texmf-config
TeXmacs ~/.TeXmacs export TEXMACS_HOME_PATH=$XDG_STATE_HOME/texmacs
tiptopAUR ~/.tiptoprc This will still expect the .tiptoprc file.

tiptop -W "$XDG_CONFIG_HOME"/tiptop

ruby-travisAUR ~/.travis/ [255] export TRAVIS_CONFIG_PATH=$XDG_CONFIG_HOME/travis
uncrustify ~/.uncrustify.cfg export UNCRUSTIFY_CONFIG="$XDG_CONFIG_HOME"/uncrustify/uncrustify.cfg
Unison ~/.unison export UNISON="$XDG_DATA_HOME"/unison
unitsAUR ~/.units_history units --history "$XDG_CACHE_HOME"/units_history
urxvtd ~/.urxvt/urxvtd-hostname export RXVT_SOCKET="$XDG_RUNTIME_DIR"/urxvtd
Vagrant ~/.vagrant.d, ~/.vagrant.d/aliases [256] export VAGRANT_HOME="$XDG_DATA_HOME"/vagrant, export VAGRANT_ALIAS_FILE="$XDG_DATA_HOME"/vagrant/aliases
virtualenv ~/.virtualenvs export WORKON_HOME="$XDG_DATA_HOME/virtualenvs"
Visual Studio Code ~/.vscode-oss/ [257] You can use export VSCODE_PORTABLE="$XDG_DATA_HOME"/vscode, which is not documented and might break unexpectedly.

Setting this makes the editor look for the contents of .config/Code - OSS in $VSCODE_PORTABLE/user-data.

You can also run Visual Studio with the --extensions-dir flag, such as code --extensions-dir "$XDG_DATA_HOME/vscode". This is documented and probably will not break as unexpectedly, as it is has other use cases.

VSCodiumAUR ~/.vscode-oss/ [258] [259] You can run VSCodium with the --extensions-dir flag, such as vscodium --extensions-dir "$XDG_DATA_HOME/vscode". This however won't prevent the creation of ~/.vscode-oss/ directory.
w3m ~/.w3m 26284ff [260] [261] export W3M_DIR="$XDG_STATE_HOME/w3m"
wakatime ~/.wakatime.cfg, ~/.wakatime.data, ~/.wakatime.db, ~/.wakatime.log export WAKATIME_HOME="$XDG_CONFIG_HOME/wakatime"

The directory needs to be created manually

mkdir "$XDG_CONFIG_HOME/wakatime"

wget ~/.wgetrc, ~/.wget-hsts export WGETRC="$XDG_CONFIG_HOME/wgetrc" and add the following as an alias for wget: wget --hsts-file="$XDG_CACHE_HOME/wget-hsts", or set the hsts-file variable with an absolute path as wgetrc does not support environment variables: echo hsts-file \= "$XDG_CACHE_HOME"/wget-hsts >> "$XDG_CONFIG_HOME/wgetrc"
wine ~/.wine [262] Winetricks uses XDG-alike location below for WINEPREFIX management:

mkdir -p "$XDG_DATA_HOME"/wineprefixes, export WINEPREFIX="$XDG_DATA_HOME"/wineprefixes/default

x3270AUR ~/.x3270pro, ~/.c3270pro export X3270PRO="$XDG_CONFIG_HOME"/x3270/config, export C3270PRO="$XDG_CONFIG_HOME"/c3270/config

App also creates ~/.x3270connect but this is currently unsupported.

xbindkeys ~/.xbindkeysrc xbindkeys -f "$XDG_CONFIG_HOME"/xbindkeys/config
xorg-xauth ~/.Xauthority export XAUTHORITY="$XDG_RUNTIME_DIR"/Xauthority

Note that LightDM does not allow you to change this variable. If you change it nonetheless, you will not be able to login. Use startx instead or configure LightDM. According to [263] SLiM has ~/.Xauthority hardcoded.

The SDDM Xauthority path can be changed in its own configuration files as shown below. Unfortunately, it is relative to the home directory.


On Wayland, overriding this may cause Xorg programs to fail to connect to the Xwayland server. For example, both kwin and mutter use a randomized name, so it cannot be set to a static value.

xinit ~/.xinitrc, ~/.xserverrc [264] export XINITRC="$XDG_CONFIG_HOME"/X11/xinitrc, export XSERVERRC="$XDG_CONFIG_HOME"/X11/xserverrc
xorg-xrdb ~/.Xresources, ~/.Xdefaults Ultimately you should be using Xresources and since these resources are loaded via xrdb you can specify a path such as xrdb -load ~/.config/X11/xresources.
Xorg ~/.xsession, ~/.xsessionrc, ~/.Xsession, ~/.xsession-errors These can be added as part of your Xorg init script (~/.xinitrc) or Xsession start script (which will often be based on /etc/X11/Xsession).

Depending on where you have configured your $XDG_CACHE_HOME, you might need to expand the paths yourself.

# xsession start script

Unlike most other examples in this table, actual X11 init scripts will vary a lot between installations.

z ~/.z [265] export _Z_DATA="$XDG_DATA_HOME/z"
yarn ~/.yarnrc, ~/.yarn/, ~/.yarncache/, ~/.yarn-config/ 2d454b5 [266] [267] alias yarn='yarn --use-yarnrc "$XDG_CONFIG_HOME/yarn/config"'


Application Legacy Path Discussion Notes
adb & Android Studio ~/.android/ Despite appearances otherwise, adb will always generate ~/.android/adbkeys, though it will try keys in ADB_VENDOR_KEYS as well.
aegisub ~/.aegisub/ [268]
alpine ~/.pinerc, ~/.addressbook, ~/.pine-debug[1-4], ~/.newsrc, ~/.mailcap, ~/.mime.types, ~/.pine-interrupted-mail alias alpine="alpine -p $XDG_CONFIG_HOME/alpine/pinerc"

In the above config file, some locations can be customized using options like newsrc-path= and address-book=.

aMule ~/.aMule [269] [270] [271]
anthy ~/.anthy [272]
Apache Directory Studio ~/.ApacheDirectoryStudio
ARandR ~/.screenlayout [273]
Arduino ~/.arduino15, ~/.jssc won't fix
arduino-cli ~.arduino15/ [274] mv ~/.arduino15 $XDG_CONFIG_HOME/arduino15

Specify the new directories used by Arduino CLI in arduino-cli.yaml as mentioned in the documentation here. alias arduino-cli='arduino-cli --config-file $XDG_CONFIG_HOME/arduino15/arduino-cli.yaml'

ASP.NET Core ~/.aspnet [275]
Avidemux ~/.avidemux6 [276]
Bash ~/.bashrc, ~/.bash_history, ~/.bash_profile, ~/.bash_login, ~/.bash_logout won't fix mkdir -p "$XDG_STATE_HOME"/bash

export HISTFILE="$XDG_STATE_HOME"/bash/history

bashrc can be sourced from a different location in /etc/bash.bashrc. Specify --init-file <file> as an alternative to ~/.bashrc for interactive shells.

Berkshelf ~/.berkshelf/
chattyAUR ~/.chatty/ [277]
cmake ~/.cmake/ [278] Used for the user package registry ~/.cmake/packages/<package>, detailed in cmake-packages(7) § User Package Registry and the Package registry wiki page. Looks like it's hardcoded, for example in cmFindPackageCommand.cxx.
cmus ~/.config/cmus [279] [280]
Cinnamon ~/.cinnamon/ [281]
conanAUR ~/.conan/ [282] export CONAN_USER_HOME="$XDG_CONFIG_HOME" will set the directory in which .conan/ is created. It was designed to simplify CI, but can be used here too.
cryptomatorAUR ~/.Cryptomator [283]
ctags (universial-ctags) ~/.ctagsrc, .ctags.d [284]
cVim[dead link 2022-09-23 ⓘ] ~/.cvimrc [285]
darcs ~/.darcs/ [286]
dart ~/.dart, ~/.dartServer [287]
dbus ~/.dbus/ [288] Consider using dbus-broker, as it does not create or use this directory.
devede ~/.devedeng Hardcoded here
Dia ~/.dia/
dig ~/.digrc
dotnet-sdk ~/.dotnet/, ~/.templateengine [289]
dropbox ~/.dropbox/
Eclipse ~/.eclipse/ [290] Option -Dosgi.configuration.area=@user.home/.config/.. overrides but must be added to "$ECLIPSE_HOME"/eclipse.ini" rather than command line which means you must have write access to $ECLIPSE_HOME. (Arch Linux hard-codes $ECLIPSE_HOME in /usr/bin/eclipse)
equalxAUR ~/.equalx/ [291]
Fetchmail ~/.fetchmailrc
Firefox ~/.mozilla/ [292] [293]
Flatpak ~/.var/ [294] [295] won't fix
freesweep ~/.sweeprc [296]
gftpAUR ~/.gftp/ [297] Following the XDG spec is planned for gftp.
ghidra [298]
gitkrakenAUR ~/.gitkraken/ [299]
GoldenDict ~/.goldendict/ [300]
gphoto2 ~/.gphoto [301]
gramps ~/.gramps/ [302] 2022 Support XDG base directory specification (for next release Gramps 5.2 ) - Patch https://github.com/gramps-project/gramps/pull/1368
groovy ~/.groovy/
grsync ~/.grsync/ [303]
google-cloud-cliAUR ~/.gsutil/ [304]
gtk-recordMyDesktop ~/.gtk-recordmydesktop
hplip ~/.hplip/ [305]
hydrogen ~/.hydrogen/ [306]
idris ~/.idris [307]
itch-setup-binAUR ~/.itch won't fix You can move the Game install location in the app settings.
Jmol ~/.jmol/ [308]
lbdbAUR ~/.lbdbrc, ~/.lbdb/ [309]
llpp ~/.config/llpp.conf [310][dead link 2022-09-23 ⓘ] (repo was deleted) Added in 3ab86f0 but subsequently reverted in old:e253c9f1/new:e253c9f1
Java OpenJDK ~/.java/fonts [311] export _JAVA_OPTIONS=-Djava.util.prefs.userRoot="$XDG_CONFIG_HOME"/java
Java OpenJFX ~/.java/webview
jgmenu ~/.jgmenu-lockfile [312] [313]
jitsi-meetAUR ~/Downloads libjitsi#518 Download dir hardcoded to ~/Downloads rather than XDG_DOWNLOAD_DIR (from XDG user directories)
julia ~/.juliarc.jl, ~/.julia_history, ~/.julia [314] [315] The trailing :$JULIA_DEPOT_PATH is necessary. See [316]


kotlin ~/.kotlinc_history Related Konan issue: [317]
Kubernetes ~/.kube/ [318][319] export KUBECONFIG="$XDG_CONFIG_HOME/kube"
librewolfAUR ~/.mozilla


lldb ~/.lldb, ~/.lldbinit
LMMS ~/.lmmsrc.xml [321]
mathomatic ~/.mathomaticrc, ~/.matho_history History can be moved by using rlwrap mathomatic -r with the RLWRAP_HOME environment set appropriately.
Minecraft ~/.minecraft/ won't fix
Minetest ~/.minetest/ won't fix [322]
minicom ~/.minirc.dfl Upstream has a TODO entry for supporting configuration files under ~/.config/minicom. [323]
Mono ~/.mono/ [324]
mongodb ~/.mongorc.js, ~/.dbshell [325] This Stack Overflow thread suggests a partial workaround using command-line switch --norc.
~/.netrc Like ~/.ssh, many programs expect this file to be here. These include projects like curl (CURLOPT_NETRC_FILE), ftp (NETRC), s-nail (NETRC), etc. While some of them offer alternative configurable locations, many do not such as w3m, wget and lftp.
nim ~/.nimble [326]


nmcli ~/.nmcli-history [328] Hardcoded to g_get_home_dir()[329] [330]
Networkmanager-openvpn ~/.cert/nm-openvpn [331]
ocaml-utopAUR ~/.utop-history [332] There's an open PR to move ~/.utop-hostory to $XDG_CACHE_HOME [333]
OpenSSH ~/.ssh won't fix Assumed to be present by many ssh daemons and clients such as DropBear and OpenSSH.
palemoon ~/.moonchild productions [334]
parsec-binAUR ~/.parsec
pcsxrAUR ~/.pcsxr A -cfg flag exists, but can only be set relative to ~/.pcsxr.
perf ~/.debug Hardcoded in tools/perf/util/config.c. Commit: [335]
perl ~/.cpan, ~/perl5 [336] Perl5's CPAN expects ~/.cpan
phoronix-test-suiteAUR ~/.phoronix-test-suite [337]
portfolio-performance-binAUR ~/.PortfolioPerformance/ [338]
various shells and display managers ~/.profile
psensor ~/.psensor [339]
pulumi ~/.pulumi [340]
python ~/.python_history [341] [342] [343] All history from interactive sessions is saved to ~/.python_history by default since version 3.4. This can still be customized the same way as in older versions (see this example), including to use a custom path or disable history saving.


python-tensorflow ~/.keras [344] The issues is for tf.keras module
qmmp ~/.qmmp [345]
Qt Designer ~/.designer [346]
R ~/.Rprofile, ~/.Rdata, ~/.Rhistory
RedNotebook ~/.rednotebook [347]
Remarkable ~/.remarkable
renderdoc ~/.renderdoc won't fix
Ren'Py ~/.renpy won't fix
repo ~/.repoconfig [348]
ripgrep-all ~/.cache/rga [349] [350] [351] Support for writing the cache at $XDG_CACHE_HOME/ripgrep-all (+ reading configuration from $XDG_CONFIG_HOME/ripgrep-all/config.jsonc) was implemented in commit 963524b, which has not yet been included in a release (as of v0.9.6).
rpm ~/.rpmrc ~/.rpmmacros Backlog Workaround is to use --rcfile and --macros however this come with sideeffects.
SANE ~/.sane/ scanimage creates a .cal file there
sbcl ~/.sbclrc
(require :asdf)
(setf sb-ext:*userinit-pathname-function*
      (lambda () (uiop:xdg-config-home #P"sbcl/sbclrc")))

Note that this requires root privileges and will change the location of ~/.sbclrc for all users. This can be mitigated by checking for an existing ~/.sbclrc inside the lambda form.

SeaMonkey ~/.mozilla/seamonkey [352]
Signal Desktop [353] Currently keeps messages in ~/.config/Signal
Snap ~/snap/ [354]
Solfege ~/.solfege, ~/.solfegerc, ~/lessonfiles [355]
SpamAssassin ~/.spamassassin
SQLite ~/.sqlite_history, ~/.sqliterc [356] export SQLITE_HISTORY=$XDG_DATA_HOME/sqlite_history, sqlite3 -init "$XDG_CONFIG_HOME"/sqlite3/sqliterc
Steam ~/.steam, ~/.steampath, ~/.steampid [357] Many game engines (Unity 3D, Unreal) follow the specification, but then individual game publishers hardcode the paths in Steam Auto-Cloud causing game-saves to sync to the wrong directory.
stremioAUR ~/.stremio-server/ [358]
sts4 ~/.sts4 [359] Pass JVM arg -Dlanguageserver.boot.symbolCacheDir=$XDG_CACHE_HOME/sts4/symbolCache
python-streamlitAUR ~/.streamlit [360]
TeamSpeak ~/.ts3client export TS3_CONFIG_DIR="$XDG_CONFIG_HOME/ts3client"
terraform ~/.terraform.d/ [361]
texinfo ~/.infokey info --init-file "$XDG_CONFIG_HOME/infokey"
Thunderbird ~/.thunderbird/ [362]
TigerVNC ~/.vnc [363]
tllocalmgr ~/.texlive
urlviewAUR ~/.urlview Use fork urlview-xdg-gitAUR instead. The fork will use XDG_CONFIG_HOME/urlview/config
valeAUR ~/.vale.ini won't fix vale --config "$XDG_CONFIG_HOME/vale/config.ini"
vim ~/.vim, ~/.vimrc, ~/.viminfo [364] Since 7.3.1178 vim will search for ~/.vim/vimrc if ~/.vimrc is not found.
set runtimepath^=$XDG_CONFIG_HOME/vim
set runtimepath+=$XDG_DATA_HOME/vim
set runtimepath+=$XDG_CONFIG_HOME/vim/after

set packpath^=$XDG_DATA_HOME/vim,$XDG_CONFIG_HOME/vim
set packpath+=$XDG_CONFIG_HOME/vim/after,$XDG_DATA_HOME/vim/after

let g:netrw_home = $XDG_DATA_HOME."/vim"
call mkdir($XDG_DATA_HOME."/vim/spell", 'p')

set backupdir=$XDG_STATE_HOME/vim/backup | call mkdir(&backupdir, 'p')
set directory=$XDG_STATE_HOME/vim/swap   | call mkdir(&directory, 'p')
set undodir=$XDG_STATE_HOME/vim/undo     | call mkdir(&undodir,   'p')
set viewdir=$XDG_STATE_HOME/vim/view     | call mkdir(&viewdir,   'p')

if !has('nvim') | set viminfofile=$XDG_STATE_HOME/vim/viminfo | endif
export GVIMINIT='let $MYGVIMRC="$XDG_CONFIG_HOME/vim/gvimrc" | source $MYGVIMRC'
export VIMINIT='let $MYVIMRC="$XDG_CONFIG_HOME/vim/vimrc" | source $MYVIMRC'

[G]VIMINIT environment variable will also affect Neovim. If separate configs for Vim and Neovim are desired then the following will be a better choice:

export GVIMINIT='let $MYGVIMRC = !has("nvim") ? "$XDG_CONFIG_HOME/vim/gvimrc" : "$XDG_CONFIG_HOME/nvim/init.gvim" | so $MYGVIMRC'
export VIMINIT='let $MYVIMRC = !has("nvim") ? "$XDG_CONFIG_HOME/vim/vimrc" : "$XDG_CONFIG_HOME/nvim/init.vim" | so $MYVIMRC'
vimperator ~/.vimperatorrc [365] export VIMPERATOR_INIT=":source $XDG_CONFIG_HOME/vimperator/vimperatorrc"


visidata ~/.visidata [366]
wpa_cli ~/.wpa_cli_history
wegoAUR ~/.wegorc [367]
x2goclientAUR ~/.x2goclient alias x2goclient="x2goclient --home=$HOME/.config"
xpdf ~/.xpdfrc
xrdpAUR ~/thinclient_drives For the directory ~/thinclient_drives, you may consider editing /etc/xrdp/sesman.ini and modifying the section [Chansrv] following the example config.
XVim2 ~/.xvimrc [368]
YARD ~/.yard [369] Would accept Pull Request if anyone want to implement it.
zenmap nmap ~/.zenmap [370] [371]
zoomAUR ~/.zoom Unrecommended: setting the following variable moves the contents of .zoom but the directory itself always gets created. Moreover, it breaks some functionalities eg. being able to start a meeting. export SSB_HOME="$XDG_DATA_HOME"/zoom
zotero-binAUR ~/.zotero ~/Zotero [372]
zsh ~/.zshrc, ~/.zprofile, ~/.zshenv, ~/.zlogin, ~/.zlogout, ~/.histfile, ~/.zcompdump, ~/.zcompcache [373] Consider exporting ZDOTDIR=$HOME/.config/zsh in ~/.zshenv (this is hardcoded due to the bootstrap problem). You could also add this to /etc/zsh/zshenv and avoid the need for any dotfiles in your HOME. Doing this however requires root privilege which may not be viable and is system-wide.

export HISTFILE="$XDG_STATE_HOME"/zsh/history

compinit -d $XDG_CACHE_HOME/zsh/zcompdump-$ZSH_VERSION [374] /!\ The folder needs to exist

zstyle ':completion:*' cache-path $XDG_CACHE_HOME/zsh/zcompcache


The tool xdg-ninjaAUR detects unwanted files/directories in $HOME which can be moved to XDG base directories. See README for examples.


C99: Cloudef's simple implementation.
go-appdir (deprecated, archived)
configdir (deprecated, abandoned)
kyoh86/xdg (deprecated, archived)
Officially in directory since ab9d0810ce.
Java, Kotlin, Clojure, Scala, ...
appdirs (abandoned)
rubyworks/xdg (deprecated, abandoned)
Builtin support via GLib.Environment.
See get_user_cache_dir, get_user_data_dir, get_user_config_dir, etc.

Tips and tricks

Hiding unwanted directories

For directories which cannot be relocated, some desktop environments such as KDE allow you to hide them:

$ echo path >> ~/.hidden

path is the path of the file/directory, relative to the parent directory of .hidden.

See also