From a71695198543b641f88ba576b2decb083b822174 Mon Sep 17 00:00:00 2001 From: Sebastian M Date: Sun, 25 Feb 2024 09:22:51 +0100 Subject: [PATCH] Prevent Octavi Exception on Connect (#1713) --- MobiFlight/Joysticks/Octavi/Octavi.cs | 52 +++++++++++++++++++-------- 1 file changed, 38 insertions(+), 14 deletions(-) diff --git a/MobiFlight/Joysticks/Octavi/Octavi.cs b/MobiFlight/Joysticks/Octavi/Octavi.cs index b7db3eb5..c13ffcf2 100644 --- a/MobiFlight/Joysticks/Octavi/Octavi.cs +++ b/MobiFlight/Joysticks/Octavi/Octavi.cs @@ -20,20 +20,35 @@ public Octavi(SharpDX.DirectInput.Joystick joystick, JoystickDefinition definiti } + /// + /// Method is not called by regular Joystick Manager + /// This method is called implicitly when Update() is called + /// public void Connect() { - if (Device == null) + // Prevent reentry and parallel execution by multiple threads + lock (this) { - Device = DeviceList.Local.GetHidDeviceOrNull(vendorID: VendorId, productID: ProductId); - if (Device == null) return; - } + if (Device == null) + { + Device = DeviceList.Local.GetHidDeviceOrNull(vendorID: VendorId, productID: ProductId); + if (Device == null) return; + } - Stream = Device.Open(); - Stream.ReadTimeout = System.Threading.Timeout.Infinite; - reportDescriptor = Device.GetReportDescriptor(); - inputReceiver = reportDescriptor.CreateHidDeviceInputReceiver(); - inputReceiver.Received += InputReceiver_Received; - inputReceiver.Start(Stream); + if (Stream == null) + { + Stream = Device.Open(); + Stream.ReadTimeout = System.Threading.Timeout.Infinite; + reportDescriptor = Device.GetReportDescriptor(); + } + + if (inputReceiver == null) + { + inputReceiver = reportDescriptor.CreateHidDeviceInputReceiver(); + inputReceiver.Received += InputReceiver_Received; + inputReceiver.Start(Stream); + } + } } private void InputReceiver_Received(object sender, System.EventArgs e) @@ -80,6 +95,8 @@ protected void TriggerButtonPress(int i, MobiFlightButton.InputEvent inputEvent) public override void Update() { + // Octavi is not a DirectInput device + // so we have to connect it here. if (Stream == null || inputReceiver == null) { Connect(); @@ -99,10 +116,17 @@ protected override void EnumerateDevices() public override void Shutdown() { - Stream.Close(); - inputReceiver.Received -= InputReceiver_Received; - Stream = null; - inputReceiver = null; + if (Stream != null) + { + Stream.Close(); + Stream = null; + } + + if (inputReceiver != null) + { + inputReceiver.Received -= InputReceiver_Received; + inputReceiver = null; + } } } }