mirror of
https://github.com/ppy/osu.git
synced 2025-01-23 18:13:20 +08:00
Refine uninstall logic to account for legacy windows features
This commit is contained in:
parent
6ded79cf07
commit
6dbba705b3
@ -222,12 +222,21 @@ namespace osu.Desktop.Windows
|
|||||||
programKey?.SetValue(null, description);
|
programKey?.SetValue(null, description);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Uninstalls the file extenstion association in accordance with https://learn.microsoft.com/en-us/windows/win32/shell/fa-file-types#deleting-registry-information-during-uninstallation
|
||||||
|
/// </summary>
|
||||||
public void Uninstall(RegistryKey classes)
|
public void Uninstall(RegistryKey classes)
|
||||||
{
|
{
|
||||||
// importantly, we don't delete the default program entry because some other program could have taken it.
|
using (var extensionKey = classes.OpenSubKey(Extension, true))
|
||||||
|
{
|
||||||
|
// clear our default association so that Explorer doesn't show the raw programId to users
|
||||||
|
// the null/(Default) entry is used for both ProdID association and as a fallback friendly name, for legacy reasons
|
||||||
|
if (extensionKey?.GetValue(null) is string s && s == programId)
|
||||||
|
extensionKey.SetValue(null, string.Empty);
|
||||||
|
|
||||||
using (var extensionKey = classes.OpenSubKey($@"{Extension}\OpenWithProgIds", true))
|
using (var openWithKey = extensionKey?.CreateSubKey(@"OpenWithProgIds"))
|
||||||
extensionKey?.DeleteValue(programId, throwOnMissingValue: false);
|
openWithKey?.DeleteValue(programId, throwOnMissingValue: false);
|
||||||
|
}
|
||||||
|
|
||||||
classes.DeleteSubKeyTree(programId, throwOnMissingSubKey: false);
|
classes.DeleteSubKeyTree(programId, throwOnMissingSubKey: false);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user