My .config Ship of Theseus(shift1w.com) |
My .config Ship of Theseus(shift1w.com) |
but why not awk then?
With very few exceptions I just stick with the defaults and it works for me.
I also had other workmates who did everything in some exotic shell, so of course none of their one-liners worked in bash.
It keeps my machines uniform enough without too much hassle.
The app ‘Conductor’ does this, and I had to uninstall it; I just can’t crack my ‘ls ~/.co<TAB>’ habit, and “nd” is juuuuuust ahead of “nf”.
It *used to* be ‘~/c<TAB>’ before .claude crapped itself into existence..
I also suggest you try xdg-ninja, which automatically scans your home directory and shows which of those directories you can change to a different location:
https://github.com/b3nj5m1n/xdg-ninja
I have a big shell config file that sets proper locations for all sort of programs I use:
https://github.com/flexagoon/dotfiles/blob/main/dot_config/f...
On my Mac, there are 94 items in my home directory. 10 of them are expected, coming from either the user template or from single user installations of applications.
Two of the additions are not hidden: go and quicklisp. I don't actually mind this. Hidden folders are stupid if I am expected to be navigating into them either in the GUI or in the CLI. Slightly annoying since there's a perfectly good Library folder they could have dumped themselves in instead but whatever. At least I can see them without unhiding hidden files.
The rest? The other EIGHTY FUCKING TWO items in "my home"?? Hidden dot file BULLSHIT.
11 for Zsh related bullshit. Eleven! Are you fucking serious?
.wget-hsts? What the fuck is even that? Fuck off!
What absolute slop! What an incredibly stupid and shitty way to create caches and configurations. Braindead. I feel like im taking crazy pills. I'm gobsmacked that every time I look into "can I move this dogshit" I find a GitHub issue where the devs seem taken aback and confused "why would you want to do that". Eat shit! What do you mean the plaintext json files we put your config into and never built a GUI for should go into a folder you can see and navigate too easily? Whaaaat?? What do you mean "$XDG_CONFIG" exists? Hmmm no, checking for that would take 5 lines of code so no. Also, assholes, macOS doesn't canonically use goddamn XDG environment variables. Just because it uses a terminal you recognize doesn't mean it's fucking Linux! Take your .config and .cache and .local shite out of here.
And I've tried to fight it, but eventually you give up. It's a losing battle against tasteless patterns and asshole, careless developers. 150 something versions of Firefox and only recently could you move .mozilla. OpenSSH will never not pollute your home directory, they said so!
My desktop is now my home directory. It's mine. My terminal starts up there. Folders of stuff I actually give a fuck about go there. My browsers download into ~/Desktop/Downloads. I'm done fighting. My home was trashed. Crimes occurred. So I moved.
God I fucking hate dotfiles.
EDIT: Oh yeah, my favorite part is that on macOS, the Desktop folder is protected by TCC, so I can easily tell if some background app or something is trying to access it and deny it right then and there. It's a far safer place to keep things like AWS keys and secrets and my SSH keys, but NNoOOoOoOOoO that goes in my home folder that has nothing but POSIX file system level permissions. But don't worry, it's hidden by default! No one will know its there! At least the AWS cli lets you point somewhere else but that comes with a bunch of extra friction.
Apps require full disk access to read my Safari cookie jar database, but they can grab my SSH keys without any issue. Great system we got here! .stupid .bozo .bullshit
The only place I've encountered where they are visible by default and do get in the way is bash filename completion, and you can change this via the readline config file:
# ~/.inputrc:
set match-hidden-files offif only people knew about, read (and followed) xdg... aka freedesktop.org
First: you can template stuff easily. Like having config that have different parameters (say a display name to display stuff on) between devices.
Second: You can do "the everything else" of the machine setup, not just configs but also installed apps and various quirks and tweaks.
I think it can also do rudimentary app management via storing a lockfile, but I haven’t tried that out.
https://github.com/podiki/dot.me (nonguix maintainer) https://codeberg.org/hako/Testament (guix and nonguix maintainer) https://codeberg.org/cmargiotta/dotfiles (good gaming stuff) https://codeberg.org/daviwil/dotfiles/src/branch/guix-home (I modeled off this) https://gitlab.com/pjotrp/guix-notes
... but of course some apps must be super special flowers that need their own dir
0: https://ia800708.us.archive.org/25/items/pdfy-MgN0H1joIoDVoI...
I see them when I have to show unhidden files to find some massively bloated folder taking up space or go and manually modify any of the files in those hidden folders, which is quite often! Is it not unexpected to want to navigate to my configuration files? Why is .config hidden? Why not just put it in a folder called "Appropriate-Synonym-For-Stuff-You-Are-Unlikely-To-Want-To-See-Daily/config" I get you're trying to be helpful, but I know that I can hide them and they are hidden by default. The problem is not seeing them. It's that there are 94 top level items in "my" home directory and I'd rather there not be, and yet, I am doomed to suffer this, and I can't most of it because most apps do a piss-poor job of following XDG basedir standards or incorrectly apply them to platforms where they are absolutely not a valid or even sensible specification, and just lazily hardcode their code to pile shit into $HOME/.fucking_garbage.
It is a beyond stupid convention that a . automatically hides a file or folder. It is my computer. Files should always be visible in the GUI or in the terminal. If they should not be for convenience, then that is enough of a "type" or "classification" of a file to group them all together and collapse all that clutter into a folder that is still visible, and easily browsable without switching modes in my graphical file browser or having to add extra flags to commands and what not. Otherwise, the only person who should be hiding anything on my computer is me, via a file system flag (chflags first appeared in BSD 4.4, non-existent on Linux) or manually in the file manager GUI.
If anything, it's the reason this is such a common issue, the dot lets everyone shit files out all over the place but oh it's hidden so no big deal.
None of that shit should live in .local. I have a "local" already, it's called ~/Library. There's a Caches folder in there. Also a Preferences folder.
At the very least why make local a dot-folder? Why add the extra keystroke? Local? Local to what?! Of course it's "local" it's my fucking home folder, everything in it is "local" to me. It's redundant. It just further supports that the convention is stupid.
Even when I'm on my Linux computers, where it is at least a half-assed convention, I still hate this crap. The XDG directories and hierarchy are bad and dumb. None of them should be "dot" anything. Hiding clutter under a dot is like hiding clutter in your house under a rug. It's not organization, you just have a big mess you don't have to look at but you have to step around all the time. NeXT solved this shit 30+ years ago and they cleaned it up 25 years ago. You put it in a box (~/Library) with a clean label of a proper noun (Preferences, Caches, Keychains, Extensions, etc) that identifies it, stow it somewhere out of the way but accessible, so you can find it when you need it but otherwise not have to look at it. 84 little dot folders could all be swept out of sight by moving them into the Library, one single folder in my home, but instead, they just sit under a big dot rug in the middle of it.
Apple does commit one sin here and that is hiding the user Library folder by default, but that is part of making computers work for mere mortals as dumb users will go and delete their Library folder to save space and break shit, but that uses a proper file system flag not this crappy convention from half a century ago that breaks sorting.
All that said, I do agree that at the very least Linux apps should be following $XDG_CONFIG and only if unset, pollute the home folder. It's a fucking if-then-else. No excuse. I shouldn't be seeing shit like ".arduinoIDE" or ".claude" Claude should be able to add this feature on its own anyways.
XDG has nothing to do with X11. XDG stands for "Cross-Desktop Group," and is designed specifically for any Unix or Unix-like operating system, which includes macOS.
you can point them to %APPDATA%..., ~/Library or the Linux defaults.
my point in this is: there are free and open conventions and we wouldn't need this "my HOME is cluttered" fuss, if technical teams would embrace them.
so why don't they respect XDG_ env vars for their config and data?
The need for cross platform openness? Did anyone at FDO ask Apple or Microsoft if they wanted to comment or make suggestions on the basedir spec? Did FDO look at either of the platforms' existing specifications and see if there were any ideas they could copy? Or did they just do a Linux-oid thing, disregarding norms and specifications that exist already on the other platforms they didn't invite to the party, and force some weird thing onto those platforms under the assumption that it was good because its open and cross platform.
My complaints come from two things.
1. On my Linux computers, I am inundated by bad applications that do not follow the conventions set out by XDG for basedir. The one good thing basedir lets me do is set my own goddamn directories that aren't dot-file trash, but I still can't depend on it being followed or respected. On this, we seem to agree. But I think the defaults from basedir are terrible and dot-files in general are terrible stupid things, hence the rant.
2. On my Windows and Mac computers, there is no reason for XDG envvars to be set because they do not purport to follow XDG basedir specifications. Thus, even though I could set an envvar for XDG_CONFIG and so on, they are more often ignored by crappy developers. However, I am still highly annoyed by now having at least two places where all of this crap might be, because even if an app developer follows XDG, it is up to me to force them to follow the platforms conventions. All of the basedir directories already have better analogue on macOS, it's ~/Library. Why shouldn't it be on the developer to do a simple `if macOS then put config data in ~/Library/Application Support/APPNAME and caches into ~/Library/Caches/APP_NAME` as is expected and typical on the Mac? Especially since there are no easy ways to set envvars for GUI applications on the Mac, what, am I supposed to make my own shortcuts for everything to set 5 XDG_BLANK envvars to launch an app instead of double-clicking an app bundle?
That said, you are correct that it has nothing to do with Windows (and I never said that it did).
FDO applies to Linux and "Unix-Like" Operating Systems. macOS is not "UNIX-like", Apple still bothers to get it certified under UNIX 2003 so it is technically not a Unix-like. Again, just because it has a /usr folder and a /var folder and can run a bash shell out of the box doesn't mean all the same mostly just OK standards from Linux should be copy-pasted over.