Firefox has an issue that's been open for 20 years regarding implementing the XDG Base Directory Specification.
linuxmemes
I use Arch btw
Sister communities:
- LemmyMemes: Memes
- LemmyShitpost: Anything and everything goes.
- RISA: Star Trek memes and shitposts
Community rules
- Follow the site-wide rules and code of conduct
- Be civil
- Post Linux-related content
- No recent reposts
Please report posts and comments that break these rules!
Firefox is the biggest offender for me. ~/.mozilla instead of something sane like ~/.config/firefox
Even worse, Thunderbird doesn't save data in ~/.mozilla/thunderbird, but in ~/.thunderbird.
At least Thunderbird configs are stored in ~/.config/.mozilla/thunderbird. Right? Right...?
my favourite part is Steam throwing in a symlink, a broken symlink, and a directory of 4 files and 7 more symlinks that all point to a more reasonable point in ~/.local/share/steam/
Which indirectly led to this wild as fuck bug that nuked some poor user's data.
Haha you just reminded me of that damn flashing broken steam sym link in my home folder, it's been there for years and I've yet to investigate or do anything about it.
It's there for ancient compatibility reasons and recreated when steam starts, iirc. I've looked a bit into removing it last year but didn't get far
lol that's great. Does flatpak Steam do that too? I can't see anything from Steam directly in my home directory, and I use the flatpak version.
Protect your home, use xdg ninja
Ninja can't help if the program does not want to cooperate :(
You can use a wrapper script on PATH that launches the app in a fake home wherever you want.
It's one thing when they have legacy hardcode mountains preventing a standardisation, but I really dislike developers who just disagree with the standard and take away the choice as well and justify it with some made up problems with that standard.
https://github.com/minetest/minetest/issues/864
https://bugzilla.mozilla.org/show_bug.cgi?id=735285
etc...
Archlinux Wiki even has an article about those.
https://wiki.archlinux.org/title/XDG_Base_Directory#Hardcoded
who would win?
dozens of conflicting standards on where to store files over years of poorly enforced linux development practice
vs
some symlink bois
for real tho, I discovered gnu-stow the other day and it looks like the ideal solution for this sorta stuff
vs. user choice via variable.
"Am I out of touch?
No, it is the users who are wrong!"
That's how my employer does it...
Haven't used much of Linux before, can someone explain the joke?
The Windows equivilent would be instead of putting application data in the AppData folder, it throws it in Documents, My Games, or just in the home folder directly.
ah so like every fucking game and it's save files for some reason?
Better, it could be literally anywhere and there's nothing you can do about it. Also symlinks practically look like regular folders and files to most apps.
That's why i prefer to use Wine for games. Just change the symlinks in C:/users/ to somewhere sane, like .local/Games//save. Guess you could also use the variables in .config/user-dirs.dirs while creating the prefix, but i haven't tested that yet.
... or just imagine all of it being thrown on the Desktop (the bare user directory is rarely visited in Windows)
Hahahaha oh man I know exactly what you're talking about too 😭 hate when they do that
Most software on Linux is configured to place their config files in ~/.config. Some others, like the ones in the pic, just dump them directly into your home folder.
Yes.
Many applications have configuration files. Historically these files were placed in your home directory aka "on the floor". The variable mentioned defines a directory where these files should go. Many applications ignore this.
A non-linux version of this meme might go,
"Here is the pizza you ordered"
"Great, could you put it in my hands"
"Lol (throws pizza on floor)"
$XDG_CONFIG_HOME is an environment variable that programs can (and should) read to determine the location for storing dotfiles (config files, kind of). Not reading (or caring about) the environment variable, and not adhering to the default of /home/username/.config/ results in them ending up in the home directory.
Meanwhile kde scattering everything in .config/
If plasma could put all their damn files inside a "plasma" folder that'd be great too.
In theory this issue can be solved with LD_PRELOAD trick. E.g. redirect all/most/some fopen
calls to "$HOME" to some other directory. But before I try to tackle it myself: is there already a similar solution like that?
I love you all very much but just please be aware that "the floor" is literally where the files are supposed to go, according to the spec. I don't like it, you don't like it, nobody likes it. But that's why it's happening.
Relevant section quoted for the lazy:
User specific configuration files for applications are stored in the user's home directory in a file that starts with the '.' character (a "dot file"). If an application needs to create more than one dot file then they should be placed in a subdirectory with a name starting with a '.' character, (a "dot directory"). In this case the configuration files should not start with the '.' character.
You know everything on that site was written in 2004 or earlier, right? That hasn't been the relevant spec for a long, long time now. We use xdg for that now. Configs go in xdg_config_home.
i understand the linux side of the joke but can someone explain what this meme format means? /gen
is this pizza guy known for chucking pizzas?
They probably just found an image of a pizza delivery guy and fitted it for the meme. I am not aware of any memes of pizza throwers other than Walter White
i am the one who yeets
Set your config directory to be your home directory and outplay those apps