XDG Base Directory
This article summarizes the XDG Base Directory specification in #Specification and tracks software support in #Support.
Specification
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. Changing it might cause issues with pipewire and screen sharing on chromium.
See Environment variables#Globally for information on defining variables.
User directories
- 
XDG_CONFIG_HOME- Where user-specific configurations should be written (analogous to /etc).
- Should default to $HOME/.config.
 
- Where user-specific configurations should be written (analogous to 
- 
XDG_CACHE_HOME- Where user-specific non-essential (cached) data should be written (analogous to /var/cache).
- Should default to $HOME/.cache.
 
- Where user-specific non-essential (cached) data should be written (analogous to 
- 
XDG_DATA_HOME- Where user-specific data files should be written (analogous to /usr/share).
- Should default to $HOME/.local/share.
 
- Where user-specific data files should be written (analogous to 
- 
XDG_STATE_HOME- Where user-specific state files should be written (analogous to /var/lib).
- Should default to $HOME/.local/state.
 
- Where user-specific state files should be written (analogous to 
- 
XDG_RUNTIME_DIR- 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
- 
XDG_DATA_DIRS- List of directories separated by :(analogous toPATH).
- Should default to /usr/local/share:/usr/share.
 
- List of directories separated by 
- 
XDG_CONFIG_DIRS- List of directories separated by :(analogous toPATH).
- Should default to /etc/xdg.
 
- List of directories separated by 
Support
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.
Contributing
When contributing make sure to use the correct section.
Nothing should require code evaluation, 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.
Supported
| Application | Legacy Path | Supported Since | Discussion | Notes | |
|---|---|---|---|---|---|
| act | ~/.actrc | 1656 | [5] | XDG_CONFIG_HOME/act/actrcIf present  | |
| aerc | fff1664 | XDG_CONFIG_HOME/aerc/aerc.conf | |||
| ALSA | ~/.asoundrc | 577df36 | [6] | XDG_CONFIG_HOME/alsa/asoundrc | |
| anacondaAUR | ~/.conda/.condarc,~/.conda/condarc,~/.conda/condarc.d/,~/.condarc | 4.11.0 | [7] [8] | ||
| Android Studio | ~/.AndroidStudioX.X | Android Studio 4.1 | XDG_CONFIG_HOME/Google/AndroidStudioX.X XDG_DATA_HOME/Google/AndroidStudioX.X XDG_CACHE_HOME/Google/AndroidStudioX.X 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 | [9] [10] [11] | Uses $XDG_DATA_HOME/Anki2as default if no older location exists, can be changed by usinganki -b <anki_dir> | ||
| antimicrox | ~/.antimicro,~/.antimicrox | edba864 | [12] | ||
| apvlvAUR | ~/.apvlvrc | [13] | [14] | Uses XDG_CONFIG_HOME/apvlv/apvlvrcnow if it exist. | |
| aria2 | ~/.aria2 | 8bc1d37 | [15] | XDG_CONFIG_HOME/aria2/ XDG_CACHE_HOME/aria2/ | |
| atuin | ~/.config/atuin~/.local/share/atuin | 156893d | XDG_CONFIG_HOME/atuin/config.toml XDG_DATA_HOME/atuin/history.db | ||
| asunderAUR | ~/.asunder~/.asunder_album_artist~/.asunder_album_genre~/.asunder_album_title | 2.9.0[dead link 2021-05-17 ⓘ] | [16][dead link 2021-05-17 ⓘ] | Uses XDG_CONFIG_HOME/asunder/asunderfor~/.asunderandXDG_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 | [17] | Uses new locations if legacy do not exist: XDG_CONFIG_HOME/audacity XDG_DATA_HOME/audacity | |
| btop | b5e709d | XDG_CONFIG_HOME/btop | |||
| binwalk | ~/.binwalk | 2051757 | [18] | XDG_CONFIG_HOME/binwalk | |
| bitwarden-cli | ~/.config/Bitwarden CLI | 1.7.1 | [19] | XDG_CONFIG_HOME/Bitwarden CLI The  Currently contains a single  | |
| Blender | ~/.blender | 4293f47 | [20] | ||
| borgmatic | ~/.borgmatic/ | 1.9.0 | [21] | ||
| byobu | ~/.byobu | 4.17 | [22] | 
 Legacy path takes precedence if present, or if  | |
| cabal | ~/.cabal/ | 9f7dc55 v3.10.1.0 | [23] | ||
| calcurse | ~/.calcurse | 04162d | [24] [25] | XDG_CONFIG_HOME/calcurse XDG_DATA_HOME/calcurse If the legacy path  | |
| calibre | |||||
| ccache | ~/.ccache | 4.0 | [26] | XDG_CACHE_HOME/ccache XDG_CONFIG_HOME/ccache/ccache.conf | |
| catfish | ~/.config/catfish | af65ed25 | [27] | ||
| clangd | ~/.clangd | ad38f4b3 11.0.0 | [28] | XDG_CONFIG_HOME/clangd/config.yml
 Project specific configuration can be specified in  | |
| clifmAUR | ~/.config/clifm/ | 9d6e482 | XDG_CONFIG_HOME/clifm/ | ||
| Composer | ~/.composer | 1.0.0-beta1 | [29] | ||
| crossnote | ~/.mume | d714a82 | [30] | $XDG_CONFIG_HOME/mumeIf the legacy path is present, it will take precedence. | |
| ctags (universal-ctags) | ~/.ctagsrc, .ctags.d | 68da03a | Issue 89 | At start-up time, Universal-ctags loads files having file`.ctags` as a file extension under: $XDG_CONFIG_HOME/ctagsSee Ctags Option files. | |
| cURL | ~/.curlrc | 7.73.0 | [31] | XDG_CONFIG_HOME/curlrc | |
| CUPS | ~/.cups/ | 23b1be6 | [32] | libcups added XDG support in v3 (still in beta). The version in the official repositories is still hardcoded to  | |
| dconf | |||||
| Dolphin emulator | ~/.dolphin-emu | a498c68 | [33] | ||
| dr14_t.meter-gitAUR | 7e777ca | [34] | XDG_CONFIG_HOME/dr14tmeter/ | ||
| dunst | 78b6e2b | [35] | XDG_CONFIG_HOME/dunst/ | ||
| Emacs | ~/.emacs~/.emacs.d/init.el | [36] | XDG_CONFIG_HOME/emacs/init.elLegacy paths have precedence over XDG paths.  Emacs will never create  | ||
| fish | |||||
| fltk | ~/.fltk/ | 7308bcd | [37] [38] | Only supported in version 1.4.0, which doesn't exist in Arch Linux's official repositories yet (as of 25-May-2025) | |
| fontconfig | ~/.fontconfig~/.fonts | 8c255fb, [39] | Config goes in XDG_CONFIG_HOME/fontconfig/fonts.conforXDG_CONFIG_HOME/fontconfig/conf.d/, fonts are stored inXDG_DATA_HOME/fonts/ | ||
| fontforge | ~/.FontForge~/.PfaEdit | e4c2cc7 | |||
| freecad | ~/.FreeCAD | e7e2994ba | [42] | Defaults to XDG_CONFIG_HOME/FreeCAD XDG_DATA_HOME/FreeCAD XDG_CACHE_HOME/FreeCAD legacy path can be used with  | |
| freerdp | ~/.freerdp | edf6e72 | |||
| Gajim | ~/.gajim | 3e777ea | [43] | ||
| gconfAUR | ~/.gconf | fc28caa | [44] | ||
| GDB | ~/.gdbinit,~/.gdb_history | 11.1 | XDG_CONFIG_HOME/gdb/gdbinit,export GDBHISTFILE="$XDG_DATA_HOME"/gdb/history | ||
| ghidra | ~/.ghidra/ | 3b0aac9 | [45] | ||
| GIMP | ~/.gimp-x.y~/.thumbnails | ||||
| Git | ~/.gitconfig,~/.gitignore,~/.gitattributes,~/.git-credentials,~/.gitk | 0d94427, dc79687, 684e40f | Git Config, Git Attributes, Git Credentials, gitk | XDG_CONFIG_HOME/git/config,XDG_CONFIG_HOME/git/ignore,XDG_CONFIG_HOME/git/attributes,XDG_CONFIG_HOME/git/credentials,XDG_CONFIG_HOME/git/gitk | |
| gops | 71c4255 | ||||
| gnuplot | ~/.gnuplot_history | a5562b1 | |||
| goobookAUR | ~/.goobookrc | 3.5 | [49] | XDG_CONFIG_HOME/goobookrc | |
| Godot Engine | ~/.godot | 73049d1 | [50] | ||
| GStreamer | ~/.gstreamer-0.10 | 4e36f93 | [51] | ||
| GTK 3 | |||||
| Haskell#Stack | ~/.stack | 2.9.3 | [52] | Defaults to legacy. Use export STACK_XDG=1to make it compliant with the spec.The old method of  | |
| helm | ~/.helm | 3.0.0 | |||
| htop | ~/.htoprc | 93233a6 | XDG_CONFIG_HOME/htop/htoprc | ||
| httpie | ~/.httpie | 5af0874 | [54] | ||
| hunspell | ~/.hunspell_default. | [55] | |||
| i3 | ~/.i3 | 7c130fb | |||
| i3blocks, i3blocks-gitAUR | [56] | ||||
| i3status | ~/.i3status.conf | c3f7fc4 | |||
| i3status-rust | |||||
| IdeaVim | ~/.ideavimrc | 0.54.1-EAP | [57] | XDG_CONFIG_HOME/ideavim/ideavimrc | |
| imagemagick | |||||
| iotop-c | ~/.config/iotop | [58] | [59] | ||
| Inkscape | ~/.inkscape | 0.47 | [60] | ||
| ipython | ~/.ipython | 8.0.0 | [61] | Checks if $XDG_CONFIG_HOME/ipython(or~/.config/ipythonifXDG_CONFIG_HOMEis unset) exists, otherwise it uses~/.ipython. | |
| iwd / iwctl | ~/.iwctl_history | d3e00d7f | |||
| intellij-idea-community-edition / intellij-idea-ultimate-editionAUR | ~/.IntelliJIdeaXXXX.X | 2020.1 | [62] | XDG_CONFIG_HOME/JetBrains/IntelliJIdeaXXXX.X XDG_DATA_HOME/JetBrains/IntelliJIdeaXXXX.X XDG_CACHE_HOME/JetBrains/IntelliJIdeaXXXX.X | |
| josm | ~/.josm | 11162 | [63] | ||
| jupyter | ~/.jupyter | opt-in in 5.0, opt-out in 6.0, compulsory in 7.0 (changelog) | XDG_CONFIG_HOME/jupyter | ||
| Kakoune | |||||
| keynavAUR | ~/.keynavrc | XDG_CONFIG_HOME/keynav/keynavrc | |||
| less | ~/.lesskey,~/.lesshst | 590 full support in 598 | [64] | The environment variables XDG_CONFIG_HOMEandXDG_DATA_HOMEmust be set in version 590. In version 598 this is no longer necessary.
 
 | |
| latexmk (in texlive-binextra) | ~/.latexmkrc | 
 | |||
| lftp | ~/.lftp | 21dc400 | [65] | ||
| lgogdownloaderAUR | ~/.gogdownloader | d430af6 | [66] | ||
| luarocks | ~/.luarocks | cd16cdd | [67] | XDG_CONFIG_HOME/luarocks XDG_CACHE_HOME/luarocks If the legacy path  | |
| mangohud | 65b90fc | [68] | XDG_CONFIG_HOME/MangoHud | ||
| mc | ~/.mc | [69] | |||
| Mercurial | ~/.hgrc | XDG_CONFIG_HOME/hg/hgrc. | |||
| mesa | 87ab26b | XDG_CACHE_HOME/mesa | |||
| milkytracker | ~/.milkytracker_config | eb487c5 | [70] | ||
| mlterm | ~/.mlterm/ | 71df071 | [71] | XDG_CONFIG_HOME/mlterm/ | |
| mozc | ~/.mozc | 91cc1e1 | [72] | ||
| mpd | ~/.mpdconf | 87b7328 | |||
| mpv | ~/.mpv | cb250d4 | [73] | ||
| msmtp | ~/.msmtprc | af2f409 v1.6.7+ |  XDG_CONFIG_HOME/msmtp/config. | ||
| mutt | ~/.mutt | b17cd67 | [74] | ||
| mypaint | ~/.mypaint | cf723b7 | |||
| nano | ~/.nano/~/.nanorc | c16e79b | [75] | ||
| ncmpcpp | ~/.ncmpcpp~/.lyrics | ncmpcpp_directoryshould be set to avoid anerror.logfile in~/.ncmpcpp. Andlyrics_directorycan be set to~/.cache/ncmpcpp-lyricsto avoid~/.lyrics. | |||
| Neovim | ~/.nvim~/.nvimlog~/.nviminfo | 1ca5646bb | |||
| Nestopia UE | ~/.nestopia/ | 610c008 1.51.0 | [81] | ||
| newsboat | ~/.newsboat | 3c57824 | [82] | It is required to create both directories [83]: 
 | |
| Nix | ~/.nix-channels~/.nix-defexpr~/.nix-profile | [84] | [85] | Set use-xdg-base-directories = truein your/etc/nix/nix.conf | |
| node-gyp | ~/.node-gyp | 2b5ce52a | [86] | ||
| nmcli | ~/.nmcli-history | 1.52.0 | [87] [88] [89] | XDG_CACHE_HOME/nmcli-history | |
| np2kai-gitAUR | ~/.config/np2kai~/.config/xnp2kai | 56a1cc2 | [90] | ||
| notmuch | ~/.notmuch-config | [91] | mkdir -p $XDG_CONFIG_HOME/notmuch/default; mv ~/.notmuch-config $XDG_CONFIG_HOME/notmuch/default/config | ||
| NSS | ~/.pki | 3.42 (da45424) | [92] | See Chromium for existing issue. | |
| nteract-binAUR | 4593e72 | [93] [94] | does not recognize workarounds for ipython/jupyter | ||
| ocaml-utopAUR | ~/.utop-history
 | 2.13.0 | [95] | XDG_STATE_HOME/utop/utop-history
 | |
| OfflineIMAP | ~/.offlineimaprc | 5150de5 | [96] | XDG_CONFIG_HOME/offlineimap/config | |
| openal | ~/.alsoftrc | 3c90ed9 | XDG_CONFIG_HOME/alsoft.conf | ||
| opentyrianAUR | ~/.opentyrian | 39559c3 | [97] | ||
| oscAUR | ~/.oscrc~/.osc_cookiejar | 6bc2d3f | github.com/openSUSE/osc/pull/940 | 
 Legacy path takes precedence if it exists | |
| pam-u2f | ~/.config/Yubico/u2f_keys | ad52dd8 | [98] | XDG_CONFIG_HOME/Yubico/u2f_keys | |
| pandoc-cli | ~/.pandoc/ | 0bed0ab | [99] | ||
| PCManFM | ~/.thumbnails | 1.3.2 | |||
| pcsx2AUR | ~/.pcsx2 | [100] [101] | |||
| pdfsamAUR | ~/.openjfx | export _JAVA_OPTIONS=-Djavafx.cachedir="$XDG_CACHE_HOME"/openjfx | |||
| Pry | ~/.pryrc~/.pry_history | [102] | |||
| python-autoimportAUR | ~/.config/autoimport/config.toml | 1.2.0 | [103] | XDG_CONFIG_HOME/autoimport/config.toml | |
| python-black | ~/.config/black | 21.4b0 | [104] | XDG_CONFIG_HOME/black,XDG_CACHE_HOME/black/<version>/ | |
| python-pylint | ~/.pylint.d | 2.10 | [105] | Formerly export PYLINTHOME="$XDG_CACHE_HOME"/pylint, global config still needs:export PYLINTRC="$XDG_CONFIG_HOME"/pylint/pylintrc | |
| python-pip | ~/.pip | 6.0 | [106] | ||
| python-pipx | ~/.local/pipx | c3d8de9 | [107] | For compatibility, pipx will revert to ~/.local/pipxif it exists. Implemented using python-platformdirs | |
| python-poetry | ~/.poetry | [108] | [109] | ||
| powershellAUR | 6.0 | ||||
| ppsspp | ~/.ppsspp | 132fe47 | [110] | ||
| procps-ng | ~/.toprc | af53e17 | |||
| pacman | ~/.makepkg.conf | 80eca94 | [113] | ||
| panda3dAUR | ~/.panda3d | 2b537d2 | |||
| pnpm | ~/.pnpm-store | [114] [115] | [116] | ||
| poezioAUR | |||||
| PulseAudio | ~/.pulse~/.pulse-cookie | [117] | Steam might still create ~/.pulse-cookie. Addcookie-file = ~/.config/pulse/cookieto/etc/pulse/client.confto get rid of it. | ||
| pyroomAUR | |||||
| quodlibet | ~/.quodlibet | 3.10.0 | [118] | ||
| qutebrowser | |||||
| qtile | [119] | Some optional bar widgets can create files and directories in non-compliant paths, but most often these are still configurable. | |||
| rclone | ~/.rclone.conf | 9d36258 | [120] | ||
| retroarch | |||||
| ripgrep-all | ~/.cache/rga | 963524b v0.10.3 | [121] [122] [123] | ||
| rrAUR | ~/.rr | 02e7d41 | [124] | ||
| RSpec | ~/.rspec | 5e395e2 | [125] | ||
| rTorrent | ~/.rtorrent.rc | 6a8d332 | |||
| RuboCop | ~/.rubocop.yml | 6fe5956 | [126] | ||
| Ruby#RubyGems | ~/.gem | 3.0.0 (5c6269c) | [127] | XDG_CONFIG_HOME/gem/gemrc XDG_CONFIG_HOME/irb XDG_DATA_HOME/gem XDG_DATA_HOME/rdoc | |
| sandboxd | ~/.sandboxrc | [128] | [129] | XDG_CONFIG_HOME/sandboxd/sandboxrc | |
| scribus | ~/.scribus | 1.5.3 | |||
| scummvm | ~/.scummvmrc~/.scummvm/ | 7d014be | [130] | It is required to migrate data by hand. 
 | |
| sdcv | ~/.stardict/~/.sdcv_history | 958ec35 | [131] | ||
| shellcheck | ~/.shellcheckrc | 581bcc3 | XDG_CONFIG_HOME/shellcheckrcSee Shellcheck RC Files for more info. | ||
| snes9x | ~/.snes9x | 93b5f11 | [132] | 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 | [133] | ||
| 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 | ||||
| sway | ~/.sway/config | 614393c | [134] | XDG_CONFIG_HOME/sway/config | |
| sxhkd | |||||
| systemd | |||||
| teeworlds | ~/.teeworlds | [135] | |||
| termite | |||||
| tig | ~/.tigrc,~/.tig_history | 2.2 | [136] | ~/.local/share/tigdirectory must exist, writes to~/.tig_historyotherwise. | |
| TigerVNC | ~/.vnc | 1.14.0 | [137] | ||
| Theming (desktop) | ~/.icons/,~/.themes/ | [138] | XDG_DATA_HOME/icons
 For Qt programs, GTK or Qt programs on Wayland, to use cursors in  | ||
| tmux | ~/.tmux.conf | 3.1 | [139] | 3.1 introduced ~/.config/tmux/tmux.confand in 3.2XDG_CONFIG_HOME/tmux/tmux.confwas added | |
| tmuxp | ~/.tmuxp | 1.5.0 | [140] | Fixed in 1.5.2 | |
| tmuxinatorAUR | ~/.tmuxinator | 2636923 | [141] | ||
| Transmission | ~/.transmission | b71a298 | |||
| util-linux | 570b321 | ||||
| yapf | a0b51d2 | [142] | $XDG_CONFIG_HOME/yapf/style | ||
| Uzbl | c6fd63a | [143] | |||
| vale | ~/.vale.ini | 3.0.0 | |||
| vim | ~/.vim,~/.vimrc,~/.viminfo | c9df1fb | [144] | XDG_CONFIG_HOME/vim/vimrcSee :h xdg-base-dir for more details. The viminfo file can be set with  | |
| vimb | |||||
| VirtualBox | ~/.VirtualBox | 4.3 | [145] | ||
| vis | ~/.vis | [146] | |||
| VLC | ~/.vlcrc | 16f32e1 | [147] | ||
| warsow | ~/.warsow-2.x | 98ece3f | [148] | ||
| WeeChat | ~/.weechat | [149] | [150] [151][dead link 2023-05-06 ⓘ] | XDG_CONFIG_HOME/weechat XDG_CACHE_HOME/weechat XDG_DATA_HOME/weechat | |
| Wireshark | ~/.wireshark | b0b53fa v2.1.0 | |||
| wxWidgets | [152] | ||||
| XKB | ~/.xkb | ||||
| Xsettingsd | ~/.xsettingsd | b4999f5 | |||
| xmobar | ~/.xmobarrc | 7b0d6bf[dead link 2024-07-30 ⓘ] 9fc6b37[dead link 2024-07-30 ⓘ] eaccf70[dead link 2024-07-30 ⓘ] | [153][dead link 2024-07-30 ⓘ] | XDG_CONFIG_HOME/xmobar/xmobarrc | |
| xmonad | ~/.xmonad/ | 40fc10b | All of these must exist, otherwise it gives up and falls back to ~/.xmonad/for each:XDG_CACHE_HOME/xmonad XDG_CONFIG_HOME/xmonad XDG_DATA_HOME/xmonad Alternatively, it always respects  | ||
| xonsh | ~/.xonshrc | [157] | $XDG_CONFIG_HOME/xonsh/rc.xsh | ||
| xournalpp | ~/.xournalpp | 20db937f | [158] | ||
| xsel | ~/.xsel.log | ee7b481 | [160] | ||
| Zim | e42b8b0 | $XDG_CONFIG_HOME/zim/preferences.conf $XDG_CONFIG_HOME/zim/notebooks.list | |||
| zoxide | ~/.zo | 0.3.0 | [161] | ||
| zutils | ~/.zutilsrc | 1.12 | $XDG_CONFIG_HOME/zutils.conf | 
Partial
| Application | Legacy Path | Supported Since | Discussion | Notes | 
|---|---|---|---|---|
| abookAUR | ~/.abook | abook --config "$XDG_CONFIG_HOME"/abook/abookrc --datafile "$XDG_DATA_HOME"/abook/addressbook | ||
| ackAUR | ~/.ackrc | [162] | export ACKRC="$XDG_CONFIG_HOME/ack/ackrc" | |
| Ansible | ~/.ansible | 2.14 | [163] [164] [165] | 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"[166]The remote's  | 
| asdf-vmAUR | ~/.asdfrc,~/.asdf/ | [169] | export ASDF_CONFIG_FILE="${XDG_CONFIG_HOME}/asdf/asdfrc",export ASDF_DATA_DIR="${XDG_DATA_HOME}/asdf" | |
| aspell | ~/.aspell.conf | [170] | Very incomplete. The following re-locates the endictionaries, but additional possible dictionaries are not specificed here for brevity.export ASPELL_CONF="per-conf $XDG_CONFIG_HOME/aspell/aspell.conf; personal $XDG_DATA_HOME/aspell/en.pws; repl $XDG_DATA_HOME/aspell/en.prepl" | |
| aws-cli | ~/.aws | 1.7.45 | [171] | 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 [172], you can specify a file to run commands from. Thus, move the init file to XDG_CONFIG_HOME/bashdb/bashdbinitand create an aliasalias bashdb='bashdb -x ${XDG_CONFIG_HOME:-$HOME/.config}/bashdb/bashdbinit'. Unfortunately the history file is hardcoded [173]. | ||
| bazaar | ~/.bazaar,~/.bzr.log | 2.3.0 | [174] | Discussion in upstream bug states that bazaar will use ~/.config/bazaarif it exists. The logfile~/.bzr.logmight still be written. | 
| bogofilter-db | ~/.bogofilter | 0.7.5 | [175] | export BOGOFILTER_DIR="$XDG_DATA_HOME"/bogofilter | 
| btpd-gitAUR | ~/.btpd/ | [176] | btpd -d "$XDG_DATA_HOME"/.btpd
 | |
| bunAUR | ~/.bun/ | [177] | Bun will prioritize using $XDG_CONFIG_HOME,$XDG_CACHE_HOME, and/or$XDG_DATA_HOMEwhen these have explicitly been set. As an alternative,export BUN_INSTALL="$XDG_DATA_HOME"/buncan be used to setbun's main location for its directories. | |
| calc | ~/.calc_history | export CALCHISTFILE="$XDG_CACHE_HOME"/calc_history | ||
| Rust#Cargo | ~/.cargo | [178] [179] [180] [181] | export CARGO_HOME="$XDG_DATA_HOME"/cargo | |
| cataclysm-dda | ~/.cataclysm-dda | 0.D-1 | [182] | partial support due to required compile time option | 
| cd-bookmark | ~/.cdbookmark | [183] | export CD_BOOKMARK_FILE=$XDG_CONFIG_HOME/cd-bookmark/bookmarksor use the fork that has native XDG support: [184] | |
| cgdb | ~/.cgdb | 0.8.0 | [185] [186] | Set export CGDB_DIR=$XDG_CONFIG_HOME/cgdband move the config file toXDG_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) andexport CHKTEXRC=$XDG_CONFIG_HOME/chktex | ||
| Chromium | ~/.chromium,~/.pki | 23057 | [187] [188] [189] | Deliberately (according to these sources) clobbers ~/.configby writing hundreds of megabytes of cache data into it. Quite unsupported.Chromium creates .pki due to not setting up NSS properly even though NSS itself allows using XDG spec now. This results in downstream from it not working as well (Qt WebEngine especially affecting many cases like KMail and etc.) | 
| cinelerra | ~/.bcast5 | [190] | export CIN_CONFIG="$XDG_CONFIG_HOME"/bcast5 | |
| conky | ~/.conkyrc | 00481ee | [191] | conky --config="$XDG_CONFIG_HOME"/conky/conkyrc | 
| claws-mail | ~/.claws-mail | [192] | 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: 
 | ||
| clusterssh | ~/.clusterssh/ | alias cssh="cssh --config-file '$XDG_CONFIG_HOME/clusterssh/config'"$XDG_CONFIG_HOME/clusterssh/config extra_cluster_file=$HOME/.config/clusterssh/clusters extra_tag_file=$HOME/.config/clusterssh/tags Despite this, clusterssh will still create  | ||
| CUDA | ~/.nv | export CUDA_CACHE_PATH="$XDG_CACHE_HOME"/nv | ||
| dict | ~/.dictrc | dict -c "$XDG_CONFIG_HOME"/dict/dictrc | ||
| discord | ${XDG_CONFIG_HOME}/discord | As of version 0.0.27: Undocumented, though actively used:
 Source:  | ||
| 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 | [193] | dosbox -conf "$XDG_CONFIG_HOME"/dosbox/dosbox.conf | |
| dub | ~/.dub | v1.30.0-beta.1 | Dub uses the ~/.dubdirectory for both user settings and caching downloaded packages. The directory can only be moved as a whole, usingexport 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,~/.hex | afaf889 | [194] [195] | Elixir does not fully conform to XDG specs, it will use XDG only if the MIX_XDGvariable is set to a special value, otherwise it will by default use legacy path.
 | 
| erlang | ~/.erlang.cookie | [196] | [197] | Erlang does not fully conform to XDG specs, it looks for its files in XDG_CONFIG_HOMElast.
 | 
| Elm | ~/.elm | export ELM_HOME="$XDG_CONFIG_HOME"/elm | ||
| factorioAUR | ~/.factorio/ | [198] [199] | Factorio supports manually specifying data paths with a config file: [200] __Game_Install_directory/config-path.cfg use-system-read-write-data-directories=true __Game_Install_directory/config/config.ini [path] read-data=__PATH__executable__/../../data write-data=.local/share/factorio | |
| fceux | ~/.fceux/ | [201] | export FCEUX_HOME="$XDG_CONFIG_HOME"/fceux. Fceux will create.fceuxdirectory inside$FCEUX_HOME. | |
| FFmpeg | ~/.ffmpeg | export FFMPEG_DATADIR="$XDG_CONFIG_HOME"/ffmpeg | ||
| flutterAUR | ~/.flutter,~/.flutter_settings,~/.flutter_tool_state,~/.pub-cache | [202] | ||
| fzf-gitAUR | ~/.fzf.bash, ~/.fzf.zsh | [203] | The shell init files will be installed to XDG_CONFIG_HOME/fzfif the installation script is called with--xdgfor example /usr/local/opt/fzf/install --xdg. | |
| emscripten | ~/.emscripten,~/.emscripten_sanity,~/.emscripten_ports,~/.emscripten_cache__last_clear | [204] | 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 | [205] | [206][dead link 2025-04-06 ⓘ] | Supported upstream from 9.4.1 [207], but as of 2025-03-18 Arch package is 9.2.8 and not yet up-to-date. | 
| ghcup-hs-binAUR | ~/.ghcup | [208] | [209] | export GHCUP_USE_XDG_DIRS=trueThe environment variable  | 
| glivAUR | ~/.glivrc | gliv --glivrc="$XDG_CONFIG_HOME"/gliv/glivrc | ||
| gnuradio | ~/.gnuradio | [211] | GNU Radio: 
 GNU Radio Companion:
 | |
| GnuPG | ~/.gnupg | [212] [213] | export GNUPGHOME="$XDG_DATA_HOME"/gnupg,gpg2 --homedir "$XDG_DATA_HOME"/gnupgNote 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  [Service] Environment="GNUPGHOME=%h/.local/share/gnupg" If you use GPG as your SSH agent, set  | |
| Go | ~/go | [214] | export GOPATH="$XDG_DATA_HOME"/go,export GOMODCACHE="$XDG_CACHE_HOME"/go/modIf  | |
| Google Earth | ~/.googleearth | Some paths can be changed with the KMLPathandCachePathoptions in~/.config/Google/GoogleEarthPlus.conf | ||
| gopass | ~/.password-store | Override settings in ~/.config/gopass/config.yml:~/.config/gopass/config.yml root: path: gpgcli-gitcli-fs+file:///home/<userid>/.config/password-store 
 | ||
| gpodder | ~/gPodder | GPODDER_DOWNLOAD_DIRsets the download folder.GPODDER_HOME- where config and database files are stored, downloads also ifGPODDER_DOWNLOAD_DIRis 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 | [217] | export GRADLE_USER_HOME="$XDG_DATA_HOME"/gradle | |
| 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":"$XDG_CONFIG_HOME/gtk-2.0/gtkrc.mine"If Lxappearance is used,  To prevent KDE Plasma from creating this file, disable the "GNOME/GTK Settings Synchronization" background service. | ||
| hledger | ~/.hledger.journal | [219] | export LEDGER_FILE="$XDG_DATA_HOME"/hledger.journal | |
| Houdini | ~/houdiniMAJOR.MINOR) | [220] | export HOUDINI_USER_PREF_DIR="$XDG_CACHE_HOME"/houdini__HVER__The value of this variable must include the substring  | |
| imapfilterAUR | ~/.imapfilter | export IMAPFILTER_HOME="$XDG_CONFIG_HOME/imapfilter" | ||
| IPFS | ~/.ipfs | export IPFS_PATH="$XDG_DATA_HOME"/ipfs | ||
| irb | ~/.irbrc | ~/.profile $ export IRBRC="$XDG_CONFIG_HOME"/irb/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 | [222] | irssi --config="$XDG_CONFIG_HOME"/irssi/config --home="$XDG_DATA_HOME"/irssi | |
| isync | ~/.mbsyncrc | [223] | mbsync -c "$XDG_CONFIG_HOME"/isync/mbsyncrc | |
| Java#OpenJDK | ~/.java/.userPrefs | [224] | export _JAVA_OPTIONS=-Djava.util.prefs.userRoot="$XDG_CONFIG_HOME"/java | |
| jupyter | ~/.jupyter | 5.0.0rc0 | [225] [226] | python-jupyter-core < v5.0.0: 
 v5.0.0 <= python-jupyter-core < v6.0.0: 
 python-jupyter-core >= v6.0.0: full support (via python-platformdirs) enabled by default | 
| k9s | ~/.k9s | 0.20.4 | [228] | export K9SCONFIG="$XDG_CONFIG_HOME"/k9s | 
| KDE4 | ~/.kde,~/.kde4 | [229] | export KDEHOME="$XDG_CONFIG_HOME"/kdeKDE4 uses  | |
| keychain | ~/.keychain | [230] | [231] | keychain --absolute --dir "$XDG_RUNTIME_DIR"/keychain | 
| kodi | ~/.kodi | [232] | [233] | KODI_DATA=$XDG_DATA_HOME/kodi | 
| kscriptAUR | ~/.kscript | [234] | export KSCRIPT_CACHE_DIR="$XDG_CACHE_HOME"/kscript | |
| ledger | ~/.ledgerrc,~/.pricedb | [235] | ledger --init-file "$XDG_CONFIG_HOME"/ledgerrc | |
| Leiningen | ~/.lein,~/.m2 | [236] | export LEIN_HOME="$XDG_DATA_HOME"/leinto change the m2 repo location used by leiningen look here: Leiningen#m2_repo_location | |
| libdvdcss | ~/.dvdcss | [237] | export DVDCSS_CACHE="$XDG_DATA_HOME"/dvdcss | |
| libice | ~/.ICEauthority | [238] | export ICEAUTHORITY="$XDG_CACHE_HOME"/ICEauthorityMake sure  Do not use  | |
| LibreOffice | [239] | Libreoffice stores everything in $XDG_CONFIG_HOME/libreoffice/4/user/, including runtime files, user data, cache and extensions. Some of these can be changed unter Tools > Options > LibreOffice > Paths | ||
| 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 | ||
| Luanti | ~/.minetest/ | [240] | export MINETEST_USER_PATH="$XDG_DATA_HOME"/luanti | |
| lynx | /etc/lynx.cfg | export LYNX_CFG="$XDG_CONFIG_HOME"/lynx.cfg | ||
| m17n-db | ~/.m17n.d | [241] | ||
| maptool-binAUR | ~/.maptool-rptools | [242] | /opt/maptool/lib/app/MapTool.cfg [JavaOptions] -DMAPTOOL_DATADIR=.local/share/maptool-rptools However, no way to change the location of this configuration file. | |
| maven | ~/.m2 | [243] | export MAVEN_OPTS=-Dmaven.repo.local="$XDG_DATA_HOME"/maven/repository,export MAVEN_ARGS="--settings $XDG_CONFIG_HOME/maven/settings.xml",  | |
| Mathematica | ~/.Wolfram | export WOLFRAM_USERBASE="$XDG_CONFIG_HOME"/WolframUsed to be  | ||
| maxima | ~/.maxima | export MAXIMA_USERDIR="$XDG_CONFIG_HOME"/maxima | ||
| mednafen | ~/.mednafen | export MEDNAFEN_HOME="$XDG_CONFIG_HOME"/mednafen | ||
| minikube | ~/.minikube | [244] | export MINIKUBE_HOME="$XDG_DATA_HOME"/minikubeCreates a further  | |
| 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 | ||
| mtpaint | ~/.mtpaint | [245] | /etc/mtpaint/mtpaintrc userINI = ~/.config/mtpaint | |
| mypy | ~/.config/mypy/config,~/.mypy.ini,~/.mypy_cache | v0.670 | [246] [247] | 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
 
 | ||
| mysql-workbench | ~/.mysql/workbench | You can run MySQL Workbench with the ---configdirflag, such asmysql-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: 
 | ||
| n | /usr/local/n | export N_PREFIX=$XDG_DATA_HOME/n | ||
| ncmpc | ~/.ncmpc | ncmpc -f "$XDG_CONFIG_HOME"/ncmpc/config | ||
| Netbeans | ~/.netbeans | [249] | netbeans --userdir "${XDG_CONFIG_HOME}"/netbeans | |
| Node.js | ~/.node_repl_history | [250] | export NODE_REPL_HISTORY="$XDG_DATA_HOME"/node_repl_history | |
| npm | ~/.npm,~/.npmrc | [251] | export NPM_CONFIG_USERCONFIG=$XDG_CONFIG_HOME/npm/npmrcnpmrc prefix=${XDG_DATA_HOME}/npm
cache=${XDG_CACHE_HOME}/npm
init-module=${XDG_CONFIG_HOME}/npm/config/npm-init.js
logs-dir=${XDG_STATE_HOME}/npm/logs
 | |
| opam | ~/.opam | [252] | export OPAMROOT="$XDG_DATA_HOME/opam"Both configuration and state data are stored in  | |
| PHP | ~/.php_history | PHP 8.4 | [253] | export PHP_HISTFILE="$XDG_STATE_HOME"/php/history | 
| PuTTY | ~/.putty/ | 9952b2d | Will use $XDG_CONFIG_HOME/puttyif it already exists. Creates~/.puttyif not. Prioritises$XDG_CONFIG_HOME/puttyif both exist. Tested in 0.74 | |
| python-easyocrAUR | ~/.EasyOCR | export EASYOCR_MODULE_PATH="$XDG_CONFIG_HOME/EasyOCR" | ||
| spotdlAUR | ~/.spotdl | v4.0.6 (3929cae) | [254] | mkdir "$XDG_DATA_HOME"/spotdl | 
| nuget | ~/.nuget/packages | [255] | export NUGET_PACKAGES="$XDG_CACHE_HOME"/NuGetPackages | |
| NVIDIA | ~/.nv | Uses XDG_CACHE_HOMEif set, otherwise improperly falls back to~/.nvinstead of~/.cache. | ||
| nvidia-settings | ~/.nvidia-settings-rc | [256] | nvidia-settings --config="$XDG_CONFIG_HOME"/nvidia/settings | |
| nvm | ~/.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"$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  | ||
| omnisharp-roslyn-binAUR | ~/.omnisharp/ | [257] | [258] | export OMNISHARPHOME="$XDG_CONFIG_HOME/omnisharp" | 
| openscad | ~/.OpenSCAD | 7c3077b0f | [259] | Does not fully honour XDG Base Directory Specification, see [260] Currently it hard-codes  | 
| packettracerAUR | ~/.packettracer,~/pt | Has GUI config to change PT installation directory, ~/pt/(Options > Preferences > Administrative > User Folder). This path is written to the file~/.packettracer.Log files may still be written to  | ||
| parallel | ~/.parallel | 20170422 | export PARALLEL_HOME="$XDG_CONFIG_HOME"/parallel | |
| pass | ~/.password-store | export PASSWORD_STORE_DIR="$XDG_DATA_HOME"/pass | ||
| Phive | ~/.phive | [261] | Since 0.14.5, it is possible to move the whole data directory. 
 | |
| Pidgin | ~/.purple | [264] | pidgin --config="$XDG_DATA_HOME"/purple | |
| platformio-core | ~/.platformio | [265] | export PLATFORMIO_CORE_DIR="$XDG_DATA_HOME"/platformio | |
| PostgreSQL | ~/.psqlrc,~/.psql_history,~/.pgpass,~/.pg_service.conf | 9.2 | [266] [267] | 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:  | 
| PulseAudio | ~/.esd_auth | Very likely generated by the module-esound-protocol-unix.somodule.  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.paor"$XDG_CONFIG_HOME"/pulse/default.pa. | ||
| pyenv | ~/.pyenv | [268] [269] | export PYENV_ROOT=$XDG_DATA_HOME/pyenv | |
| azure-cli | ~/.azure | export AZURE_CONFIG_DIR=$XDG_DATA_HOME/azure | ||
| python | ~/.python_history | v3.13 | [270] [271] [272] | All history from interactive sessions is saved to ~/.python_historyby default since version 3.4 andPYTHON_HISTORYsince 3.13. For the history file, Python will not create any missing directories and only writes to the file if its directory exists. 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_HISTORY:  | 
| python-gripAUR | ~/.grip | export GRIPHOME="$XDG_CONFIG_HOME/grip" | ||
| python-kivy | ~/.kivy | export KIVY_HOME="$XDG_DATA_HOME/kivy" | ||
| python-setuptools | ~/.python-eggs | export PYTHON_EGG_CACHE="$XDG_CACHE_HOME"/python-eggs | ||
| racket | ~/.racketrc,~/.racket | [273] | export PLTUSERHOME="$XDG_DATA_HOME"/racket | |
| rbenv | ~/.rbenv | [274] [275] | 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 | [276] | export RIPGREP_CONFIG_PATH=$XDG_CONFIG_HOME/ripgrep/config | ||
| rlwrap | ~/.*_history | [277] | export RLWRAP_HOME="$XDG_DATA_HOME"/rlwrap | |
| ruby-bundler | ~/.bundle | 4a120d8 | Pull request 3545 | export BUNDLE_USER_CACHE=$XDG_CACHE_HOME/bundle export BUNDLE_USER_CONFIG=$XDG_CONFIG_HOME/bundle/config export BUNDLE_USER_PLUGIN=$XDG_DATA_HOME/bundle For more info see Bundler: bundle config. | 
| ruby-solargraphAUR | ~/.solargraph/cache/ | [278] | export SOLARGRAPH_CACHE=$XDG_CACHE_HOME/solargraph | |
| ruff | .ruff_cache | [279] | export RUFF_CACHE_DIR=$XDG_CACHE_HOME/ruff | |
| Rust#Rustup | ~/.rustup | [280] | export RUSTUP_HOME="$XDG_DATA_HOME"/rustup | |
| sbt | ~/.sbt
 | [281] | sbt -ivy "$XDG_DATA_HOME"/ivy2 -sbt-dir "$XDG_DATA_HOME"/sbt(beware [282]) | |
| SageMath | ~/.sage | export DOT_SAGE="$XDG_CONFIG_HOME"/sage | ||
| GNU Screen | ~/.screenrc
 | export SCREENRC="$XDG_CONFIG_HOME"/screen/screenrc,export SCREENDIR="${XDG_RUNTIME_DIR}/screen" | ||
| simplescreenrecorderAUR | ~/.ssr/ | 0.4.3 | [283] | Will use $XDG_CONFIG_HOME/simplescreenrecorder/ONLY if it already was created otherwise defaults to~/.ssr
 | 
| singularity-ceAUR | ~/.singularity | 3.11.4 | export SINGULARITY_CONFIGDIR="$XDG_CONFIG_HOME/singularity",export SINGULARITY_CACHEDIR="$XDG_CACHE_HOME/singularity" | |
| spacemacs | ~/.spacemacs,~/.spacemacs.d | [285] | [286] | Move the ~/.spacemacsfile.
 Other files need to be configured like Emacs. | 
| SQLite | ~/.sqliterc,~/.sqlite_history | 3.44.0 for the config; history is still in the legacy place | XDG_CONFIG_HOME/sqlite3/sqliterc,export SQLITE_HISTORY=$XDG_STATE_HOME/sqlite_history | |
| starship | ~/.config/starship,~/.cache/starship | [287] (v0.2.0), [288] (v0.45.0) | [289] | export STARSHIP_CONFIG="$XDG_CONFIG_HOME"/starship.toml,export STARSHIP_CACHE="$XDG_CACHE_HOME"/starship | 
| subversion | ~/.subversion | [290] [291][292] | alias svn="svn --config-dir \"$XDG_CONFIG_HOME\"/subversion" | |
| sudo | ~/.sudo_as_admin_successful | 1.9.6 | [293] [294] | 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 [295][296]) | ||
| 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 .tiptoprcfile.
 | ||
| ruby-travisAUR | ~/.travis/ | [297] | 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 | [298] | export VAGRANT_HOME="$XDG_DATA_HOME"/vagrant,export VAGRANT_ALIAS_FILE="$XDG_DATA_HOME"/vagrant/aliases | |
| vint | ~/.vintrc.yaml,.vintrc.yml,.vintrc | 0f741ac2c | [299] | Undocumented, but the code says $XDG_CONFIG_HOME/.vintrc.yamlshould work | 
| virtualenv | ~/.virtualenvs | export WORKON_HOME="$XDG_DATA_HOME/virtualenvs" | ||
| Visual Studio Code | ~/.vscode-oss/ | [300] | 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  You can also run Visual Studio with the  | |
| VSCodiumAUR | ~/.vscode-oss/ | [301] [302] | You can run VSCodium with the --extensions-dirflag, such asvscodium --extensions-dir "$XDG_DATA_HOME/vscode". This however won't prevent the creation of~/.vscode-oss/directory. | |
| w3m | ~/.w3m | 26284ff | [303] [304] | 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 
 | ||
| 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 thehsts-filevariable 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 | [305] | Winetricks uses XDG-alike location below for WINEPREFIX management: 
 | |
| x3270AUR | ~/.x3270pro,~/.c3270pro | export X3270PRO="$XDG_CONFIG_HOME"/x3270/config,export C3270PRO="$XDG_CONFIG_HOME"/c3270/configApp also creates  | ||
| xbindkeys | ~/.xbindkeysrc | xbindkeys -f "$XDG_CONFIG_HOME"/xbindkeys/config | ||
| xorg-xauth | ~/.Xauthority | export XAUTHORITY="$XDG_RUNTIME_DIR"/XauthorityNote 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 [306] SLiM has  The SDDM Xauthority path can be changed in its own configuration files as shown below. Unfortunately, it is relative to the home directory. /etc/sddm.conf.d/xauth-path.conf [X11] UserAuthFile=.Xauthority 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 | [307] | export XINITRC="$XDG_CONFIG_HOME"/X11/xinitrc,export XSERVERRC="$XDG_CONFIG_HOME"/X11/xserverrc | |
| xorg-xrdb | ~/.Xresources,~/.Xdefaults | Ultimately you should be using Xresourcesand since these resources are loaded viaxrdbyou can specify a path such asxrdb -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  # xsession start script USERXSESSION="$XDG_CACHE_HOME/X11/xsession" USERXSESSIONRC="$XDG_CACHE_HOME/X11/xsessionrc" ALTUSERXSESSION="$XDG_CACHE_HOME/X11/Xsession" ERRFILE="$XDG_CACHE_HOME/X11/xsession-errors" Unlike most other examples in this table, actual X11 init scripts will vary a lot between installations. | ||
| z | ~/.z | [308] | export _Z_DATA="$XDG_DATA_HOME/z" | |
| yarn | ~/.yarnrc,~/.yarn/,~/.yarncache/,~/.yarn-config/ | 2d454b5 | [309] [310] | alias yarn='yarn --use-yarnrc "$XDG_CONFIG_HOME/yarn/config"' | 
| zsh | ~/.zshrc,~/.zprofile,~/.zshenv,~/.zlogin,~/.zlogout,~/.histfile,~/.zcompdump,~/.zcompcache | [311] | [312] | export ZDOTDIR=$HOME/.config/zshto avoid the need of most zsh dotfiles in your home."$XDG_CONFIG_HOME"/zsh/.zshrc # Use XDG dirs for completion and history files [ -d "$XDG_STATE_HOME"/zsh ] || mkdir -p "$XDG_STATE_HOME"/zsh HISTFILE="$XDG_STATE_HOME"/zsh/history [ -d "$XDG_CACHE_HOME"/zsh ] || mkdir -p "$XDG_CACHE_HOME"/zsh zstyle ':completion:*' cache-path "$XDG_CACHE_HOME"/zsh/zcompcache compinit -d "$XDG_CACHE_HOME"/zsh/zcompdump-$ZSH_VERSION Finally, if you use zsh as a login shell and chose to rely on either of the startup files  | 
Hardcoded
| Application | Legacy Path | Discussion | Notes | 
|---|---|---|---|
| adb & Android Studio | ~/.android/ | Despite appearances otherwise, adb will always generate ~/.android/adbkeys, though it will try keys inADB_VENDOR_KEYSas well. | |
| aegisub | ~/.aegisub/ | [313] | |
| 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  | |
| aMule | ~/.aMule | [314] [315] [316] | |
| anthy | ~/.anthy | [317] | |
| Apache Directory Studio | ~/.ApacheDirectoryStudio | ||
| ARandR | ~/.screenlayout | [318] | |
| Arduino | ~/.arduino15,~/.jssc | won't fix | |
| arduino-cli | ~/.arduino15/ | [319] | mv ~/.arduino15 $XDG_CONFIG_HOME/arduino15Specify the new directories used by Arduino CLI in arduino-cli.yaml as mentioned in the documentation here.
 | 
| ASP.NET Core | ~/.aspnet | [320] | |
| Avidemux | ~/.avidemux6 | [321] | |
| azote | ~/.azotebg | [322] | |
| Bash | ~/.bashrc,~/.bash_history,~/.bash_profile,~/.bash_login,~/.bash_logout | [323] [324] | mkdir -p "$XDG_STATE_HOME"/bash
 
 | 
| Barony | ~/.barony | [325] | |
| Berkshelf | ~/.berkshelf/ | ||
| celestiaAUR | ~/.celestiarc | ||
| chatty | ~/.chatty/ | [326] | |
| cmake | ~/.cmake/ | [327] | 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 | [328] | [329] | 
| Cinnamon | ~/.cinnamon/ | [330] | |
| conanAUR | ~/.conan/ | [331] | 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 | [332] | |
| cVim[dead link 2022-09-23 ⓘ] | ~/.cvimrc | [333] | |
| darcs | ~/.darcs/ | [334] | |
| dart | ~/.dart,~/.dart-tool,~/.dartServer | [335] | |
| dbus | ~/.dbus/ | [336] | 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 | [337] | |
| dropbox | ~/.dropbox/ | [338] | |
| Eclipse | ~/.eclipse/ | [339] | 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_HOMEin/usr/bin/eclipse) | 
| emacs-slime | ~/.slime/ | [340] | |
| equalxAUR | ~/.equalx/ | [342] | |
| feh | ~/.fehbg | [343] | |
| Fetchmail | ~/.fetchmailrc | ||
| Firefox | ~/.mozilla/ | [344] [345] | |
| Flatpak | ~/.var/ | [346] [347] won't fix | |
| freesweep | ~/.sweeprc | [348] | |
| gftpAUR | ~/.gftp/ | [349] | Following the XDG spec is planned for gftp. | 
| gitkrakenAUR | ~/.gitkraken/ | [350] | |
| GoldenDict | ~/.goldendict/ | [351] | |
| gphoto2 | ~/.gphoto | [352] | |
| gramps | ~/.gramps/ | [353] | 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/ | [354] | |
| google-cloud-cliAUR | ~/.gsutil/ | [355] | |
| gtk-recordMyDesktop | ~/.gtk-recordmydesktop | ||
| hplip | ~/.hplip/ | [356] | |
| hydrogen | ~/.hydrogen/ | [357] | |
| idris | ~/.idris | [358] | |
| itch-setup-binAUR | ~/.itch | won't fix | You can move the Game install location in the app settings. | 
| Jmol | ~/.jmol/ | [359] | |
| lbdbAUR | ~/.lbdbrc, ~/.lbdb/ | [360] | |
| llpp | ~/.config/llpp.conf | [361][dead link 2022-09-23 ⓘ] (repo was deleted) | Added in 3ab86f0 but subsequently reverted in old:e253c9f1/new:e253c9f1 | 
| Java OpenJDK | ~/.java/fonts | [362] | export _JAVA_OPTIONS=-Djava.util.prefs.userRoot="$XDG_CONFIG_HOME"/java | 
| Java OpenJFX | ~/.java/webview | ||
| jgmenu | ~/.jgmenu-lockfile | [363] [364] | |
| jitsi-meetAUR | ~/Downloads | libjitsi#518 | Download dir hardcoded to ~/Downloadsrather thanXDG_DOWNLOAD_DIR(from XDG user directories) | 
| julia | ~/.juliarc.jl,~/.julia_history,~/.julia | [365] [366] | The trailing :$JULIA_DEPOT_PATHis necessary. See [367]export JULIA_DEPOT_PATH="$XDG_DATA_HOME/julia:$JULIA_DEPOT_PATH" export JULIAUP_DEPOT_PATH="$XDG_DATA_HOME/julia" | 
| kotlin | ~/.kotlinc_history | Related Konan issue: [368] | |
| Kubernetes | ~/.kube/ | [369][370][371] | export KUBECONFIG="$XDG_CONFIG_HOME/kube" export KUBECACHEDIR="$XDG_CACHE_HOME/kube" | 
| elan-leanAUR | ~/.elan | [372] | |
| librewolfAUR | ~/.mozilla
 | [373] | |
| lldb | ~/.lldb,~/.lldbinit,~/.lldb/lldb-widehistory | [374] | |
| LMMS | ~/.lmmsrc.xml | [375] | |
| maliit-keyboard | ~/.presage | Maliit Keyboard uses an old, unmaintained library called Presage that creates ~/.presage. In 2024, Maliit Keyboard dropped their Presage dependency but as of version 2.3.1, this has not yet been included in a release. In the meantime, compile the master branch of maliit-keyboard. | |
| man-db | ~/.manpath | [376] | |
| mathomatic[dead link 2024-10-12 ⓘ] | ~/.mathomaticrc,~/.matho_history | History can be moved by using rlwrap mathomatic -rwith theRLWRAP_HOMEenvironment set appropriately. | |
| MediaWiki | ~/.mweval_historyand~/.mwsql_history(if $HOME is defined) | If $HOME is not defined: [MediaWiki]/maintenance/.mweval_historyand[MediaWiki]/maintenance/.mwsql_history. | |
| megacmdAUR | ~/.megaCmd/ | [377] | |
| Minecraft | ~/.minecraft/ | won't fix | |
| minicom | ~/.minirc.dfl | Upstream has a TODO entry for supporting configuration files under ~/.config/minicom. [378] | |
| Mono | ~/.mono/ | [379] | |
| mongodb | ~/.mongorc.js,~/.dbshell | [380] | 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 | [381] | Nimble will try to load ~/.config/nimble/nimble.iniat startup, setnimbleDirthere. You will have to changenimblepathin the Nim compiler configuration file as well. | 
| Networkmanager-openvpn | ~/.cert/nm-openvpn | [383] | |
| nyx | ~/.nyx | The project is not currently maintained | |
| oh-my-bash-gitAUR | ~/.osh-update | ||
| Ollama | ~/.ollama | [384] | Model locations can be set with: 
 Source: [385] | 
| openshot | ~/.openshot_qt | [386] [387] | |
| OpenSSH | ~/.ssh | won't fix | Assumed to be present by many ssh daemons and clients such as DropBear and OpenSSH. | 
| palemoon | ~/.moonchild productions | [388] | |
| parsec-binAUR | ~/.parsec | ||
| pcsxrAUR | ~/.pcsxr | A -cfgflag exists, but can only be set relative to~/.pcsxr. | |
| perf | ~/.debug | Hardcoded in tools/perf/util/config.c. Commit: [389] | |
| perl | ~/.cpan,~/perl5 | [390] | Perl5's CPAN expects ~/.cpan | 
| phoronix-test-suiteAUR | ~/.phoronix-test-suite | [391] | Partial workaround: [392] | 
| portfolio-performance-binAUR | ~/.PortfolioPerformance/ | [393] | |
| various shells and display managers | ~/.profile | ||
| psensor | ~/.psensor | [394] | |
| pulumi | ~/.pulumi | [395] | |
| python-tensorflow | ~/.keras | [396] | The issues is for tf.kerasmodule | 
| quilt | ~/.quiltrc | Fallback to /etc/quilt.quiltrcif~/.quiltrcdoes not exist. | |
| Qt Designer | ~/.designer | [397] | |
| R | ~/.Rprofile, ~/.Rdata, ~/.Rhistory | R_HOME_USER="$HOME/.config/R" R_PROFILE_USER="$HOME/.config/R/profile" R_HISTFILE="$HOME/.config/R/history" | |
| RedNotebook | ~/.rednotebook | [398] | |
| Remarkable | ~/.remarkable | ||
| renderdoc | ~/.renderdoc | won't fix | |
| Ren'Py | ~/.renpy | won't fix | Recent versions respect RENPY_PATH_TO_SAVESenvironment variable. So you could set it to change the path for some games.export RENPY_PATH_TO_SAVES="$XDG_DATA_HOME/renpy" | 
| repo | ~/.repoconfig | [399] | |
| rpm | ~/.rpmrc~/.rpmmacros | Backlog | Workaround is to use --rcfile and --macros however this come with sideeffects. | 
| SANE | ~/.sane/ | scanimagecreates a.calfile there | |
| sbcl | ~/.sbclrc | /etc/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  | |
| SeaMonkey | ~/.mozilla/seamonkey | [400] | |
| Signal Desktop | [401] | Currently keeps messages in ~/.config/Signal | |
| Snap | ~/snap/ | [402] | |
| Solfege | ~/.solfege,~/.solfegerc,~/lessonfiles | [403] | |
| SpamAssassin | ~/.spamassassin | ||
| Steam | ~/.steam,~/.steampath,~/.steampid | [404] | 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. | 
| stellariumAUR | ~/.stellarium/ | [405] | |
| stremioAUR | ~/.stremio-server/ | [406] | |
| sts4 | ~/.sts4 | [407] | Pass JVM arg -Dlanguageserver.boot.symbolCacheDir=$XDG_CACHE_HOME/sts4/symbolCache | 
| python-streamlit | ~/.streamlit | [408] | |
| sweethome3d | ~/.eteks/sweethome3d | [409] | |
| python-sympy | ~/.sympy-history | [410] | |
| TeamSpeak | ~/.ts3client | export TS3_CONFIG_DIR="$XDG_CONFIG_HOME/ts3client" | |
| terraform | ~/.terraform.d/ | [411] | |
| texinfo | ~/.infokey | info --init-file "$XDG_CONFIG_HOME/infokey" | |
| Thunderbird | ~/.thunderbird/ | [412] | |
| tllocalmgr | ~/.texlive | ||
| urlviewAUR | ~/.urlview | Use fork urlview-xdg-gitAUR instead. The fork will use XDG_CONFIG_HOME/urlview/config | |
| viberAUR | ~/.ViberPC | ||
| vimperator | ~/.vimperatorrc | [413] | export VIMPERATOR_INIT=":source $XDG_CONFIG_HOME/vimperator/vimperatorrc"
 | 
| visidata | ~/.visidata | [414] | |
| wpa_cli | ~/.wpa_cli_history | alias wpa_cli='HOME=$XDG_STATE_HOME wpa_cli' | |
| wegoAUR | ~/.wegorc | [415] | |
| 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.iniand modifying the section[Chansrv]following the example config. | |
| XVim2 | ~/.xvimrc | [416] | |
| YARD | ~/.yard | [417] | Would accept Pull Request if anyone want to implement it. | 
| zenmap nmap | ~/.zenmap | [418] [419] | |
| 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 | [420] | ~/Zoterodefault location for data can be changed from GUI: Edit -> Preferences -> Advanced -> Data Directory Location -> Custom | 
Tools
The tool xdg-ninjaAUR detects unwanted files/directories in $HOME which can be moved to XDG base directories. See README for examples.
The tool boxxy can be used to wrap applications which do not respect the XDG base directories and redirect any unwanted files.
The tool ephemeral can be used to link chromium/electron caches that normally live in XDG_CONFIG_HOME to locations in XDG_CACHE_HOME.
Libraries
- C++
- xdg-utils-cxx
- xdgpp
- Go
- adrg/xdg
- go-appdir (deprecated, archived)
- configdir (deprecated, abandoned)
- kyoh86/xdg (deprecated, archived)
- Haskell
- Officially in directory since 1.2.3.0 ab9d0810ce.
- xdg-basedir
- JVM
- Java, Kotlin, Clojure, Scala, ...
- directories-jvm
- Perl
- File-BaseDir
- Python
- pyxdg
- appdirs (abandoned)
- platformdirs
- Ruby
- bkuhlmann/xdg
- rubyworks/xdg (deprecated, abandoned)
- Rust
- directories-rs
- rust-xdg
- Swift
- swift-xdg
- Vala
- 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
- GNOME Goal: XDG Base Directory Specification Usage
- Rob Pike: "Dotfiles" being hidden is a UNIXv2 mistake.
- systemd-path(1)
- file-hierarchy(7)
- Grawity's notes on dotfiles.
- Grawity's notes on environment variables.
- ploum.net: Modify Your Application to use XDG Folders.
- The PCGamingWiki attempts to document whether or not Linux PC games follow the XDG Base Directory Specification.