mirror of
https://github.com/DarthAffe/RGB.NET.git
synced 2025-12-12 17:48:31 +00:00
Fixed potential callback collection in CorsairDeviceProvider
This commit is contained in:
parent
c0adbad599
commit
8f7e24ba33
@ -47,6 +47,9 @@ internal static unsafe class _CUESDK
|
||||
|
||||
#region Properties & Fields
|
||||
|
||||
// ReSharper disable once NotAccessedField.Local - This is important, the delegate can be collected if it's not stored!
|
||||
private static readonly CorsairSessionStateChangedHandler SESSION_STATE_CHANGED_CALLBACK;
|
||||
|
||||
internal static bool IsConnected => SesionState == CorsairSessionState.Connected;
|
||||
internal static CorsairSessionState SesionState { get; private set; }
|
||||
|
||||
@ -58,6 +61,15 @@ internal static unsafe class _CUESDK
|
||||
|
||||
#endregion
|
||||
|
||||
#region Constructors
|
||||
|
||||
static _CUESDK()
|
||||
{
|
||||
SESSION_STATE_CHANGED_CALLBACK = CorsairSessionStateChangedCallback;
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region Methods
|
||||
|
||||
private static void CorsairSessionStateChangedCallback(nint context, _CorsairSessionStateChanged eventdata)
|
||||
@ -174,7 +186,7 @@ internal static unsafe class _CUESDK
|
||||
{
|
||||
if (_corsairConnectPtr == null) throw new RGBDeviceException("The Corsair-SDK is not initialized.");
|
||||
if (IsConnected) throw new RGBDeviceException("The Corsair-SDK is already connected.");
|
||||
return _corsairConnectPtr(CorsairSessionStateChangedCallback, 0);
|
||||
return _corsairConnectPtr(SESSION_STATE_CHANGED_CALLBACK, 0);
|
||||
}
|
||||
|
||||
internal static CorsairError CorsairGetSessionDetails(out _CorsairSessionDetails? details)
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user