/// <summary> /// Executes in two distinct scenarios. /// /// 1. If disposing is true, the method has been called directly /// or indirectly by a user's code via the Dispose method. /// Both managed and unmanaged resources can be disposed. /// /// 2. If disposing is false, the method has been called by the /// runtime from inside the finalizer and you should not reference (access) /// other managed objects, as they already have been garbage collected. /// Only unmanaged resources can be disposed. /// </summary> /// <remarks> /// If any exceptions are thrown, that is fine. /// If the method is being done in a finalizer, it will be ignored. /// If it is thrown by client code calling Dispose, /// it needs to be handled by fixing the issue. /// </remarks> private void Dispose(bool disposing) { if (IsDisposed) { return; } if (disposing) { if (_notesBrowser != null) { _notesBrowser.Dispose(); } if (_chorusSystem != null) { _chorusSystem.Dispose(); } if (_connectionHelper != null) { JumpUrlChanged -= _connectionHelper.SendJumpUrlToFlex; } if (_chorusSystem != null) { _chorusSystem.Dispose(); } } _connectionHelper = null; MainForm = null; _chorusUser = null; _notesBrowser = null; IsDisposed = true; }