From cee712105850ac3385cd0091a923438167433f9f Mon Sep 17 00:00:00 2001
From: TSR Berry <20988865+TSRBerry@users.noreply.github.com>
Date: Sat, 8 Apr 2023 01:22:00 +0200
Subject: Move solution and projects to src
---
.../WindowsMultimediaTimerResolution.cs | 114 ---------------------
1 file changed, 114 deletions(-)
delete mode 100644 Ryujinx.Common/SystemInterop/WindowsMultimediaTimerResolution.cs
(limited to 'Ryujinx.Common/SystemInterop/WindowsMultimediaTimerResolution.cs')
diff --git a/Ryujinx.Common/SystemInterop/WindowsMultimediaTimerResolution.cs b/Ryujinx.Common/SystemInterop/WindowsMultimediaTimerResolution.cs
deleted file mode 100644
index a4fbf0bd..00000000
--- a/Ryujinx.Common/SystemInterop/WindowsMultimediaTimerResolution.cs
+++ /dev/null
@@ -1,114 +0,0 @@
-using Ryujinx.Common.Logging;
-using System;
-using System.Runtime.CompilerServices;
-using System.Runtime.InteropServices;
-using System.Runtime.Versioning;
-
-namespace Ryujinx.Common.SystemInterop
-{
- ///
- /// Handle Windows Multimedia timer resolution.
- ///
- [SupportedOSPlatform("windows")]
- public partial class WindowsMultimediaTimerResolution : IDisposable
- {
- [StructLayout(LayoutKind.Sequential)]
- public struct TimeCaps
- {
- public uint wPeriodMin;
- public uint wPeriodMax;
- };
-
- [LibraryImport("winmm.dll", EntryPoint = "timeGetDevCaps", SetLastError = true)]
- private static partial uint TimeGetDevCaps(ref TimeCaps timeCaps, uint sizeTimeCaps);
-
- [LibraryImport("winmm.dll", EntryPoint = "timeBeginPeriod")]
- private static partial uint TimeBeginPeriod(uint uMilliseconds);
-
- [LibraryImport("winmm.dll", EntryPoint = "timeEndPeriod")]
- private static partial uint TimeEndPeriod(uint uMilliseconds);
-
- private uint _targetResolutionInMilliseconds;
- private bool _isActive;
-
- ///
- /// Create a new and activate the given resolution.
- ///
- ///
- public WindowsMultimediaTimerResolution(uint targetResolutionInMilliseconds)
- {
- _targetResolutionInMilliseconds = targetResolutionInMilliseconds;
-
- EnsureResolutionSupport();
- Activate();
- }
-
- private void EnsureResolutionSupport()
- {
- TimeCaps timeCaps = default;
-
- uint result = TimeGetDevCaps(ref timeCaps, (uint)Unsafe.SizeOf());
-
- if (result != 0)
- {
- Logger.Notice.Print(LogClass.Application, $"timeGetDevCaps failed with result: {result}");
- }
- else
- {
- uint supportedTargetResolutionInMilliseconds = Math.Min(Math.Max(timeCaps.wPeriodMin, _targetResolutionInMilliseconds), timeCaps.wPeriodMax);
-
- if (supportedTargetResolutionInMilliseconds != _targetResolutionInMilliseconds)
- {
- Logger.Notice.Print(LogClass.Application, $"Target resolution isn't supported by OS, using closest resolution: {supportedTargetResolutionInMilliseconds}ms");
-
- _targetResolutionInMilliseconds = supportedTargetResolutionInMilliseconds;
- }
- }
- }
-
- private void Activate()
- {
- uint result = TimeBeginPeriod(_targetResolutionInMilliseconds);
-
- if (result != 0)
- {
- Logger.Notice.Print(LogClass.Application, $"timeBeginPeriod failed with result: {result}");
- }
- else
- {
- _isActive = true;
- }
- }
-
- private void Disable()
- {
- if (_isActive)
- {
- uint result = TimeEndPeriod(_targetResolutionInMilliseconds);
-
- if (result != 0)
- {
- Logger.Notice.Print(LogClass.Application, $"timeEndPeriod failed with result: {result}");
- }
- else
- {
- _isActive = false;
- }
- }
- }
-
- public void Dispose()
- {
- Dispose(true);
- GC.SuppressFinalize(this);
- }
-
- protected virtual void Dispose(bool disposing)
- {
- if (disposing)
- {
- Disable();
- }
- }
- }
-}
\ No newline at end of file
--
cgit v1.2.3