- cross-posted to:
- programmerhumor@lemmy.ml
“Hey Linux, can you just delete this file please?”
“Sure thing bud, a program is using it, it’s ok, I will just unlink the inode anyway, the program can still access it until it closes the file”
This is honestly one of my favorite features of the linux filesystem. As a dev it makes things like replacing and hot-reloading plugins way easier.
It turns out you can kind of get the same functionality on Windows if you rename the open file and place the new one with the original name, but it’s a bit of a hack.
Windows won’t let you rename a file that’s being used either.
Yeah, super annoying. In Linux you can rename or move it and the app using it doesn’t care.
Although having the option of listing the app using a file so I can kill the app would also be really nice to have. I’m sure Linux has something for that too, but I don’t know what it is.
I’m sure Linux has something for that too, but I don’t know what it is
fuser
I can’t remember the other program that’ll do it.
But there’s another one that’ll list all the processes using a file.
Tip of my tongue fuck.
lsof | grep <filename>
That’s the one
You can use PowerToys on windows to see what app is using a particular file
That’s actually a thing, but I’m not entirely sure in which cases. Probably only for services and not apps, but I’ve done that myself where deleting a file was impossible, but renaming it and deleting it worked.
Maybe it’s only possible in certain cases, but I can tell you for certain it’s possible with running exe’s and loaded dll’s. I have a CMake step on Windows that does this rename hack so my builds don’t fail if I still have the app running.
It turns out you can kind of get the same functionality on Windows if you rename the open file and place the new one with the original name, but it’s a bit of a hack.
Only if you don’t have OneDrive working. In that case, you have to wait for it to sync or it won’t go through.
Anytime I have an issue at work where I can’t change or delete a file, it’s a 50/50 split between Excel and OneDrive being the cause
the mpv player does that too for the cache folder. It’s configurable and documented
Hmm. So are the blocks freed up for overwriting on file close, then?
Yes. On Linux/Unix you don’t delete the file, you just delete it’s name, which is merely a link to the actual file. That’s also the reason why the syscalls name is actually
unlink
and notdelete
. As soon as there’s nothing pointing to a file anymore, it is deleted.As long as a process holds a file handle, there’s still a reference to said file, so it won’t be deleted. That saved me once, when I accidentally deleted a file I wanted to keep: As there still was some process keeping it alive, I could just go to
/proc/[process id]/fd/[file descriptor id]
and copy it to a safe location.Good to know, and helps me understand code dealing with filesystems a little better. I’m curious how the kernel keeps track of it all, just a counter maybe?
On Linux/Unix you don’t delete the file, you just delete it’s name, which is merely a link to the actual file.
Is that different on other systems?
I don’t know how NTFS does it, but on FAT filesystems the directory table contains the filename along with all the other file metadata (access rights, creation date, size, etc). Only the list of sectors containing the actual data is separate. That means that you can’t have two filenames for the same file on FAT filesystems.
If you want to learn more about this, the data structure UNIX filesystems use, and FAT filesystems lack is called inode.
In case anyone is interested, there’s a powertoy called file locksmith that will show what’s using it and let you kill it: https://learn.microsoft.com/en-us/windows/powertoys/file-locksmith
“Time to see who’s stopping me from deleting this file… svchost??? Goddamn it!”
just kill it
Instructions unclear, I shot my gaming rig with a 6 bore shotgun…. And then set it on fire.
Instructions may have been unclear, but you got the gist of it.
Hole-y and on fire:
“This program is preventing Windows from shutting down:”
He’s a little confused, but he’s got the spirit.
I used to, all the time
This was in the XP days so I didn’t know how to figure out which service it was, I was a kid. But some svchost process would manifest as a task to switch to in the alt + tab switcher and made the computer slow and weird. I just killed it. No idea if it was a bug or a virus.
Probably the indexing service, it’s always the indexing service.
Well, it could be an executable disguising itself as svchost. Pretty common for malware or video game cheats to name their executables svchost.exe to hide from anti-virus/anticheat
I’m in this picture and I don’t like it. I was trying to diagnose a prod server crashing this very Wednesday and seeing the lines of svchost.exe is so fucking maddening… I’m glad ProcessExplorer was there to give some useful fucking info, at least.
Powertoys seems to be the only thing keeping windows somewhat usable, I have no idea why they don’t include it in the build.
I discovered powertoys only recently, and it’s a pretty cool set of tools. From color picker, tiling window manager to regex file renames or copy/paste tools, it has a lot of QoL features.
If you have to be on windows, i.e due ro work, I recommend not sleeping on it.
The performance view thing that comes with windows also allows searching for file handles but it’s not very user friendly. Also not possible without admin rights if I remember correctly
Why isn’t this in their OS instead of unwanted AI
Now the question is if I can install it on my work computer without IT getting pissy
You can use the built-in tool resmon.exe to do the same
Sysinternals handle is lightweight unitasker for this too, better option for servers.
TBF the task manager and those windows explorer dialogues were programed in like 1996 and it’s probably one of the best functioning feature in Windows so changing it too much carries high risks.
changing it too much carries high risks
This is such a Windows way of thinking. Why does every other OS constantly change and evolve but Windows is like “can’t touch this code from a quarter century ago?”
Becuase it’s still integral to countless businesses operations.
I don’t see the problem with it. Microsoft historically does a great job of making everything worse with updates.
Because any time anything changes in Windows, people bitch about it.
I dare say, that 90% of all companies in Europe and US, use Windows. And lots of companies relies heavily on software built 20-30 years ago. Microsoft knows this.
That’s why they are very reluctant to “touch that piece of code from a quarter century ago” because there’s probably a lot of software that would break without it. Software their target audience need.
You ever worked in like a real job? Have you ever seen the amount of legacy code that depends on some other legacy piece of shit which itself depends on…?
It’s absolutely maddening, being there, diagnosing the issue and absolutely having no way to do anything about it because no time, not allowed, no need if it ain’t broken, our customers rely on this specific version, etc.It’s not a Windows way of thinking, it’s what every single one of the businesses I’ve worked with for the last twenty or so years think like. And changing shit is incredibly expensive.
It just hasn’t been my experience at all as a developer. I’m sorry you’ve been forced to keep legacy code around for the sake of not breaking things.
Lol yea, but it would have been such a small tweak with big big QoL improvements LMAO
You can use process explorer, it even has option to act as a replacement for task manager.
Edit: https://learn.microsoft.com/en-us/sysinternals/downloads/process-explorer
There is nothing in windows that’s a small tweak.
Changing anything has implications to a banking business Joe somewhere, who’s program depends on the original feature working as it does, or one of the 16 layers of code is simply tangled in a way such change would require cascade of rewrites.I’ve read articles about various developments: working with
regexregistry*, or just adding a control panel option, and it’s an absolute nightmare.Bring back spacebar heating!
On my Windows 10 laptop, Task Manager virtually freezes the whole system for about four seconds when you switch tabs.
Well the only Windows 10 system still receiving support is Windows 10 Enterprise LTSC, afaik, and I have one which does not have that particular problems. Are you properly scheduling updates so that it doesn’t run automatically?
It’s a pretty old issue (and you can find others complaining online over the years) and my current machine is running Gentoo Linux, so I’m not trying to fix it any more.
The current UI is very different to the original UI though.
Yeah I think they changed how it looks starting in Windows 8.
back in the XP days, I used a software called “Unlocker” just for this problem. It probably still exists, I don’t know, because since Windows 7, the easiest way to find out what process locks a file is to open Resource Monitor (Start search: resmon) and on the CPU tab, using the “Associated handles” list, you can search for the file name and see the process in question (and kill it).
So yeah, Resource Monitor is a useful tool on Windows.
There’s a collection of free little utilities called Microsoft PowerToys, including the file unlocker thing. Why would they not include these into base kit Windows is beyond me.
not including PowerToys inside basic package is a fucking choice. Win11 is literally unusable without it in many aspects.
I would argue windows 11 is pretty much unusable regardless
LTSC is probably usable but if the base is so broken - i wonder if LTSC is still as good as Win10 LTSC.
It works you just have to launch outlook 3 times for it to take.
I suspect it’s in line with big tech policies to coddle end users instead of educating or trusting them. I assert (particularly since the introduction of the iPhone in 2007) that learned helplessness is built into the game plan.
100%! Like with major setups and upgrades now just being throbbing circles and a pulsing blue light with the creepy “We’re doing stuff on your behalf behind this screen.” messaging.
I say computers (and the Internet) are for anybody, but not everybody. Learning to use a tool will always be a requirement of useful tools.
There used to be a time when most people using a computer implicitly understood how files and folders worked, for instance. But now even such a simple abstraction is considered advanced esoteric lost arcana.
I’m deeply saddened by how the tech industry has deliberately pushed understanding backwards so hard in order to foster more obedient consumers.
It’s actually wild to see how many people who were at the very least, young adults during the computer boom of the late 80’s/early 90’s, can’t handle anything without a touch screen and don’t comprehend email.
Ignorance is sold as the future.
My dad used to say Apple is evil exactly because of that - they make stuff for people who want fancy shit but have little to no interest in actual tech.
Sysinternals is also a great tool. Not as vital for the average user though.
gotta check it out. thanks for the tip
Why would they not include these into base kit Windows is beyond me.
Some of them felt a bit buggy when I last time used Windows, maybe they aren’t fully ready to ship (like Samsung’s Good Lock apps?). And most features didn’t do quite what I imagined it to do, but that’s probably a “me problem”.
That’s a fair point, but, let’s be honest, the built in Windows features often have the same issues
Not recently copilot and AI implementation has made the OS beyond shitty recently and a lot of broken shit. That’s why I need to move to Linux they’re basically sinking their ship with broken AI code.
The telemetry is overbearing too lately.
Bill Gates secret hotline.
probably.
I feel like it’s a testing ground for new features for them, but not sure why some aren’t yet integrated. Best guess: the PowerToys team has less red tape and checks to go through than the Windows team to allow for faster iteration, but that means that integrating the features wouldn’t be just the click of a button since they’d have to adapt it to fit the Windows style. But this is just a wild guess.
I think you’re right on the money. There seems to be a component of enticing power users to stick with Windows as well. The app is still “in beta” despite the first release being in 1996 (!). I had to look that up, because I’d only heard about it in the early windows 10 days.
The first version of PowerToys was released for Windows 95 on 17 November, 1996 as a download on Microsoft’s FTP server at the time.
Well wadaya knows?
I like that it wasn’t a proper installed thing, just a bunch of executables in a zip file.
Because they want to include things with ads now - i.e. the ad-supported Outlook in the place of Mail.
The bugs and horribly slow hardware that caused the locks in NT/XP have slowly disappeared, by win 10, I rarely had any files I couldn’t delete if I, worst case, made explorer reload. It used to happent o be every other day in the late 90s
What gets me is when I’m not allowed to remove an external drive. Deleting a file can be delayed until later but here I am with a physical object that I need to detach from my computer and first I need to play hide and seek with the OS.
If this happens often, you can disable write caching for that drive. It’ll feel slightly slower (since it’s actually operating at the speed of the hardware instead of caching operations in RAM and gradually writing them to disk in the background), but you’ll be able to remove the drive almost instantly.
I used to find it had something to do with the explorer thumbnailer finishing up but sort of not letting go. It would happen if I had pictures or videos on the USB drive, and if I got the error I could go to another folder like my documents, drag a picture into another folder, go look at the pretty new thumbnail, then I could remove the USB drive because the thumbnailer was ‘parked’ back on the C drive. Sounds like I’m making it up but I swear it worked.
Shouldn’t that happen automatically if the drive is identified as removable? And the real solution should be to tell the OS that it’s removable?
I was having terrible performance problems in Windows a while back, and it turned out it had marked every drive as removable and the write cache was filling up due to an extremely slow external HDD, causing even the internal SSDs to grind to a halt until the buffer was flushed whenever a large amounts of writes were made to the HDD. Which, since the external drive was used for backups and large Steam games, was almost every other day.
And that removable object’s filesystem is probably the most shit, unjournalled filesystem in the world so you’re actually fucked if it becomes corrupted by removing it early.
And if you move the drive between operating systems you’re very limited in what filesystems you can use because Windows is very limited in what filesystems it can use. So you can’t just pick a more robust filesystem.
Yeah that was kind of my point.
You can use this performance view thing that comes with windows to search for file handles and the processes that own them
opening the task manager with a shotgun cocking sound
Shame…
“Windows.exe has stopped working”
Oddly enough, this specific problem is usually solved by restarting Explorer, which is basically “windows.exe.” No explorer, no windows.
Windows response:
Shame…
Some Windows apps do handle it properly. For example, if you have an archive open in 7-zip and try to delete it, Windows Explorer should correctly tell you that it’s open in 7-Zip. I’m not sure why it doesn’t work that way for all apps.
Windows doesn’t even tell you if Explorer itself has a folder open… how the hell does 7-Zip do it?
Different user
Shout out to my MVP Notepad++ telling the file has been deleted by another process and letting me decide if I want to keep it open anyway. Fantastic feature. I literally could not do my job without its ability to leave log files alone so they can be written to while I’m still browsing them.
I like Notepad++. It can handle anything you throw at it.
I switched to Linux (Fedora with KDE) and I like KWrite for similar reasons.
Meanwhile on Linux: /boot successfully deleted
I once deleted /dev/null Do not recommend. You’d be surprised how much of the system needs it.
I once deleted /dev/urandom. I didn’t want uncertainty in my life.
Well, I was on for a surprise.
well, i guess your pc got into a pretty certain state of being, at least for that evening, so technically it worked:)
How? I could’ve sworn it wasn’t even a “real” file. I thought the file system just had special rules for interacting with that name.
Actually on windows 7 I found out how to get which process is locking one file.
You open the resources manager (task manager has a link to it)
Inside you can see how much each process uses on cpu, network and stuff.
And there is a tab where all used files for each process is listed. You can search for specific files.
Yeah there’s a Microsoft sysinternals utility where you can drag a file into to fetch that info for you.
Makes zero sense there isn’t a >Details in the error notification that tells you the damned process in Windows.
Not only that, but you can actually search all active processes to see which handles they keep references to. Just search the name of your file and it will show you the processes which use it
Gawd forbid users get some transparency.
Right? I get that it’s “alarming” to users to see weird stuff, but just hide it under a little expandable thing.
Linux fuser for the win
I’ve never fused Linux before, is it difficult?
fuser is an easy command just point it at the file and it tells you the process ids that using that file.
Not anymore. Many distribution will have most of what you need out of the box depending on what your needs are. They mostly feel like windows XP or 7.
where do i get linux xp 7?
Arch wiki
Either a distribution with KdE Plasma (Kubuntu for example), or something like Zorin OS works really well.
I barely know er!
Or stay with the basics and use lsof.
Either way, not coming with that tool by default and forcing every usage of the file to lock it is a really stupid pair of mistakes.
Well duh, Microsoft respects privacy
It’s one of the things that made me prefer using Linux a long long time ago. It’s nice to be able to rename, move, and delete files while they are used.
Same thing whenever I try to unplug a USB, Win10, on my desktop. There have been times where I plugged in one, opened a file, closed it within seconds, did the safely remove thing, and then I get the whole quick song and dance about some program still using it because of how sluggish it is to actually end what’s using it in the background.
Also, my phone’s keyboard software was bugging out and replaced “song” with “incest” for no discernable and wanted to replace the next word “and” with “rape incest”. Not related, but fuck Gboard and that weird glitch where it’ll replace words with random shit for no reason.
Doesn’t gboard try to promote words you’ve used more prior more often than ones you’ve used less…?
Yeah, dude really needs to atop looking up hentai, or at least start reading more wholesome ones.
Or get FUTO keyboard and disable autosuggest
The crazy part about that is I don’t look up hentai. Just yiff and even then, I’m a vanilla kinda guy.
I may occasionally joke about Alabama and incest out loud, but never really type it.
Also, I would switch to something like FUTO but I have yet to find a FOSS keyboard that can handle Japanese or Chinese.
OK, WTAF on those word replacements. I’d be freaking out about malware.
I cannot remember what it’s done in the past, but I’ve definitely had much more tame occurrences of this. Same with holding the delete key and having the thing think that the first letter of a word doesn’t exist from time to time.
Probably a couple of minor bugs that g••gle doesn’t care to fix.
That’s what happens when they train it on bad porn sites.
There are good keyboard apps on F-Droid…
I have yet to find one that can properly do Chinese and/or Japanese and I’m too dumb to make one. That’s the only thing holding me back.
“Hey Microsoft, i want to safely remove this hard drive so i don’t corrupt my data”
“Nope, it’s being used by another program”
“I shut down every program, nothing is open, please eject my Hard drive”
“Nope, It’s being used by another program”
**Proceed to just yank the cord out of the computer and flick off the screen.
Mac does the same thing (as others have said) and you can at least
sudo lsof
and find it, but somehow filesystem access now is worse than Windows 95 era Excel spreadsheet file handles that never worked.Here’s what an operating system is peeps: Something that handles files and programs that live on top of it. That’s it.
How is it none of them can’t do their basic function anymore?
Same command works on Linux. Its a real saver sometimes.
You can also specify a path.
Files, hardware / peripherals and programs. The distinction can get a bit blurry what with drivers and the fact that Linux exposes most of the hardware via the filesystem.