// Copyright © 2019 The CefSharp Authors. All rights reserved. // // Use of this source code is governed by a BSD-style license that can be found in the LICENSE file. using System; using System.Windows.Forms; namespace CefSharp.WinForms.Example { public static class ControlExtensions { /// /// Executes the Action asynchronously on the UI thread, does not block execution on the calling thread. /// No action will be performed if the control doesn't have a valid handle or the control is Disposed/Disposing. /// /// the control for which the update is required /// action to be performed on the control public static void InvokeOnUiThreadIfRequired(this Control control, Action action) { //See https://stackoverflow.com/questions/1874728/avoid-calling-invoke-when-the-control-is-disposed //for background and some guidance when implementing your own version. //No action if (control.Disposing || control.IsDisposed || !control.IsHandleCreated) { return; } if (control.InvokeRequired) { control.BeginInvoke((Action)(() => { //No action if (control.Disposing || control.IsDisposed || !control.IsHandleCreated) { return; } action(); })); } else { action.Invoke(); } } } }