1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- // Licensed to the .NET Foundation under one or more agreements.
- // The .NET Foundation licenses this file to you under the Apache 2.0 License.
- // See the LICENSE file in the project root for more information.
- namespace System.Reactive.Disposables
- {
- /// <summary>
- /// Represents a disposable resource whose underlying disposable resource can be replaced by another disposable resource, causing automatic disposal of the previous underlying disposable resource.
- /// </summary>
- public sealed class SerialDisposable : ICancelable
- {
- private readonly object _gate = new object();
- private IDisposable _current;
- private bool _disposed;
- /// <summary>
- /// Initializes a new instance of the <see cref="SerialDisposable"/> class.
- /// </summary>
- public SerialDisposable()
- {
- }
- /// <summary>
- /// Gets a value that indicates whether the object is disposed.
- /// </summary>
- public bool IsDisposed
- {
- get
- {
- lock (_gate)
- {
- return _disposed;
- }
- }
- }
- /// <summary>
- /// Gets or sets the underlying disposable.
- /// </summary>
- /// <remarks>If the SerialDisposable has already been disposed, assignment to this property causes immediate disposal of the given disposable object. Assigning this property disposes the previous disposable object.</remarks>
- public IDisposable Disposable
- {
- get
- {
- return _current;
- }
- set
- {
- var shouldDispose = false;
- var old = default(IDisposable);
- lock (_gate)
- {
- shouldDispose = _disposed;
- if (!shouldDispose)
- {
- old = _current;
- _current = value;
- }
- }
- if (old != null)
- old.Dispose();
- if (shouldDispose && value != null)
- value.Dispose();
- }
- }
- /// <summary>
- /// Disposes the underlying disposable as well as all future replacements.
- /// </summary>
- public void Dispose()
- {
- var old = default(IDisposable);
- lock (_gate)
- {
- if (!_disposed)
- {
- _disposed = true;
- old = _current;
- _current = null;
- }
- }
- if (old != null)
- old.Dispose();
- }
- }
- }
|