My last post implied that I ego-surfed and found a Wikipedia chat entry about me, but that’s not the case. I was searching for information on how to remove a system-protected font from Windows 10, and seeing as I often post solutions to obscure technical issues on here, I had hoped I recorded my how-to last time. The libel posted by some Australian Wikipedia editor came up during that search.
Once upon a time, Microsoft didn’t care if you removed system fonts, but at some point, it began protecting Arial, whose design, for reasons I’ve gone into elsewhere, I’ve always considered compromised. There was one stage where you could replace Arial with something else called Arial, and as I had a licence for a very, very old Agfa version of Helvetica (do people remember CG Triumvirate?!), I decided to modify its file name to fool Windows into thinking all was well.
The last time Windows did an update—version 1909—I had to resort to a safe-mode boot and taking control of the font files as admin, but I really could not remember the specifics. The problem is that when you install the “new” Arial, the existing roman one is used by quite a few applications, and you don’t really replace it—your only solution is to delete it.
With version 2004, safe mode is quite different, and the command prompt and Powershell commands I knew just didn’t cut it. I realize the usual solution is to go into the registry keys—I’ve used this one for a long, long time—and to remove or modify the references to the offending fonts at HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Fonts. I’ve also used the HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\FontSubstitutes key to make sure that Helvetica does not map on to Arial (in fact, I make sure Arial maps on to Helvetica). Neither actually works in this case; they are ignored, even bypassed by certain programs. And, really, neither deletes the file; they just attempt to have Windows not load them, something which, as I discovered, doesn’t prevent Windows from loading them.
By all means, use these methods, but be prepared for the exception where it doesn’t work. The claim that the methods ‘delete’ the fonts is actually untrue: they remain in C:\Windows\Fonts.
The other methods that do not work are altering the equivalent keys under WOW6432node (which get intercepted and directed from the 32-bit keys anyway), using an elevated command prompt to delete the files (at least not initially), or doing the same from safe mode (which is very different now, as safe mode is in the same resolution and the Windows\Fonts folder displays as it does in the regular mode—so you cannot see the files you have to remove). You cannot take ownership of the font files through an elevated Powershell (errors result), nor can you do this from safe mode. Nothing happens if you delete FNTCACHE.DAT from the system32 directory, and nothing happens if you delete ~fontcache files from the Local directory.
What was interesting was what kept calling arial.ttf in the fonts’ directory even after “my” Arial was loaded up. The imposter Arial loaded in most programs, but for the Chromium-based browsers (Vivaldi, Edge), somehow these knew to avoid the font registry and access the font directly. This was confirmed by analysing the processes under Process Monitor: sure enough, something had called up and used arial.ttf.
This Wikihow article was a useful lead, getting us to delete the fonts under the Windows\WinSxS folder, and showing how to take ownership of them. I don’t know if altering these ultimately affected the ones inside Windows\Fonts, but I followed the instructions, to find that the original Arial was being accessed by three programs: Vivaldi, Keybase, and Qt Qtwebengineprocess. I shut each one of these down and removed the Arial family.
Reboot: it was still there. Then it hit me, and I posted the solution in the Microsoft Answers forum (perhaps inadvertently prompting a Microsoft programmer to make things even harder in future!). Another user had told me it was impossible, but I knew that to be untrue, since it had been possible every other time.
The solution is pretty simple: since you can’t see the full Windows\Fonts directory with Windows Explorer, then I needed another file manager.
Luckily, I had 7zip, which I opened as an administrator. It allowed me to go into the folder and view all its contents, not just the fonts called up under HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Fonts, which we know is not an accurate representation of the fonts being used by the system. From there I could finally delete the offending four fonts without changing the ownership (which makes me wonder if the Wikihow advice of changing the owner under Windows\WinSxS wound up affecting the Windows\Fonts files). Once again, I had to close Keybase, Vivaldi and Qt Qtwebengineprocess.
It took from c. 4 p.m., when my desktop PC updated to v. 2004 (my laptop had been on it for many weeks; soon after its release, in fact) to 2 a.m., with a break in between to cook and eat dinner. I’m hoping those hours of having typographic OCD helps others who want to have a font menu where they determine what they should have. Also, user beware: don’t delete stuff that the system really, really needs, including an icon font that Windows uses for rendering its GUI.
When I try to delete some fonts, I’m getting this error message: “The action can’t be completed because the file is open in fontdrvhost.exe.” From what I’ve read online, forcing fontdrvhost to quit is A Bad Thing. Any suggestions? TIA
Hi Beal, I wouldn’t force fontdrvhost.exe to quit, either—better that the fonts are not loaded to begin with, which was what I hoped my suggestion would do. Which ones aren’t budging?
Since I wrote the post I noticed Windows had duplicated a set of fonts under c:\users\[My name]\appdata\local\microsoft\windows\fonts which could also cause a problem. I opened this query at Microsoft Answers, though I haven’t carried out Van’s suggestion yet. There’s a chance that some issues are down to these duplicates.
I couldn’t delete Malgun Gothic, Marlett, MS Gothic, Nirmala, and Yu Gothic. I successfully deleted Constantia, Impact, Leelawadee, MingLiU, PhagsPa, and MS Reference Specialty. Hopefully I didn’t delete anything important (eek!).
You wouldn’t be using programs that require Asian typefaces, would you? Regardless, I wouldn’t remove Marlett, MS Gothic or Yu Gothic though—looking through their character sets, Windows may need some of their glyphs to draw boxes and some parts of the UI. That might explain why those don’t budge, and there’s a chance the others are staying for a similar reason.
Nope, I don’t use Asian typefaces, and as far as I know, I’m not using any programs that require them. Well, unless Chrome counts — it’s my browser of choice, and it displays Asian characters in YouTube comments.
I noticed when I wrote the original post that Chromium browsers do tend to load certain fonts, regardless of what you have in the usual registry keys, so Chrome’s capture of some of those could well be why you can’t delete them easily. And I see your point about fontdrvhost—after seeing this I definitely wouldn’t recommend force-quitting it.
Oh well… at least I got some fonts deleted! Thanks so much for your help! :-)
You’re very welcome!
I don’t know if this article is still active enough to recieve a reply, but In hopes that it is I leave this: I don’t see anywhere in your article that describes step by ste instructions, and I would be ecstatic if I could get my hands on them. I hate 3/4 of the fonts. I am not a computer genious, but I am also not on lower end of the intellect spectrum. If any one here could please direct me to where I may find step by step instructions I would be forever grateful. thank you
Sorry, I don’t know what you mean about not seeing instructions. This is a personal journal and I’m not a computer tech, but what you read in the post are the steps I’ve taken. The user above, Beal, seems to have been able to follow them.