1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-07 23:23:12 +08:00

Inline constants

This commit is contained in:
Susko3 2024-02-05 14:16:35 +01:00
parent 7789cc01eb
commit 4ec9d26657
2 changed files with 14 additions and 19 deletions

View File

@ -138,7 +138,7 @@ namespace osu.Desktop
LoadComponentAsync(new GameplayWinKeyBlocker(), Add); LoadComponentAsync(new GameplayWinKeyBlocker(), Add);
if (OperatingSystem.IsWindows() && IsDeployedBuild) if (OperatingSystem.IsWindows() && IsDeployedBuild)
LoadComponentAsync(new WindowsAssociationManager(Path.ChangeExtension(typeof(OsuGameDesktop).Assembly.Location, ".exe"), "osu"), Add); LoadComponentAsync(new WindowsAssociationManager(), Add);
LoadComponentAsync(new ElevatedPrivilegesChecker(), Add); LoadComponentAsync(new ElevatedPrivilegesChecker(), Add);

View File

@ -2,6 +2,7 @@
// See the LICENCE file in the repository root for full licence text. // See the LICENCE file in the repository root for full licence text.
using System; using System;
using System.IO;
using System.Runtime.InteropServices; using System.Runtime.InteropServices;
using System.Runtime.Versioning; using System.Runtime.Versioning;
using Microsoft.Win32; using Microsoft.Win32;
@ -31,6 +32,14 @@ namespace osu.Desktop.Windows
/// </summary> /// </summary>
public const string SHELL_OPEN_COMMAND = @"Shell\Open\Command"; public const string SHELL_OPEN_COMMAND = @"Shell\Open\Command";
public static readonly string EXE_PATH = Path.ChangeExtension(typeof(WindowsAssociationManager).Assembly.Location, ".exe");
/// <summary>
/// Program ID prefix used for file associations. Should be relatively short since the full program ID has a 39 character limit,
/// see https://learn.microsoft.com/en-us/windows/win32/com/-progid--key.
/// </summary>
public const string PROGRAM_ID_PREFIX = "osu";
private static readonly FileAssociation[] file_associations = private static readonly FileAssociation[] file_associations =
{ {
new FileAssociation(@".osz", WindowsAssociationManagerStrings.OsuBeatmap, Icons.Lazer), new FileAssociation(@".osz", WindowsAssociationManagerStrings.OsuBeatmap, Icons.Lazer),
@ -50,20 +59,6 @@ namespace osu.Desktop.Windows
private IBindable<LocalisationParameters> localisationParameters = null!; private IBindable<LocalisationParameters> localisationParameters = null!;
private readonly string exePath;
private readonly string programIdPrefix;
/// <param name="exePath">Path to the executable to register.</param>
/// <param name="programIdPrefix">
/// Program ID prefix used for file associations. Should be relatively short since the full program ID has a 39 character limit,
/// see https://learn.microsoft.com/en-us/windows/win32/com/-progid--key.
/// </param>
public WindowsAssociationManager(string exePath, string programIdPrefix)
{
this.exePath = exePath;
this.programIdPrefix = programIdPrefix;
}
[BackgroundDependencyLoader] [BackgroundDependencyLoader]
private void load() private void load()
{ {
@ -87,10 +82,10 @@ namespace osu.Desktop.Windows
return; return;
foreach (var association in file_associations) foreach (var association in file_associations)
association.Install(classes, exePath, programIdPrefix); association.Install(classes, EXE_PATH, PROGRAM_ID_PREFIX);
foreach (var association in uri_associations) foreach (var association in uri_associations)
association.Install(classes, exePath); association.Install(classes, EXE_PATH);
} }
updateDescriptions(); updateDescriptions();
@ -112,7 +107,7 @@ namespace osu.Desktop.Windows
foreach (var association in file_associations) foreach (var association in file_associations)
{ {
var b = localisation.GetLocalisedBindableString(association.Description); var b = localisation.GetLocalisedBindableString(association.Description);
association.UpdateDescription(classes, programIdPrefix, b.Value); association.UpdateDescription(classes, PROGRAM_ID_PREFIX, b.Value);
b.UnbindAll(); b.UnbindAll();
} }
@ -131,7 +126,7 @@ namespace osu.Desktop.Windows
} }
} }
public void UninstallAssociations() => UninstallAssociations(programIdPrefix); public void UninstallAssociations() => UninstallAssociations(PROGRAM_ID_PREFIX);
public static void UninstallAssociations(string programIdPrefix) public static void UninstallAssociations(string programIdPrefix)
{ {