Răsfoiți Sursa

Some improvements to core classes.

Bart De Smet 8 ani în urmă
părinte
comite
64fa823960

+ 3 - 3
Rx.NET/Source/src/System.Reactive/AnonymousObservable.cs

@@ -7,7 +7,7 @@ using System.Reactive.Disposables;
 namespace System.Reactive
 namespace System.Reactive
 {
 {
     /// <summary>
     /// <summary>
-    /// Class to create an <see cref="IObservable{T}"/> instance from a delegate-based implementation of the Subscribe method.
+    /// Class to create an <see cref="IObservable{T}"/> instance from a delegate-based implementation of the <see cref="IObservable{T}.Subscribe(IObserver{T})"/> method.
     /// </summary>
     /// </summary>
     /// <typeparam name="T">The type of the elements in the sequence.</typeparam>
     /// <typeparam name="T">The type of the elements in the sequence.</typeparam>
     public sealed class AnonymousObservable<T> : ObservableBase<T>
     public sealed class AnonymousObservable<T> : ObservableBase<T>
@@ -17,8 +17,8 @@ namespace System.Reactive
         /// <summary>
         /// <summary>
         /// Creates an observable sequence object from the specified subscription function.
         /// Creates an observable sequence object from the specified subscription function.
         /// </summary>
         /// </summary>
-        /// <param name="subscribe">Subscribe method implementation.</param>
-        /// <exception cref="ArgumentNullException"><paramref name="subscribe"/> is null.</exception>
+        /// <param name="subscribe"><see cref="IObservable{T}.Subscribe(IObserver{T})"/> method implementation.</param>
+        /// <exception cref="ArgumentNullException"><paramref name="subscribe"/> is <c>null</c>.</exception>
         public AnonymousObservable(Func<IObserver<T>, IDisposable> subscribe)
         public AnonymousObservable(Func<IObserver<T>, IDisposable> subscribe)
         {
         {
             if (subscribe == null)
             if (subscribe == null)

+ 23 - 35
Rx.NET/Source/src/System.Reactive/AnonymousObserver.cs

@@ -15,12 +15,12 @@ namespace System.Reactive
         private readonly Action _onCompleted;
         private readonly Action _onCompleted;
 
 
         /// <summary>
         /// <summary>
-        /// Creates an observer from the specified OnNext, OnError, and OnCompleted actions.
+        /// Creates an observer from the specified <see cref="IObserver{T}.OnNext(T)"/>, <see cref="IObserver{T}.OnError(Exception)"/>, and <see cref="IObserver{T}.OnCompleted()"/> actions.
         /// </summary>
         /// </summary>
-        /// <param name="onNext">Observer's OnNext action implementation.</param>
-        /// <param name="onError">Observer's OnError action implementation.</param>
-        /// <param name="onCompleted">Observer's OnCompleted action implementation.</param>
-        /// <exception cref="ArgumentNullException"><paramref name="onNext"/> or <paramref name="onError"/> or <paramref name="onCompleted"/> is null.</exception>
+        /// <param name="onNext">Observer's <see cref="IObserver{T}.OnNext(T)"/> action implementation.</param>
+        /// <param name="onError">Observer's <see cref="IObserver{T}.OnError(Exception)"/> action implementation.</param>
+        /// <param name="onCompleted">Observer's <see cref="IObserver{T}.OnCompleted()"/> action implementation.</param>
+        /// <exception cref="ArgumentNullException"><paramref name="onNext"/> or <paramref name="onError"/> or <paramref name="onCompleted"/> is <c>null</c>.</exception>
         public AnonymousObserver(Action<T> onNext, Action<Exception> onError, Action onCompleted)
         public AnonymousObserver(Action<T> onNext, Action<Exception> onError, Action onCompleted)
         {
         {
             if (onNext == null)
             if (onNext == null)
@@ -36,66 +36,54 @@ namespace System.Reactive
         }
         }
 
 
         /// <summary>
         /// <summary>
-        /// Creates an observer from the specified OnNext action.
+        /// Creates an observer from the specified <see cref="IObserver{T}.OnNext(T)"/> action.
         /// </summary>
         /// </summary>
-        /// <param name="onNext">Observer's OnNext action implementation.</param>
-        /// <exception cref="ArgumentNullException"><paramref name="onNext"/> is null.</exception>
+        /// <param name="onNext">Observer's <see cref="IObserver{T}.OnNext(T)"/> action implementation.</param>
+        /// <exception cref="ArgumentNullException"><paramref name="onNext"/> is <c>null</c>.</exception>
         public AnonymousObserver(Action<T> onNext)
         public AnonymousObserver(Action<T> onNext)
             : this(onNext, Stubs.Throw, Stubs.Nop)
             : this(onNext, Stubs.Throw, Stubs.Nop)
         {
         {
         }
         }
 
 
         /// <summary>
         /// <summary>
-        /// Creates an observer from the specified OnNext and OnError actions.
+        /// Creates an observer from the specified <see cref="IObserver{T}.OnNext(T)"/> and <see cref="IObserver{T}.OnError(Exception)"/> actions.
         /// </summary>
         /// </summary>
-        /// <param name="onNext">Observer's OnNext action implementation.</param>
-        /// <param name="onError">Observer's OnError action implementation.</param>
-        /// <exception cref="ArgumentNullException"><paramref name="onNext"/> or <paramref name="onError"/> is null.</exception>
+        /// <param name="onNext">Observer's <see cref="IObserver{T}.OnNext(T)"/> action implementation.</param>
+        /// <param name="onError">Observer's <see cref="IObserver{T}.OnError(Exception)"/> action implementation.</param>
+        /// <exception cref="ArgumentNullException"><paramref name="onNext"/> or <paramref name="onError"/> is <c>null</c>.</exception>
         public AnonymousObserver(Action<T> onNext, Action<Exception> onError)
         public AnonymousObserver(Action<T> onNext, Action<Exception> onError)
             : this(onNext, onError, Stubs.Nop)
             : this(onNext, onError, Stubs.Nop)
         {
         {
         }
         }
 
 
         /// <summary>
         /// <summary>
-        /// Creates an observer from the specified OnNext and OnCompleted actions.
+        /// Creates an observer from the specified <see cref="IObserver{T}.OnNext(T)"/> and <see cref="IObserver{T}.OnCompleted()"/> actions.
         /// </summary>
         /// </summary>
-        /// <param name="onNext">Observer's OnNext action implementation.</param>
-        /// <param name="onCompleted">Observer's OnCompleted action implementation.</param>
-        /// <exception cref="ArgumentNullException"><paramref name="onNext"/> or <paramref name="onCompleted"/> is null.</exception>
+        /// <param name="onNext">Observer's <see cref="IObserver{T}.OnNext(T)"/> action implementation.</param>
+        /// <param name="onCompleted">Observer's <see cref="IObserver{T}.OnCompleted()"/> action implementation.</param>
+        /// <exception cref="ArgumentNullException"><paramref name="onNext"/> or <paramref name="onCompleted"/> is <c>null</c>.</exception>
         public AnonymousObserver(Action<T> onNext, Action onCompleted)
         public AnonymousObserver(Action<T> onNext, Action onCompleted)
             : this(onNext, Stubs.Throw, onCompleted)
             : this(onNext, Stubs.Throw, onCompleted)
         {
         {
         }
         }
 
 
         /// <summary>
         /// <summary>
-        /// Calls the onNext action.
+        /// Calls the action implementing <see cref="IObserver{T}.OnNext(T)"/>.
         /// </summary>
         /// </summary>
         /// <param name="value">Next element in the sequence.</param>
         /// <param name="value">Next element in the sequence.</param>
-        protected override void OnNextCore(T value)
-        {
-            _onNext(value);
-        }
+        protected override void OnNextCore(T value) => _onNext(value);
 
 
         /// <summary>
         /// <summary>
-        /// Calls the onError action.
+        /// Calls the action implementing <see cref="IObserver{T}.OnError(Exception)"/>.
         /// </summary>
         /// </summary>
         /// <param name="error">The error that has occurred.</param>
         /// <param name="error">The error that has occurred.</param>
-        protected override void OnErrorCore(Exception error)
-        {
-            _onError(error);
-        }
+        protected override void OnErrorCore(Exception error) => _onError(error);
 
 
         /// <summary>
         /// <summary>
-        /// Calls the onCompleted action.
+        /// Calls the action implementing <see cref="IObserver{T}.OnCompleted()"/>.
         /// </summary>
         /// </summary>
-        protected override void OnCompletedCore()
-        {
-            _onCompleted();
-        }
+        protected override void OnCompletedCore() => _onCompleted();
 
 
-        internal IObserver<T> MakeSafe(IDisposable disposable)
-        {
-            return new AnonymousSafeObserver<T>(_onNext, _onError, _onCompleted, disposable);
-        }
+        internal IObserver<T> MakeSafe(IDisposable disposable) => new AnonymousSafeObserver<T>(_onNext, _onError, _onCompleted, disposable);
     }
     }
 }
 }

+ 1 - 1
Rx.NET/Source/src/System.Reactive/AnonymousSafeObserver.cs

@@ -18,7 +18,7 @@ namespace System.Reactive
     /// that accept delegates for the On* handlers. By doing the fusion, we make the call stack depth shorter which
     /// that accept delegates for the On* handlers. By doing the fusion, we make the call stack depth shorter which
     /// helps debugging and some performance.
     /// helps debugging and some performance.
     /// </summary>
     /// </summary>
-    class AnonymousSafeObserver<T> : IObserver<T>
+    internal sealed class AnonymousSafeObserver<T> : IObserver<T>
     {
     {
         private readonly Action<T> _onNext;
         private readonly Action<T> _onNext;
         private readonly Action<Exception> _onError;
         private readonly Action<Exception> _onError;

+ 2 - 2
Rx.NET/Source/src/System.Reactive/EnlightenmentProvider.cs

@@ -7,8 +7,8 @@ namespace System.Reactive.PlatformServices
     /// <summary>
     /// <summary>
     /// Provides access to the platform enlightenments used by other Rx libraries to improve system performance and
     /// Provides access to the platform enlightenments used by other Rx libraries to improve system performance and
     /// runtime efficiency. While Rx can run without platform enlightenments loaded, it's recommended to deploy the
     /// runtime efficiency. While Rx can run without platform enlightenments loaded, it's recommended to deploy the
-    /// System.Reactive.PlatformServices assembly with your application and call <see cref="EnlightenmentProvider.
-    /// EnsureLoaded"/> during application startup to ensure enlightenments are properly loaded.
+    /// System.Reactive.PlatformServices assembly with your application and call <see cref="EnsureLoaded"/> during
+    /// application startup to ensure enlightenments are properly loaded.
     /// </summary>
     /// </summary>
     public static class EnlightenmentProvider
     public static class EnlightenmentProvider
     {
     {

+ 2 - 8
Rx.NET/Source/src/System.Reactive/EventPattern.cs

@@ -93,10 +93,7 @@ namespace System.Reactive
         /// <param name="first">The first <see cref="EventPattern{TSender, TEventArgs}"/> to compare, or <c>null</c>.</param>
         /// <param name="first">The first <see cref="EventPattern{TSender, TEventArgs}"/> to compare, or <c>null</c>.</param>
         /// <param name="second">The second <see cref="EventPattern{TSender, TEventArgs}"/> to compare, or <c>null</c>.</param>
         /// <param name="second">The second <see cref="EventPattern{TSender, TEventArgs}"/> to compare, or <c>null</c>.</param>
         /// <returns><c>true</c> if both <see cref="EventPattern{TSender, TEventArgs}"/> objects represent the same event; otherwise, <c>false</c>.</returns>
         /// <returns><c>true</c> if both <see cref="EventPattern{TSender, TEventArgs}"/> objects represent the same event; otherwise, <c>false</c>.</returns>
-        public static bool operator ==(EventPattern<TSender, TEventArgs> first, EventPattern<TSender, TEventArgs> second)
-        {
-            return object.Equals(first, second);
-        }
+        public static bool operator ==(EventPattern<TSender, TEventArgs> first, EventPattern<TSender, TEventArgs> second) => Equals(first, second);
 
 
         /// <summary>
         /// <summary>
         /// Determines whether two specified <see cref="EventPattern{TSender, TEventArgs}"/> objects represent a different event.
         /// Determines whether two specified <see cref="EventPattern{TSender, TEventArgs}"/> objects represent a different event.
@@ -104,9 +101,6 @@ namespace System.Reactive
         /// <param name="first">The first <see cref="EventPattern{TSender, TEventArgs}"/> to compare, or <c>null</c>.</param>
         /// <param name="first">The first <see cref="EventPattern{TSender, TEventArgs}"/> to compare, or <c>null</c>.</param>
         /// <param name="second">The second <see cref="EventPattern{TSender, TEventArgs}"/> to compare, or <c>null</c>.</param>
         /// <param name="second">The second <see cref="EventPattern{TSender, TEventArgs}"/> to compare, or <c>null</c>.</param>
         /// <returns><c>true</c> if both <see cref="EventPattern{TSender, TEventArgs}"/> objects don't represent the same event; otherwise, <c>false</c>.</returns>
         /// <returns><c>true</c> if both <see cref="EventPattern{TSender, TEventArgs}"/> objects don't represent the same event; otherwise, <c>false</c>.</returns>
-        public static bool operator !=(EventPattern<TSender, TEventArgs> first, EventPattern<TSender, TEventArgs> second)
-        {
-            return !object.Equals(first, second);
-        }
+        public static bool operator !=(EventPattern<TSender, TEventArgs> first, EventPattern<TSender, TEventArgs> second) => Equals(first, second);
     }
     }
 }
 }

+ 1 - 1
Rx.NET/Source/src/System.Reactive/EventPatternSource.cs

@@ -4,7 +4,7 @@
 
 
 namespace System.Reactive
 namespace System.Reactive
 {
 {
-    class EventPatternSource<TEventArgs> : EventPatternSourceBase<object, TEventArgs>, IEventPatternSource<TEventArgs>
+    internal sealed class EventPatternSource<TEventArgs> : EventPatternSourceBase<object, TEventArgs>, IEventPatternSource<TEventArgs>
     {
     {
         public EventPatternSource(IObservable<EventPattern<object, TEventArgs>> source, Action<Action<object, TEventArgs>, /*object,*/ EventPattern<object, TEventArgs>> invokeHandler)
         public EventPatternSource(IObservable<EventPattern<object, TEventArgs>> source, Action<Action<object, TEventArgs>, /*object,*/ EventPattern<object, TEventArgs>> invokeHandler)
             : base(source, invokeHandler)
             : base(source, invokeHandler)

+ 16 - 8
Rx.NET/Source/src/System.Reactive/EventPatternSourceBase.cs

@@ -24,7 +24,7 @@ namespace System.Reactive
         /// </summary>
         /// </summary>
         /// <param name="source">Source sequence to expose as an event.</param>
         /// <param name="source">Source sequence to expose as an event.</param>
         /// <param name="invokeHandler">Delegate used to invoke the event for each element of the sequence.</param>
         /// <param name="invokeHandler">Delegate used to invoke the event for each element of the sequence.</param>
-        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="invokeHandler"/> is null.</exception>
+        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="invokeHandler"/> is <c>null</c>.</exception>
         protected EventPatternSourceBase(IObservable<EventPattern<TSender, TEventArgs>> source, Action<Action<TSender, TEventArgs>, /*object,*/ EventPattern<TSender, TEventArgs>> invokeHandler)
         protected EventPatternSourceBase(IObservable<EventPattern<TSender, TEventArgs>> source, Action<Action<TSender, TEventArgs>, /*object,*/ EventPattern<TSender, TEventArgs>> invokeHandler)
         {
         {
             if (source == null)
             if (source == null)
@@ -40,9 +40,9 @@ namespace System.Reactive
         /// <summary>
         /// <summary>
         /// Adds the specified event handler, causing a subscription to the underlying source.
         /// Adds the specified event handler, causing a subscription to the underlying source.
         /// </summary>
         /// </summary>
-        /// <param name="handler">Event handler to add. The same delegate should be passed to the Remove operation in order to remove the event handler.</param>
+        /// <param name="handler">Event handler to add. The same delegate should be passed to the <see cref="Remove(Delegate)"/> operation in order to remove the event handler.</param>
         /// <param name="invoke">Invocation delegate to raise the event in the derived class.</param>
         /// <param name="invoke">Invocation delegate to raise the event in the derived class.</param>
-        /// <exception cref="ArgumentNullException"><paramref name="handler"/> or <paramref name="invoke"/> is null.</exception>
+        /// <exception cref="ArgumentNullException"><paramref name="handler"/> or <paramref name="invoke"/> is <c>null</c>.</exception>
         protected void Add(Delegate handler, Action<TSender, TEventArgs> invoke)
         protected void Add(Delegate handler, Action<TSender, TEventArgs> invoke)
         {
         {
             if (handler == null)
             if (handler == null)
@@ -59,9 +59,13 @@ namespace System.Reactive
                 lock (gate)
                 lock (gate)
                 {
                 {
                     if (isAdded)
                     if (isAdded)
+                    {
                         Remove(handler);
                         Remove(handler);
+                    }
                     else
                     else
+                    {
                         isDone = true;
                         isDone = true;
+                    }
                 }
                 }
             });
             });
 
 
@@ -90,17 +94,19 @@ namespace System.Reactive
             {
             {
                 var l = new Stack<IDisposable>();
                 var l = new Stack<IDisposable>();
                 if (!_subscriptions.TryGetValue(handler, out l))
                 if (!_subscriptions.TryGetValue(handler, out l))
+                {
                     _subscriptions[handler] = l = new Stack<IDisposable>();
                     _subscriptions[handler] = l = new Stack<IDisposable>();
+                }
 
 
                 l.Push(disposable);
                 l.Push(disposable);
             }
             }
         }
         }
 
 
         /// <summary>
         /// <summary>
-        /// Removes the specified event handler, causing a disposal of the corresponding subscription to the underlying source that was created during the Add operation.
+        /// Removes the specified event handler, causing a disposal of the corresponding subscription to the underlying source that was created during the <see cref="Add(Delegate, Action{TSender, TEventArgs})"/> operation.
         /// </summary>
         /// </summary>
-        /// <param name="handler">Event handler to remove. This should be the same delegate as one that was passed to the Add operation.</param>
-        /// <exception cref="ArgumentNullException"><paramref name="handler"/> is null.</exception>
+        /// <param name="handler">Event handler to remove. This should be the same delegate as one that was passed to the <see cref="Add(Delegate, Action{TSender, TEventArgs})"/> operation.</param>
+        /// <exception cref="ArgumentNullException"><paramref name="handler"/> is <c>null</c>.</exception>
         protected void Remove(Delegate handler)
         protected void Remove(Delegate handler)
         {
         {
             if (handler == null)
             if (handler == null)
@@ -114,13 +120,15 @@ namespace System.Reactive
                 if (_subscriptions.TryGetValue(handler, out l))
                 if (_subscriptions.TryGetValue(handler, out l))
                 {
                 {
                     d = l.Pop();
                     d = l.Pop();
+
                     if (l.Count == 0)
                     if (l.Count == 0)
+                    {
                         _subscriptions.Remove(handler);
                         _subscriptions.Remove(handler);
+                    }
                 }
                 }
             }
             }
 
 
-            if (d != null)
-                d.Dispose();
+            d?.Dispose();
         }
         }
     }
     }
 }
 }

+ 11 - 3
Rx.NET/Source/src/System.Reactive/EventSource.cs

@@ -6,7 +6,7 @@ using System.Collections.Generic;
 
 
 namespace System.Reactive
 namespace System.Reactive
 {
 {
-    class EventSource<T> : IEventSource<T>
+    internal sealed class EventSource<T> : IEventSource<T>
     {
     {
         private readonly IObservable<T> _source;
         private readonly IObservable<T> _source;
         private readonly Dictionary<Delegate, Stack<IDisposable>> _subscriptions;
         private readonly Dictionary<Delegate, Stack<IDisposable>> _subscriptions;
@@ -32,9 +32,13 @@ namespace System.Reactive
                     lock (gate)
                     lock (gate)
                     {
                     {
                         if (isAdded)
                         if (isAdded)
+                        {
                             Remove(value);
                             Remove(value);
+                        }
                         else
                         else
+                        {
                             isDone = true;
                             isDone = true;
+                        }
                     }
                     }
                 });
                 });
 
 
@@ -69,7 +73,9 @@ namespace System.Reactive
             {
             {
                 var l = new Stack<IDisposable>();
                 var l = new Stack<IDisposable>();
                 if (!_subscriptions.TryGetValue(handler, out l))
                 if (!_subscriptions.TryGetValue(handler, out l))
+                {
                     _subscriptions[handler] = l = new Stack<IDisposable>();
                     _subscriptions[handler] = l = new Stack<IDisposable>();
+                }
 
 
                 l.Push(disposable);
                 l.Push(disposable);
             }
             }
@@ -85,13 +91,15 @@ namespace System.Reactive
                 if (_subscriptions.TryGetValue(handler, out l))
                 if (_subscriptions.TryGetValue(handler, out l))
                 {
                 {
                     d = l.Pop();
                     d = l.Pop();
+
                     if (l.Count == 0)
                     if (l.Count == 0)
+                    {
                         _subscriptions.Remove(handler);
                         _subscriptions.Remove(handler);
+                    }
                 }
                 }
             }
             }
 
 
-            if (d != null)
-                d.Dispose();
+            d?.Dispose();
         }
         }
     }
     }
 }
 }

+ 1 - 1
Rx.NET/Source/src/System.Reactive/ExcludeFromCodeCoverageAttribute.cs

@@ -12,4 +12,4 @@ namespace System.Diagnostics.CodeAnalysis
     }
     }
 }
 }
 
 
-#endif
+#endif

+ 13 - 10
Rx.NET/Source/src/System.Reactive/ListObservable.cs

@@ -10,6 +10,8 @@ using System.Reactive.Subjects;
 
 
 namespace System.Reactive
 namespace System.Reactive
 {
 {
+    // CONSIDER: Deprecate this functionality or invest in an asynchronous variant.
+
     /// <summary>
     /// <summary>
     /// Represents an object that retains the elements of the observable sequence and signals the end of the sequence.
     /// Represents an object that retains the elements of the observable sequence and signals the end of the sequence.
     /// </summary>
     /// </summary>
@@ -18,15 +20,15 @@ namespace System.Reactive
     [Experimental]
     [Experimental]
     public class ListObservable<T> : IList<T>, IObservable<object>
     public class ListObservable<T> : IList<T>, IObservable<object>
     {
     {
-        IDisposable subscription;
-        AsyncSubject<object> subject = new AsyncSubject<object>();
-        List<T> results = new List<T>();
+        private readonly IDisposable subscription;
+        private readonly AsyncSubject<object> subject = new AsyncSubject<object>();
+        private readonly List<T> results = new List<T>();
 
 
         /// <summary>
         /// <summary>
         /// Constructs an object that retains the values of source and signals the end of the sequence.
         /// Constructs an object that retains the values of source and signals the end of the sequence.
         /// </summary>
         /// </summary>
         /// <param name="source">The observable sequence whose elements will be retained in the list.</param>
         /// <param name="source">The observable sequence whose elements will be retained in the list.</param>
-        /// <exception cref="ArgumentNullException"><paramref name="source"/> is null.</exception>
+        /// <exception cref="ArgumentNullException"><paramref name="source"/> is <c>null</c>.</exception>
         public ListObservable(IObservable<T> source)
         public ListObservable(IObservable<T> source)
         {
         {
             if (source == null)
             if (source == null)
@@ -35,7 +37,7 @@ namespace System.Reactive
             subscription = source.Subscribe(results.Add, subject.OnError, subject.OnCompleted);
             subscription = source.Subscribe(results.Add, subject.OnError, subject.OnCompleted);
         }
         }
 
 
-        void Wait()
+        private void Wait()
         {
         {
             subject.DefaultIfEmpty().Wait();
             subject.DefaultIfEmpty().Wait();
         }
         }
@@ -48,8 +50,12 @@ namespace System.Reactive
             get
             get
             {
             {
                 Wait();
                 Wait();
+
                 if (results.Count == 0)
                 if (results.Count == 0)
+                {
                     throw new InvalidOperationException(Strings_Linq.NO_ELEMENTS);
                     throw new InvalidOperationException(Strings_Linq.NO_ELEMENTS);
+                }
+
                 return results[results.Count - 1];
                 return results[results.Count - 1];
             }
             }
         }
         }
@@ -185,17 +191,14 @@ namespace System.Reactive
             return results.GetEnumerator();
             return results.GetEnumerator();
         }
         }
 
 
-        IEnumerator IEnumerable.GetEnumerator()
-        {
-            return this.GetEnumerator();
-        }
+        IEnumerator IEnumerable.GetEnumerator() => GetEnumerator();
 
 
         /// <summary>
         /// <summary>
         /// Subscribes an observer to the ListObservable which will be notified upon completion.
         /// Subscribes an observer to the ListObservable which will be notified upon completion.
         /// </summary>
         /// </summary>
         /// <param name="observer">The observer to send completion or error messages to.</param>
         /// <param name="observer">The observer to send completion or error messages to.</param>
         /// <returns>The disposable resource that can be used to unsubscribe.</returns>
         /// <returns>The disposable resource that can be used to unsubscribe.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="observer"/> is null.</exception>
+        /// <exception cref="ArgumentNullException"><paramref name="observer"/> is <c>null</c>.</exception>
         public IDisposable Subscribe(IObserver<object> observer)
         public IDisposable Subscribe(IObserver<object> observer)
         {
         {
             if (observer == null)
             if (observer == null)

+ 7 - 7
Rx.NET/Source/src/System.Reactive/NamespaceDocs.cs

@@ -7,7 +7,7 @@ namespace System.Reactive
     /// <summary>
     /// <summary>
     /// The <b>System.Reactive</b> namespace contains interfaces and classes used throughout the Reactive Extensions library.
     /// The <b>System.Reactive</b> namespace contains interfaces and classes used throughout the Reactive Extensions library.
     /// </summary>
     /// </summary>
-    [System.Runtime.CompilerServices.CompilerGeneratedAttribute]
+    [System.Runtime.CompilerServices.CompilerGenerated]
     class NamespaceDoc
     class NamespaceDoc
     {
     {
     }
     }
@@ -20,7 +20,7 @@ namespace System.Reactive.Concurrency
     /// process event streams. Schedulers are used to parameterize the concurrency introduced by query operators, provide means to virtualize time, to process historical data,
     /// process event streams. Schedulers are used to parameterize the concurrency introduced by query operators, provide means to virtualize time, to process historical data,
     /// and to write unit tests for functionality built using Reactive Extensions constructs.
     /// and to write unit tests for functionality built using Reactive Extensions constructs.
     /// </summary>
     /// </summary>
-    [System.Runtime.CompilerServices.CompilerGeneratedAttribute]
+    [System.Runtime.CompilerServices.CompilerGenerated]
     class NamespaceDoc
     class NamespaceDoc
     {
     {
     }
     }
@@ -33,7 +33,7 @@ namespace System.Reactive.Disposables
     /// management in Reactive Extensions. Those types are used extensively within the implementation of Reactive Extensions and are useful when writing custom query operators or
     /// management in Reactive Extensions. Those types are used extensively within the implementation of Reactive Extensions and are useful when writing custom query operators or
     /// schedulers.
     /// schedulers.
     /// </summary>
     /// </summary>
-    [System.Runtime.CompilerServices.CompilerGeneratedAttribute]
+    [System.Runtime.CompilerServices.CompilerGenerated]
     class NamespaceDoc
     class NamespaceDoc
     {
     {
     }
     }
@@ -45,7 +45,7 @@ namespace System.Reactive.Linq
     /// The <b>System.Reactive.Linq</b> namespace contains interfaces and classes that support expressing queries over observable sequences, using Language Integrated Query (LINQ).
     /// The <b>System.Reactive.Linq</b> namespace contains interfaces and classes that support expressing queries over observable sequences, using Language Integrated Query (LINQ).
     /// Query operators are made available as extension methods for <see cref="IObservable{T}"/> and <see cref="IQbservable{T}"/> defined on the Observable and Qbservable classes, respectively.
     /// Query operators are made available as extension methods for <see cref="IObservable{T}"/> and <see cref="IQbservable{T}"/> defined on the Observable and Qbservable classes, respectively.
     /// </summary>
     /// </summary>
-    [System.Runtime.CompilerServices.CompilerGeneratedAttribute]
+    [System.Runtime.CompilerServices.CompilerGenerated]
     class NamespaceDoc
     class NamespaceDoc
     {
     {
     }
     }
@@ -58,7 +58,7 @@ namespace System.Reactive.Subjects
     /// Subjects are often used as sources of events, allowing one party to raise events and allowing another party to write queries over the event stream. Because of their ability to
     /// Subjects are often used as sources of events, allowing one party to raise events and allowing another party to write queries over the event stream. Because of their ability to
     /// have multiple registered observers, subjects are also used as a facility to provide multicast behavior for event streams in queries.
     /// have multiple registered observers, subjects are also used as a facility to provide multicast behavior for event streams in queries.
     /// </summary>
     /// </summary>
-    [System.Runtime.CompilerServices.CompilerGeneratedAttribute]
+    [System.Runtime.CompilerServices.CompilerGenerated]
     class NamespaceDoc
     class NamespaceDoc
     {
     {
     }
     }
@@ -70,7 +70,7 @@ namespace System.Reactive.PlatformServices
     /// The <b>System.Reactive.PlatformServices</b> namespace contains interfaces and classes used by the runtime infrastructure of Reactive Extensions.
     /// The <b>System.Reactive.PlatformServices</b> namespace contains interfaces and classes used by the runtime infrastructure of Reactive Extensions.
     /// Those are not intended to be used directly from user code and are subject to change in future releases of the product.
     /// Those are not intended to be used directly from user code and are subject to change in future releases of the product.
     /// </summary>
     /// </summary>
-    [System.Runtime.CompilerServices.CompilerGeneratedAttribute]
+    [System.Runtime.CompilerServices.CompilerGenerated]
     class NamespaceDoc
     class NamespaceDoc
     {
     {
     }
     }
@@ -81,7 +81,7 @@ namespace System.Reactive.Joins
     /// <summary>
     /// <summary>
     /// The <b>System.Reactive.Joins</b> namespace contains classes used to express join patterns over observable sequences using fluent method syntax.
     /// The <b>System.Reactive.Joins</b> namespace contains classes used to express join patterns over observable sequences using fluent method syntax.
     /// </summary>
     /// </summary>
-    [System.Runtime.CompilerServices.CompilerGeneratedAttribute]
+    [System.Runtime.CompilerServices.CompilerGenerated]
     class NamespaceDoc
     class NamespaceDoc
     {
     {
     }
     }

+ 24 - 18
Rx.NET/Source/src/System.Reactive/Notification.cs

@@ -119,12 +119,13 @@ namespace System.Reactive
             /// </summary>
             /// </summary>
             public override bool Equals(Notification<T> other)
             public override bool Equals(Notification<T> other)
             {
             {
-                if (Object.ReferenceEquals(this, other))
+                if (ReferenceEquals(this, other))
                     return true;
                     return true;
-                if (Object.ReferenceEquals(other, null))
+                if (ReferenceEquals(other, null))
                     return false;
                     return false;
                 if (other.Kind != NotificationKind.OnNext)
                 if (other.Kind != NotificationKind.OnNext)
                     return false;
                     return false;
+
                 return EqualityComparer<T>.Default.Equals(Value, other.Value);
                 return EqualityComparer<T>.Default.Equals(Value, other.Value);
             }
             }
 
 
@@ -245,13 +246,14 @@ namespace System.Reactive
             /// </summary>
             /// </summary>
             public override bool Equals(Notification<T> other)
             public override bool Equals(Notification<T> other)
             {
             {
-                if (Object.ReferenceEquals(this, other))
+                if (ReferenceEquals(this, other))
                     return true;
                     return true;
-                if (Object.ReferenceEquals(other, null))
+                if (ReferenceEquals(other, null))
                     return false;
                     return false;
                 if (other.Kind != NotificationKind.OnError)
                 if (other.Kind != NotificationKind.OnError)
                     return false;
                     return false;
-                return Object.Equals(Exception, other.Exception);
+
+                return Equals(Exception, other.Exception);
             }
             }
 
 
             /// <summary>
             /// <summary>
@@ -370,10 +372,11 @@ namespace System.Reactive
             /// </summary>
             /// </summary>
             public override bool Equals(Notification<T> other)
             public override bool Equals(Notification<T> other)
             {
             {
-                if (Object.ReferenceEquals(this, other))
+                if (ReferenceEquals(this, other))
                     return true;
                     return true;
-                if (Object.ReferenceEquals(other, null))
+                if (ReferenceEquals(other, null))
                     return false;
                     return false;
+
                 return other.Kind == NotificationKind.OnCompleted;
                 return other.Kind == NotificationKind.OnCompleted;
             }
             }
 
 
@@ -449,7 +452,7 @@ namespace System.Reactive
         /// Determines whether the current <see cref="Notification{T}"/> object has the same observer message payload as a specified <see cref="Notification{T}"/> value.
         /// Determines whether the current <see cref="Notification{T}"/> object has the same observer message payload as a specified <see cref="Notification{T}"/> value.
         /// </summary>
         /// </summary>
         /// <param name="other">An object to compare to the current <see cref="Notification{T}"/> object.</param>
         /// <param name="other">An object to compare to the current <see cref="Notification{T}"/> object.</param>
-        /// <returns>true if both <see cref="Notification{T}"/> objects have the same observer message payload; otherwise, false.</returns>
+        /// <returns><c>true</c> if both <see cref="Notification{T}"/> objects have the same observer message payload; otherwise, <c>false</c>.</returns>
         /// <remarks>
         /// <remarks>
         /// Equality of <see cref="Notification{T}"/> objects is based on the equality of the observer message payload they represent, including the notification Kind and the Value or Exception (if any).
         /// Equality of <see cref="Notification{T}"/> objects is based on the equality of the observer message payload they represent, including the notification Kind and the Value or Exception (if any).
         /// This means two <see cref="Notification{T}"/> objects can be equal even though they don't represent the same observer method call, but have the same Kind and have equal parameters passed to the observer method.
         /// This means two <see cref="Notification{T}"/> objects can be equal even though they don't represent the same observer method call, but have the same Kind and have equal parameters passed to the observer method.
@@ -460,9 +463,9 @@ namespace System.Reactive
         /// <summary>
         /// <summary>
         /// Determines whether the two specified <see cref="Notification{T}"/> objects have the same observer message payload.
         /// Determines whether the two specified <see cref="Notification{T}"/> objects have the same observer message payload.
         /// </summary>
         /// </summary>
-        /// <param name="left">The first <see cref="Notification{T}"/> to compare, or null.</param>
-        /// <param name="right">The second <see cref="Notification{T}"/> to compare, or null.</param>
-        /// <returns>true if the first <see cref="Notification{T}"/> value has the same observer message payload as the second <see cref="Notification{T}"/> value; otherwise, false.</returns>
+        /// <param name="left">The first <see cref="Notification{T}"/> to compare, or <c>null</c>.</param>
+        /// <param name="right">The second <see cref="Notification{T}"/> to compare, or <c>null</c>.</param>
+        /// <returns><c>true</c> if the first <see cref="Notification{T}"/> value has the same observer message payload as the second <see cref="Notification{T}"/> value; otherwise, <c>false</c>.</returns>
         /// <remarks>
         /// <remarks>
         /// Equality of <see cref="Notification{T}"/> objects is based on the equality of the observer message payload they represent, including the notification Kind and the Value or Exception (if any).
         /// Equality of <see cref="Notification{T}"/> objects is based on the equality of the observer message payload they represent, including the notification Kind and the Value or Exception (if any).
         /// This means two <see cref="Notification{T}"/> objects can be equal even though they don't represent the same observer method call, but have the same Kind and have equal parameters passed to the observer method.
         /// This means two <see cref="Notification{T}"/> objects can be equal even though they don't represent the same observer method call, but have the same Kind and have equal parameters passed to the observer method.
@@ -470,7 +473,7 @@ namespace System.Reactive
         /// </remarks>
         /// </remarks>
         public static bool operator ==(Notification<T> left, Notification<T> right)
         public static bool operator ==(Notification<T> left, Notification<T> right)
         {
         {
-            if (object.ReferenceEquals(left, right))
+            if (ReferenceEquals(left, right))
                 return true;
                 return true;
 
 
             if ((object)left == null || (object)right == null)
             if ((object)left == null || (object)right == null)
@@ -482,9 +485,9 @@ namespace System.Reactive
         /// <summary>
         /// <summary>
         /// Determines whether the two specified <see cref="Notification{T}"/> objects have a different observer message payload.
         /// Determines whether the two specified <see cref="Notification{T}"/> objects have a different observer message payload.
         /// </summary>
         /// </summary>
-        /// <param name="left">The first <see cref="Notification{T}"/> to compare, or null.</param>
-        /// <param name="right">The second <see cref="Notification{T}"/> to compare, or null.</param>
-        /// <returns>true if the first <see cref="Notification{T}"/> value has a different observer message payload as the second <see cref="Notification{T}"/> value; otherwise, false.</returns>
+        /// <param name="left">The first <see cref="Notification{T}"/> to compare, or <c>null</c>.</param>
+        /// <param name="right">The second <see cref="Notification{T}"/> to compare, or <c>null</c>.</param>
+        /// <returns><c>true</c> if the first <see cref="Notification{T}"/> value has a different observer message payload as the second <see cref="Notification{T}"/> value; otherwise, <c>false</c>.</returns>
         /// <remarks>
         /// <remarks>
         /// Equality of <see cref="Notification{T}"/> objects is based on the equality of the observer message payload they represent, including the notification Kind and the Value or Exception (if any).
         /// Equality of <see cref="Notification{T}"/> objects is based on the equality of the observer message payload they represent, including the notification Kind and the Value or Exception (if any).
         /// This means two <see cref="Notification{T}"/> objects can be equal even though they don't represent the same observer method call, but have the same Kind and have equal parameters passed to the observer method.
         /// This means two <see cref="Notification{T}"/> objects can be equal even though they don't represent the same observer method call, but have the same Kind and have equal parameters passed to the observer method.
@@ -496,7 +499,7 @@ namespace System.Reactive
         /// Determines whether the specified System.Object is equal to the current <see cref="Notification{T}"/>.
         /// Determines whether the specified System.Object is equal to the current <see cref="Notification{T}"/>.
         /// </summary>
         /// </summary>
         /// <param name="obj">The System.Object to compare with the current <see cref="Notification{T}"/>.</param>
         /// <param name="obj">The System.Object to compare with the current <see cref="Notification{T}"/>.</param>
-        /// <returns>true if the specified System.Object is equal to the current <see cref="Notification{T}"/>; otherwise, false.</returns>
+        /// <returns><c>true</c> if the specified System.Object is equal to the current <see cref="Notification{T}"/>; otherwise, <c>false</c>.</returns>
         /// <remarks>
         /// <remarks>
         /// Equality of <see cref="Notification{T}"/> objects is based on the equality of the observer message payload they represent, including the notification Kind and the Value or Exception (if any).
         /// Equality of <see cref="Notification{T}"/> objects is based on the equality of the observer message payload they represent, including the notification Kind and the Value or Exception (if any).
         /// This means two <see cref="Notification{T}"/> objects can be equal even though they don't represent the same observer method call, but have the same Kind and have equal parameters passed to the observer method.
         /// This means two <see cref="Notification{T}"/> objects can be equal even though they don't represent the same observer method call, but have the same Kind and have equal parameters passed to the observer method.
@@ -554,9 +557,12 @@ namespace System.Reactive
 
 
             return new AnonymousObservable<T>(observer => scheduler.Schedule(() =>
             return new AnonymousObservable<T>(observer => scheduler.Schedule(() =>
             {
             {
-                this.Accept(observer);
-                if (this.Kind == NotificationKind.OnNext)
+                Accept(observer);
+
+                if (Kind == NotificationKind.OnNext)
+                {
                     observer.OnCompleted();
                     observer.OnCompleted();
+                }
             }));
             }));
         }
         }
     }
     }

+ 34 - 26
Rx.NET/Source/src/System.Reactive/Observable.Extensions.cs

@@ -22,8 +22,8 @@ namespace System
         /// </summary>
         /// </summary>
         /// <typeparam name="T">The type of the elements in the source sequence.</typeparam>
         /// <typeparam name="T">The type of the elements in the source sequence.</typeparam>
         /// <param name="source">Observable sequence to subscribe to.</param>
         /// <param name="source">Observable sequence to subscribe to.</param>
-        /// <returns>IDisposable object used to unsubscribe from the observable sequence.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="source"/> is null.</exception>
+        /// <returns><see cref="IDisposable"/> object used to unsubscribe from the observable sequence.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source"/> is <c>null</c>.</exception>
         public static IDisposable Subscribe<T>(this IObservable<T> source)
         public static IDisposable Subscribe<T>(this IObservable<T> source)
         {
         {
             if (source == null)
             if (source == null)
@@ -41,8 +41,8 @@ namespace System
         /// <typeparam name="T">The type of the elements in the source sequence.</typeparam>
         /// <typeparam name="T">The type of the elements in the source sequence.</typeparam>
         /// <param name="source">Observable sequence to subscribe to.</param>
         /// <param name="source">Observable sequence to subscribe to.</param>
         /// <param name="onNext">Action to invoke for each element in the observable sequence.</param>
         /// <param name="onNext">Action to invoke for each element in the observable sequence.</param>
-        /// <returns>IDisposable object used to unsubscribe from the observable sequence.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="onNext"/> is null.</exception>
+        /// <returns><see cref="IDisposable"/> object used to unsubscribe from the observable sequence.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="onNext"/> is <c>null</c>.</exception>
         public static IDisposable Subscribe<T>(this IObservable<T> source, Action<T> onNext)
         public static IDisposable Subscribe<T>(this IObservable<T> source, Action<T> onNext)
         {
         {
             if (source == null)
             if (source == null)
@@ -63,8 +63,8 @@ namespace System
         /// <param name="source">Observable sequence to subscribe to.</param>
         /// <param name="source">Observable sequence to subscribe to.</param>
         /// <param name="onNext">Action to invoke for each element in the observable sequence.</param>
         /// <param name="onNext">Action to invoke for each element in the observable sequence.</param>
         /// <param name="onError">Action to invoke upon exceptional termination of the observable sequence.</param>
         /// <param name="onError">Action to invoke upon exceptional termination of the observable sequence.</param>
-        /// <returns>IDisposable object used to unsubscribe from the observable sequence.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="onNext"/> or <paramref name="onError"/> is null.</exception>
+        /// <returns><see cref="IDisposable"/> object used to unsubscribe from the observable sequence.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="onNext"/> or <paramref name="onError"/> is <c>null</c>.</exception>
         public static IDisposable Subscribe<T>(this IObservable<T> source, Action<T> onNext, Action<Exception> onError)
         public static IDisposable Subscribe<T>(this IObservable<T> source, Action<T> onNext, Action<Exception> onError)
         {
         {
             if (source == null)
             if (source == null)
@@ -87,8 +87,8 @@ namespace System
         /// <param name="source">Observable sequence to subscribe to.</param>
         /// <param name="source">Observable sequence to subscribe to.</param>
         /// <param name="onNext">Action to invoke for each element in the observable sequence.</param>
         /// <param name="onNext">Action to invoke for each element in the observable sequence.</param>
         /// <param name="onCompleted">Action to invoke upon graceful termination of the observable sequence.</param>
         /// <param name="onCompleted">Action to invoke upon graceful termination of the observable sequence.</param>
-        /// <returns>IDisposable object used to unsubscribe from the observable sequence.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="onNext"/> or <paramref name="onCompleted"/> is null.</exception>
+        /// <returns><see cref="IDisposable"/> object used to unsubscribe from the observable sequence.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="onNext"/> or <paramref name="onCompleted"/> is <c>null</c>.</exception>
         public static IDisposable Subscribe<T>(this IObservable<T> source, Action<T> onNext, Action onCompleted)
         public static IDisposable Subscribe<T>(this IObservable<T> source, Action<T> onNext, Action onCompleted)
         {
         {
             if (source == null)
             if (source == null)
@@ -112,8 +112,8 @@ namespace System
         /// <param name="onNext">Action to invoke for each element in the observable sequence.</param>
         /// <param name="onNext">Action to invoke for each element in the observable sequence.</param>
         /// <param name="onError">Action to invoke upon exceptional termination of the observable sequence.</param>
         /// <param name="onError">Action to invoke upon exceptional termination of the observable sequence.</param>
         /// <param name="onCompleted">Action to invoke upon graceful termination of the observable sequence.</param>
         /// <param name="onCompleted">Action to invoke upon graceful termination of the observable sequence.</param>
-        /// <returns>IDisposable object used to unsubscribe from the observable sequence.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="onNext"/> or <paramref name="onError"/> or <paramref name="onCompleted"/> is null.</exception>
+        /// <returns><see cref="IDisposable"/> object used to unsubscribe from the observable sequence.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="onNext"/> or <paramref name="onError"/> or <paramref name="onCompleted"/> is <c>null</c>.</exception>
         public static IDisposable Subscribe<T>(this IObservable<T> source, Action<T> onNext, Action<Exception> onError, Action onCompleted)
         public static IDisposable Subscribe<T>(this IObservable<T> source, Action<T> onNext, Action<Exception> onError, Action onCompleted)
         {
         {
             if (source == null)
             if (source == null)
@@ -136,13 +136,13 @@ namespace System
         #region Subscribe overloads with CancellationToken
         #region Subscribe overloads with CancellationToken
 
 
         /// <summary>
         /// <summary>
-        /// Subscribes an observer to an observable sequence, using a CancellationToken to support unsubscription.
+        /// Subscribes an observer to an observable sequence, using a <see cref="CancellationToken"/> to support unsubscription.
         /// </summary>
         /// </summary>
         /// <typeparam name="T">The type of the elements in the source sequence.</typeparam>
         /// <typeparam name="T">The type of the elements in the source sequence.</typeparam>
         /// <param name="source">Observable sequence to subscribe to.</param>
         /// <param name="source">Observable sequence to subscribe to.</param>
         /// <param name="observer">Observer to subscribe to the sequence.</param>
         /// <param name="observer">Observer to subscribe to the sequence.</param>
         /// <param name="token">CancellationToken that can be signaled to unsubscribe from the source sequence.</param>
         /// <param name="token">CancellationToken that can be signaled to unsubscribe from the source sequence.</param>
-        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="observer"/> is null.</exception>
+        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="observer"/> is <c>null</c>.</exception>
         public static void Subscribe<T>(this IObservable<T> source, IObserver<T> observer, CancellationToken token)
         public static void Subscribe<T>(this IObservable<T> source, IObserver<T> observer, CancellationToken token)
         {
         {
             if (source == null)
             if (source == null)
@@ -154,13 +154,13 @@ namespace System
         }
         }
 
 
         /// <summary>
         /// <summary>
-        /// Subscribes to the observable sequence without specifying any handlers, using a CancellationToken to support unsubscription.
+        /// Subscribes to the observable sequence without specifying any handlers, using a <see cref="CancellationToken"/> to support unsubscription.
         /// This method can be used to evaluate the observable sequence for its side-effects only.
         /// This method can be used to evaluate the observable sequence for its side-effects only.
         /// </summary>
         /// </summary>
         /// <typeparam name="T">The type of the elements in the source sequence.</typeparam>
         /// <typeparam name="T">The type of the elements in the source sequence.</typeparam>
         /// <param name="source">Observable sequence to subscribe to.</param>
         /// <param name="source">Observable sequence to subscribe to.</param>
         /// <param name="token">CancellationToken that can be signaled to unsubscribe from the source sequence.</param>
         /// <param name="token">CancellationToken that can be signaled to unsubscribe from the source sequence.</param>
-        /// <exception cref="ArgumentNullException"><paramref name="source"/> is null.</exception>
+        /// <exception cref="ArgumentNullException"><paramref name="source"/> is <c>null</c>.</exception>
         public static void Subscribe<T>(this IObservable<T> source, CancellationToken token)
         public static void Subscribe<T>(this IObservable<T> source, CancellationToken token)
         {
         {
             if (source == null)
             if (source == null)
@@ -170,13 +170,13 @@ namespace System
         }
         }
 
 
         /// <summary>
         /// <summary>
-        /// Subscribes an element handler to an observable sequence, using a CancellationToken to support unsubscription.
+        /// Subscribes an element handler to an observable sequence, using a <see cref="CancellationToken"/> to support unsubscription.
         /// </summary>
         /// </summary>
         /// <typeparam name="T">The type of the elements in the source sequence.</typeparam>
         /// <typeparam name="T">The type of the elements in the source sequence.</typeparam>
         /// <param name="source">Observable sequence to subscribe to.</param>
         /// <param name="source">Observable sequence to subscribe to.</param>
         /// <param name="onNext">Action to invoke for each element in the observable sequence.</param>
         /// <param name="onNext">Action to invoke for each element in the observable sequence.</param>
         /// <param name="token">CancellationToken that can be signaled to unsubscribe from the source sequence.</param>
         /// <param name="token">CancellationToken that can be signaled to unsubscribe from the source sequence.</param>
-        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="onNext"/> is null.</exception>
+        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="onNext"/> is <c>null</c>.</exception>
         public static void Subscribe<T>(this IObservable<T> source, Action<T> onNext, CancellationToken token)
         public static void Subscribe<T>(this IObservable<T> source, Action<T> onNext, CancellationToken token)
         {
         {
             if (source == null)
             if (source == null)
@@ -188,14 +188,14 @@ namespace System
         }
         }
 
 
         /// <summary>
         /// <summary>
-        /// Subscribes an element handler and an exception handler to an observable sequence, using a CancellationToken to support unsubscription.
+        /// Subscribes an element handler and an exception handler to an observable sequence, using a <see cref="CancellationToken"/> to support unsubscription.
         /// </summary>
         /// </summary>
         /// <typeparam name="T">The type of the elements in the source sequence.</typeparam>
         /// <typeparam name="T">The type of the elements in the source sequence.</typeparam>
         /// <param name="source">Observable sequence to subscribe to.</param>
         /// <param name="source">Observable sequence to subscribe to.</param>
         /// <param name="onNext">Action to invoke for each element in the observable sequence.</param>
         /// <param name="onNext">Action to invoke for each element in the observable sequence.</param>
         /// <param name="onError">Action to invoke upon exceptional termination of the observable sequence.</param>
         /// <param name="onError">Action to invoke upon exceptional termination of the observable sequence.</param>
         /// <param name="token">CancellationToken that can be signaled to unsubscribe from the source sequence.</param>
         /// <param name="token">CancellationToken that can be signaled to unsubscribe from the source sequence.</param>
-        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="onNext"/> or <paramref name="onError"/> is null.</exception>
+        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="onNext"/> or <paramref name="onError"/> is <c>null</c>.</exception>
         public static void Subscribe<T>(this IObservable<T> source, Action<T> onNext, Action<Exception> onError, CancellationToken token)
         public static void Subscribe<T>(this IObservable<T> source, Action<T> onNext, Action<Exception> onError, CancellationToken token)
         {
         {
             if (source == null)
             if (source == null)
@@ -209,14 +209,14 @@ namespace System
         }
         }
 
 
         /// <summary>
         /// <summary>
-        /// Subscribes an element handler and a completion handler to an observable sequence, using a CancellationToken to support unsubscription.
+        /// Subscribes an element handler and a completion handler to an observable sequence, using a <see cref="CancellationToken"/> to support unsubscription.
         /// </summary>
         /// </summary>
         /// <typeparam name="T">The type of the elements in the source sequence.</typeparam>
         /// <typeparam name="T">The type of the elements in the source sequence.</typeparam>
         /// <param name="source">Observable sequence to subscribe to.</param>
         /// <param name="source">Observable sequence to subscribe to.</param>
         /// <param name="onNext">Action to invoke for each element in the observable sequence.</param>
         /// <param name="onNext">Action to invoke for each element in the observable sequence.</param>
         /// <param name="onCompleted">Action to invoke upon graceful termination of the observable sequence.</param>
         /// <param name="onCompleted">Action to invoke upon graceful termination of the observable sequence.</param>
         /// <param name="token">CancellationToken that can be signaled to unsubscribe from the source sequence.</param>
         /// <param name="token">CancellationToken that can be signaled to unsubscribe from the source sequence.</param>
-        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="onNext"/> or <paramref name="onCompleted"/> is null.</exception>
+        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="onNext"/> or <paramref name="onCompleted"/> is <c>null</c>.</exception>
         public static void Subscribe<T>(this IObservable<T> source, Action<T> onNext, Action onCompleted, CancellationToken token)
         public static void Subscribe<T>(this IObservable<T> source, Action<T> onNext, Action onCompleted, CancellationToken token)
         {
         {
             if (source == null)
             if (source == null)
@@ -230,7 +230,7 @@ namespace System
         }
         }
 
 
         /// <summary>
         /// <summary>
-        /// Subscribes an element handler, an exception handler, and a completion handler to an observable sequence, using a CancellationToken to support unsubscription.
+        /// Subscribes an element handler, an exception handler, and a completion handler to an observable sequence, using a <see cref="CancellationToken"/> to support unsubscription.
         /// </summary>
         /// </summary>
         /// <typeparam name="T">The type of the elements in the source sequence.</typeparam>
         /// <typeparam name="T">The type of the elements in the source sequence.</typeparam>
         /// <param name="source">Observable sequence to subscribe to.</param>
         /// <param name="source">Observable sequence to subscribe to.</param>
@@ -238,7 +238,7 @@ namespace System
         /// <param name="onError">Action to invoke upon exceptional termination of the observable sequence.</param>
         /// <param name="onError">Action to invoke upon exceptional termination of the observable sequence.</param>
         /// <param name="onCompleted">Action to invoke upon graceful termination of the observable sequence.</param>
         /// <param name="onCompleted">Action to invoke upon graceful termination of the observable sequence.</param>
         /// <param name="token">CancellationToken that can be signaled to unsubscribe from the source sequence.</param>
         /// <param name="token">CancellationToken that can be signaled to unsubscribe from the source sequence.</param>
-        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="onNext"/> or <paramref name="onError"/> or <paramref name="onCompleted"/> is null.</exception>
+        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="onNext"/> or <paramref name="onError"/> or <paramref name="onCompleted"/> is <c>null</c>.</exception>
         public static void Subscribe<T>(this IObservable<T> source, Action<T> onNext, Action<Exception> onError, Action onCompleted, CancellationToken token)
         public static void Subscribe<T>(this IObservable<T> source, Action<T> onNext, Action<Exception> onError, Action onCompleted, CancellationToken token)
         {
         {
             if (source == null)
             if (source == null)
@@ -269,12 +269,16 @@ namespace System
                         ex =>
                         ex =>
                         {
                         {
                             using (r)
                             using (r)
+                            {
                                 observer.OnError(ex);
                                 observer.OnError(ex);
+                            }
                         },
                         },
                         () =>
                         () =>
                         {
                         {
                             using (r)
                             using (r)
+                            {
                                 observer.OnCompleted();
                                 observer.OnCompleted();
+                            }
                         }
                         }
                     );
                     );
 
 
@@ -292,14 +296,14 @@ namespace System
         #region SubscribeSafe
         #region SubscribeSafe
 
 
         /// <summary>
         /// <summary>
-        /// Subscribes to the specified source, re-routing synchronous exceptions during invocation of the Subscribe method to the observer's OnError channel.
+        /// Subscribes to the specified source, re-routing synchronous exceptions during invocation of the <see cref="IObservable{T}.Subscribe(IObserver{T})"/> method to the observer's <see cref="IObserver{T}.OnError(Exception)"/> channel.
         /// This method is typically used when writing query operators.
         /// This method is typically used when writing query operators.
         /// </summary>
         /// </summary>
         /// <typeparam name="T">The type of the elements in the source sequence.</typeparam>
         /// <typeparam name="T">The type of the elements in the source sequence.</typeparam>
         /// <param name="source">Observable sequence to subscribe to.</param>
         /// <param name="source">Observable sequence to subscribe to.</param>
         /// <param name="observer">Observer that will be passed to the observable sequence, and that will be used for exception propagation.</param>
         /// <param name="observer">Observer that will be passed to the observable sequence, and that will be used for exception propagation.</param>
-        /// <returns>IDisposable object used to unsubscribe from the observable sequence.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="observer"/> is null.</exception>
+        /// <returns><see cref="IDisposable"/> object used to unsubscribe from the observable sequence.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source"/> or <paramref name="observer"/> is <c>null</c>.</exception>
         [EditorBrowsable(EditorBrowsableState.Advanced)]
         [EditorBrowsable(EditorBrowsableState.Advanced)]
         public static IDisposable SubscribeSafe<T>(this IObservable<T> source, IObserver<T> observer)
         public static IDisposable SubscribeSafe<T>(this IObservable<T> source, IObserver<T> observer)
         {
         {
@@ -313,12 +317,16 @@ namespace System
             // for regular operation circumstances.
             // for regular operation circumstances.
             //
             //
             if (source is ObservableBase<T>)
             if (source is ObservableBase<T>)
+            {
                 return source.Subscribe(observer);
                 return source.Subscribe(observer);
+            }
 
 
 #if !NO_PERF
 #if !NO_PERF
             var producer = source as IProducer<T>;
             var producer = source as IProducer<T>;
             if (producer != null)
             if (producer != null)
-                return producer.SubscribeRaw(observer, false);
+            {
+                return producer.SubscribeRaw(observer, enableSafeguard: false);
+            }
 #endif
 #endif
 
 
             var d = Disposable.Empty;
             var d = Disposable.Empty;

+ 2 - 2
Rx.NET/Source/src/System.Reactive/ObservableBase.cs

@@ -23,14 +23,14 @@ namespace System.Reactive
         /// </summary>
         /// </summary>
         /// <param name="observer">Observer that will receive notifications from the observable sequence.</param>
         /// <param name="observer">Observer that will receive notifications from the observable sequence.</param>
         /// <returns>Disposable object representing an observer's subscription to the observable sequence.</returns>
         /// <returns>Disposable object representing an observer's subscription to the observable sequence.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="observer"/> is null.</exception>
+        /// <exception cref="ArgumentNullException"><paramref name="observer"/> is <c>null</c>.</exception>
         public IDisposable Subscribe(IObserver<T> observer)
         public IDisposable Subscribe(IObserver<T> observer)
         {
         {
             if (observer == null)
             if (observer == null)
                 throw new ArgumentNullException(nameof(observer));
                 throw new ArgumentNullException(nameof(observer));
 
 
             var autoDetachObserver = new AutoDetachObserver<T>(observer);
             var autoDetachObserver = new AutoDetachObserver<T>(observer);
-            
+
             if (CurrentThreadScheduler.IsScheduleRequired)
             if (CurrentThreadScheduler.IsScheduleRequired)
             {
             {
                 //
                 //

+ 6 - 4
Rx.NET/Source/src/System.Reactive/ObserverBase.cs

@@ -9,7 +9,7 @@ namespace System.Reactive
     /// <summary>
     /// <summary>
     /// Abstract base class for implementations of the <see cref="IObserver{T}"/> interface.
     /// Abstract base class for implementations of the <see cref="IObserver{T}"/> interface.
     /// </summary>
     /// </summary>
-    /// <remarks>This base class enforces the grammar of observers where OnError and OnCompleted are terminal messages.</remarks>
+    /// <remarks>This base class enforces the grammar of observers where <see cref="IObserver{T}.OnError(Exception)"/> and <see cref="IObserver{T}.OnCompleted()"/> are terminal messages.</remarks>
     /// <typeparam name="T">The type of the elements in the sequence.</typeparam>
     /// <typeparam name="T">The type of the elements in the sequence.</typeparam>
     public abstract class ObserverBase<T> : IObserver<T>, IDisposable
     public abstract class ObserverBase<T> : IObserver<T>, IDisposable
     {
     {
@@ -30,7 +30,9 @@ namespace System.Reactive
         public void OnNext(T value)
         public void OnNext(T value)
         {
         {
             if (Volatile.Read(ref isStopped) == 0)
             if (Volatile.Read(ref isStopped) == 0)
+            {
                 OnNextCore(value);
                 OnNextCore(value);
+            }
         }
         }
 
 
         /// <summary>
         /// <summary>
@@ -44,7 +46,7 @@ namespace System.Reactive
         /// Notifies the observer that an exception has occurred.
         /// Notifies the observer that an exception has occurred.
         /// </summary>
         /// </summary>
         /// <param name="error">The error that has occurred.</param>
         /// <param name="error">The error that has occurred.</param>
-        /// <exception cref="ArgumentNullException"><paramref name="error"/> is null.</exception>
+        /// <exception cref="ArgumentNullException"><paramref name="error"/> is <c>null</c>.</exception>
         public void OnError(Exception error)
         public void OnError(Exception error)
         {
         {
             if (error == null)
             if (error == null)
@@ -91,9 +93,9 @@ namespace System.Reactive
         }
         }
 
 
         /// <summary>
         /// <summary>
-        /// Core implementation of IDisposable.
+        /// Core implementation of <see cref="IDisposable"/>.
         /// </summary>
         /// </summary>
-        /// <param name="disposing">true if the Dispose call was triggered by the IDisposable.Dispose method; false if it was triggered by the finalizer.</param>
+        /// <param name="disposing"><c>true</c> if the Dispose call was triggered by the <see cref="IDisposable.Dispose"/> method; <c>false</c> if it was triggered by the finalizer.</param>
         protected virtual void Dispose(bool disposing)
         protected virtual void Dispose(bool disposing)
         {
         {
             if (disposing)
             if (disposing)

+ 1 - 1
Rx.NET/Source/src/System.Reactive/Threading/Tasks/NamespaceDoc.cs

@@ -7,7 +7,7 @@ namespace System.Reactive.Threading.Tasks
     /// <summary>
     /// <summary>
     /// The <b>System.Reactive.Threading.Tasks</b> namespace contains helpers for the conversion between tasks and observable sequences.
     /// The <b>System.Reactive.Threading.Tasks</b> namespace contains helpers for the conversion between tasks and observable sequences.
     /// </summary>
     /// </summary>
-    [System.Runtime.CompilerServices.CompilerGeneratedAttribute]
+    [System.Runtime.CompilerServices.CompilerGenerated]
     class NamespaceDoc
     class NamespaceDoc
     {
     {
     }
     }

+ 7 - 7
Rx.NET/Source/src/System.Reactive/TimeInterval.cs

@@ -39,32 +39,32 @@ namespace System.Reactive
         public TimeSpan Interval { get; }
         public TimeSpan Interval { get; }
 
 
         /// <summary>
         /// <summary>
-        /// Determines whether the current <see cref="TimeInterval{T}"/> value has the same Value and Interval as a specified <see cref="TimeInterval{T}"/> value.
+        /// Determines whether the current <see cref="TimeInterval{T}"/> value has the same <see cref="Value"/> and <see cref="Interval"/> as a specified <see cref="TimeInterval{T}"/> value.
         /// </summary>
         /// </summary>
         /// <param name="other">An object to compare to the current <see cref="TimeInterval{T}"/> value.</param>
         /// <param name="other">An object to compare to the current <see cref="TimeInterval{T}"/> value.</param>
-        /// <returns>true if both <see cref="TimeInterval{T}"/> values have the same Value and Interval; otherwise, false.</returns>
+        /// <returns><c>true</c> if both <see cref="TimeInterval{T}"/> values have the same <see cref="Value"/> and <see cref="Interval"/>; otherwise, <c>false</c>.</returns>
         public bool Equals(TimeInterval<T> other)
         public bool Equals(TimeInterval<T> other)
         {
         {
             return other.Interval.Equals(Interval) && EqualityComparer<T>.Default.Equals(Value, other.Value);
             return other.Interval.Equals(Interval) && EqualityComparer<T>.Default.Equals(Value, other.Value);
         }
         }
 
 
         /// <summary>
         /// <summary>
-        /// Determines whether the two specified <see cref="TimeInterval{T}"/> values have the same Value and Interval.
+        /// Determines whether the two specified <see cref="TimeInterval{T}"/> values have the same <see cref="Value"/> and <see cref="Interval"/>.
         /// </summary>
         /// </summary>
         /// <param name="first">The first <see cref="TimeInterval{T}"/> value to compare.</param>
         /// <param name="first">The first <see cref="TimeInterval{T}"/> value to compare.</param>
         /// <param name="second">The second <see cref="TimeInterval{T}"/> value to compare.</param>
         /// <param name="second">The second <see cref="TimeInterval{T}"/> value to compare.</param>
-        /// <returns>true if the first <see cref="TimeInterval{T}"/> value has the same Value and Interval as the second <see cref="TimeInterval{T}"/> value; otherwise, false.</returns>
+        /// <returns><c>true</c> if the first <see cref="TimeInterval{T}"/> value has the same <see cref="Value"/> and <see cref="Interval"/> as the second <see cref="TimeInterval{T}"/> value; otherwise, <c>false</c>.</returns>
         public static bool operator ==(TimeInterval<T> first, TimeInterval<T> second)
         public static bool operator ==(TimeInterval<T> first, TimeInterval<T> second)
         {
         {
             return first.Equals(second);
             return first.Equals(second);
         }
         }
 
 
         /// <summary>
         /// <summary>
-        /// Determines whether the two specified <see cref="TimeInterval{T}"/> values don't have the same Value and Interval.
+        /// Determines whether the two specified <see cref="TimeInterval{T}"/> values don't have the same <see cref="Value"/> and <see cref="Interval"/>.
         /// </summary>
         /// </summary>
         /// <param name="first">The first <see cref="TimeInterval{T}"/> value to compare.</param>
         /// <param name="first">The first <see cref="TimeInterval{T}"/> value to compare.</param>
         /// <param name="second">The second <see cref="TimeInterval{T}"/> value to compare.</param>
         /// <param name="second">The second <see cref="TimeInterval{T}"/> value to compare.</param>
-        /// <returns>true if the first <see cref="TimeInterval{T}"/> value has a different Value or Interval as the second <see cref="TimeInterval{T}"/> value; otherwise, false.</returns>
+        /// <returns><c>true</c> if the first <see cref="TimeInterval{T}"/> value has a different <see cref="Value"/> or <see cref="Interval"/> as the second <see cref="TimeInterval{T}"/> value; otherwise, <c>false</c>.</returns>
         public static bool operator !=(TimeInterval<T> first, TimeInterval<T> second)
         public static bool operator !=(TimeInterval<T> first, TimeInterval<T> second)
         {
         {
             return !first.Equals(second);
             return !first.Equals(second);
@@ -74,7 +74,7 @@ namespace System.Reactive
         /// Determines whether the specified System.Object is equal to the current <see cref="TimeInterval{T}"/>.
         /// Determines whether the specified System.Object is equal to the current <see cref="TimeInterval{T}"/>.
         /// </summary>
         /// </summary>
         /// <param name="obj">The System.Object to compare with the current <see cref="TimeInterval{T}"/>.</param>
         /// <param name="obj">The System.Object to compare with the current <see cref="TimeInterval{T}"/>.</param>
-        /// <returns>true if the specified System.Object is equal to the current <see cref="TimeInterval{T}"/>; otherwise, false.</returns>
+        /// <returns><c>true</c> if the specified System.Object is equal to the current <see cref="TimeInterval{T}"/>; otherwise, <c>false</c>.</returns>
         public override bool Equals(object obj)
         public override bool Equals(object obj)
         {
         {
             if (!(obj is TimeInterval<T>))
             if (!(obj is TimeInterval<T>))

+ 7 - 7
Rx.NET/Source/src/System.Reactive/Timestamped.cs

@@ -40,32 +40,32 @@ namespace System.Reactive
         public DateTimeOffset Timestamp { get; }
         public DateTimeOffset Timestamp { get; }
 
 
         /// <summary>
         /// <summary>
-        /// Determines whether the current <see cref="Timestamped{T}" /> value has the same Value and Timestamp as a specified <see cref="Timestamped{T}" /> value.
+        /// Determines whether the current <see cref="Timestamped{T}" /> value has the same <see cref="Value"/> and <see cref="Timestamp"/> as a specified <see cref="Timestamped{T}" /> value.
         /// </summary>
         /// </summary>
         /// <param name="other">An object to compare to the current <see cref="Timestamped{T}" /> value.</param>
         /// <param name="other">An object to compare to the current <see cref="Timestamped{T}" /> value.</param>
-        /// <returns>true if both <see cref="Timestamped{T}" /> values have the same Value and Timestamp; otherwise, false.</returns>
+        /// <returns><c>true</c> if both <see cref="Timestamped{T}" /> values have the same <see cref="Value"/> and <see cref="Timestamp"/>; otherwise, <c>false</c>.</returns>
         public bool Equals(Timestamped<T> other)
         public bool Equals(Timestamped<T> other)
         {
         {
             return other.Timestamp.Equals(Timestamp) && EqualityComparer<T>.Default.Equals(Value, other.Value);
             return other.Timestamp.Equals(Timestamp) && EqualityComparer<T>.Default.Equals(Value, other.Value);
         }
         }
 
 
         /// <summary>
         /// <summary>
-        /// Determines whether the two specified <see cref="Timestamped{T}" /> values have the same Value and Timestamp.
+        /// Determines whether the two specified <see cref="Timestamped{T}" /> values have the same <see cref="Value"/> and <see cref="Timestamp"/>.
         /// </summary>
         /// </summary>
         /// <param name="first">The first <see cref="Timestamped{T}" /> value to compare.</param>
         /// <param name="first">The first <see cref="Timestamped{T}" /> value to compare.</param>
         /// <param name="second">The second <see cref="Timestamped{T}" /> value to compare.</param>
         /// <param name="second">The second <see cref="Timestamped{T}" /> value to compare.</param>
-        /// <returns>true if the first <see cref="Timestamped{T}" /> value has the same Value and Timestamp as the second <see cref="Timestamped{T}" /> value; otherwise, false.</returns>
+        /// <returns><c>true</c> if the first <see cref="Timestamped{T}" /> value has the same <see cref="Value"/> and <see cref="Timestamp"/> as the second <see cref="Timestamped{T}" /> value; otherwise, <c>false</c>.</returns>
         public static bool operator ==(Timestamped<T> first, Timestamped<T> second)
         public static bool operator ==(Timestamped<T> first, Timestamped<T> second)
         {
         {
             return first.Equals(second);
             return first.Equals(second);
         }
         }
 
 
         /// <summary>
         /// <summary>
-        /// Determines whether the two specified <see cref="Timestamped{T}" /> values don't have the same Value and Timestamp.
+        /// Determines whether the two specified <see cref="Timestamped{T}" /> values don't have the same <see cref="Value"/> and <see cref="Timestamp"/>.
         /// </summary>
         /// </summary>
         /// <param name="first">The first <see cref="Timestamped{T}" /> value to compare.</param>
         /// <param name="first">The first <see cref="Timestamped{T}" /> value to compare.</param>
         /// <param name="second">The second <see cref="Timestamped{T}" /> value to compare.</param>
         /// <param name="second">The second <see cref="Timestamped{T}" /> value to compare.</param>
-        /// <returns>true if the first <see cref="Timestamped{T}" /> value has a different Value or Timestamp as the second <see cref="Timestamped{T}" /> value; otherwise, false.</returns>
+        /// <returns><c>true</c> if the first <see cref="Timestamped{T}" /> value has a different <see cref="Value"/> or <see cref="Timestamp"/> as the second <see cref="Timestamped{T}" /> value; otherwise, <c>false</c>.</returns>
         public static bool operator !=(Timestamped<T> first, Timestamped<T> second)
         public static bool operator !=(Timestamped<T> first, Timestamped<T> second)
         {
         {
             return !first.Equals(second);
             return !first.Equals(second);
@@ -75,7 +75,7 @@ namespace System.Reactive
         /// Determines whether the specified System.Object is equal to the current <see cref="Timestamped{T}" />.
         /// Determines whether the specified System.Object is equal to the current <see cref="Timestamped{T}" />.
         /// </summary>
         /// </summary>
         /// <param name="obj">The System.Object to compare with the current <see cref="Timestamped{T}" />.</param>
         /// <param name="obj">The System.Object to compare with the current <see cref="Timestamped{T}" />.</param>
-        /// <returns>true if the specified System.Object is equal to the current <see cref="Timestamped{T}" />; otherwise, false.</returns>
+        /// <returns><c>true</c> if the specified System.Object is equal to the current <see cref="Timestamped{T}" />; otherwise, <c>false</c>.</returns>
         public override bool Equals(object obj)
         public override bool Equals(object obj)
         {
         {
             if (!(obj is Timestamped<T>))
             if (!(obj is Timestamped<T>))