1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-04 21:12:54 +08:00
osu-lazer/osu.Desktop/OsuGameDesktop.cs

192 lines
6.3 KiB
C#
Raw Normal View History

// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
// See the LICENCE file in the repository root for full licence text.
2018-04-13 17:19:50 +08:00
using System;
using System.Diagnostics;
2018-04-13 17:19:50 +08:00
using System.IO;
using System.Reflection;
2020-11-20 17:06:08 +08:00
using System.Runtime.Versioning;
using Microsoft.Win32;
2024-02-27 18:36:03 +08:00
using osu.Desktop.Performance;
using osu.Desktop.Security;
2018-04-13 17:19:50 +08:00
using osu.Framework.Platform;
using osu.Game;
2018-07-06 15:39:27 +08:00
using osu.Desktop.Updater;
2018-08-01 01:58:39 +08:00
using osu.Framework;
using osu.Framework.Logging;
using osu.Game.Updater;
2020-07-01 23:15:41 +08:00
using osu.Desktop.Windows;
2024-02-27 18:36:03 +08:00
using osu.Framework.Allocation;
2021-01-25 02:18:16 +08:00
using osu.Game.IO;
using osu.Game.IPC;
using osu.Game.Online.Multiplayer;
2024-02-27 18:36:03 +08:00
using osu.Game.Performance;
2022-07-30 20:26:19 +08:00
using osu.Game.Utils;
using SDL2;
2018-04-13 17:19:50 +08:00
namespace osu.Desktop
{
2022-11-24 13:32:20 +08:00
internal partial class OsuGameDesktop : OsuGame
2018-04-13 17:19:50 +08:00
{
private OsuSchemeLinkIPCChannel? osuSchemeLinkIPCChannel;
private ArchiveImportIPCChannel? archiveImportIPCChannel;
2024-02-27 18:36:03 +08:00
[Cached(typeof(IHighPerformanceSessionManager))]
private readonly HighPerformanceSessionManager highPerformanceSessionManager = new HighPerformanceSessionManager();
public OsuGameDesktop(string[]? args = null)
2018-04-13 17:19:50 +08:00
: base(args)
{
}
public override StableStorage? GetStorageForStableInstall()
2018-04-13 17:19:50 +08:00
{
try
{
if (Host is DesktopGameHost desktopHost)
{
string? stablePath = getStableInstallPath();
if (!string.IsNullOrEmpty(stablePath))
2021-01-25 02:18:16 +08:00
return new StableStorage(stablePath, desktopHost);
}
2018-04-13 17:19:50 +08:00
}
catch (Exception)
2018-04-13 17:19:50 +08:00
{
Logger.Log("Could not find a stable install", LoggingTarget.Runtime, LogLevel.Important);
2018-04-13 17:19:50 +08:00
}
return null;
2018-04-13 17:19:50 +08:00
}
private string? getStableInstallPath()
{
2021-06-02 14:13:21 +08:00
static bool checkExists(string p) => Directory.Exists(Path.Combine(p, "Songs")) || File.Exists(Path.Combine(p, "osu!.cfg"));
string? stableInstallPath;
2020-11-20 17:06:08 +08:00
if (OperatingSystem.IsWindows())
{
try
{
stableInstallPath = getStableInstallPathFromRegistry();
if (!string.IsNullOrEmpty(stableInstallPath) && checkExists(stableInstallPath))
return stableInstallPath;
}
catch
{
}
}
stableInstallPath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData), @"osu!");
if (checkExists(stableInstallPath))
return stableInstallPath;
stableInstallPath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.UserProfile), ".osu");
if (checkExists(stableInstallPath))
return stableInstallPath;
return null;
}
2020-11-20 17:06:08 +08:00
[SupportedOSPlatform("windows")]
private string? getStableInstallPathFromRegistry()
2020-11-20 17:06:08 +08:00
{
using (RegistryKey? key = Registry.ClassesRoot.OpenSubKey("osu!"))
return key?.OpenSubKey(WindowsAssociationManager.SHELL_OPEN_COMMAND)?.GetValue(string.Empty)?.ToString()?.Split('"')[1].Replace("osu!.exe", "");
2020-11-20 17:06:08 +08:00
}
2020-03-05 12:34:04 +08:00
protected override UpdateManager CreateUpdateManager()
{
string? packageManaged = Environment.GetEnvironmentVariable("OSU_EXTERNAL_UPDATE_PROVIDER");
if (!string.IsNullOrEmpty(packageManaged))
return new NoActionUpdateManager();
2020-03-05 12:34:04 +08:00
switch (RuntimeInfo.OS)
{
case RuntimeInfo.Platform.Windows:
Debug.Assert(OperatingSystem.IsWindows());
2020-03-05 12:34:04 +08:00
return new SquirrelUpdateManager();
default:
return new SimpleUpdateManager();
}
}
public override bool RestartAppWhenExited()
{
switch (RuntimeInfo.OS)
{
case RuntimeInfo.Platform.Windows:
Debug.Assert(OperatingSystem.IsWindows());
// Of note, this is an async method in squirrel that adds an arbitrary delay before returning
// likely to ensure the external process is in a good state.
//
// We're not waiting on that here, but the outro playing before the actual exit should be enough
// to cover this.
Squirrel.UpdateManager.RestartAppWhenExited().FireAndForget();
return true;
}
return base.RestartAppWhenExited();
}
2018-04-13 17:19:50 +08:00
protected override void LoadComplete()
{
base.LoadComplete();
2019-12-18 13:07:32 +08:00
LoadComponentAsync(new DiscordRichPresence(), Add);
2020-07-01 23:15:41 +08:00
if (RuntimeInfo.OS == RuntimeInfo.Platform.Windows)
LoadComponentAsync(new GameplayWinKeyBlocker(), Add);
2021-04-27 05:41:04 +08:00
LoadComponentAsync(new ElevatedPrivilegesChecker(), Add);
osuSchemeLinkIPCChannel = new OsuSchemeLinkIPCChannel(Host, this);
archiveImportIPCChannel = new ArchiveImportIPCChannel(Host, this);
2018-04-13 17:19:50 +08:00
}
public override void SetHost(GameHost host)
{
base.SetHost(host);
2019-04-01 11:16:05 +08:00
2022-10-05 13:15:54 +08:00
var iconStream = Assembly.GetExecutingAssembly().GetManifestResourceStream(GetType(), "lazer.ico");
if (iconStream != null)
host.Window.SetIconFromStream(iconStream);
2022-10-05 13:15:54 +08:00
host.Window.CursorState |= CursorState.Hidden;
host.Window.Title = Name;
2018-04-13 17:19:50 +08:00
}
2022-07-30 20:26:19 +08:00
protected override BatteryInfo CreateBatteryInfo() => new SDL2BatteryInfo();
protected override void Dispose(bool isDisposing)
{
base.Dispose(isDisposing);
osuSchemeLinkIPCChannel?.Dispose();
archiveImportIPCChannel?.Dispose();
}
2022-07-30 20:26:19 +08:00
private class SDL2BatteryInfo : BatteryInfo
{
public override double? ChargeLevel
{
get
{
SDL.SDL_GetPowerInfo(out _, out int percentage);
if (percentage == -1)
return null;
return percentage / 100.0;
}
}
public override bool OnBattery => SDL.SDL_GetPowerInfo(out _, out _) == SDL.SDL_PowerState.SDL_POWERSTATE_ON_BATTERY;
}
2018-04-13 17:19:50 +08:00
}
}