Browse Source

Merge pull request #1301 from dotnet/dev/bartde/split_generated_code

Split out generated code into separate files
Bart J.F. De Smet 5 years ago
parent
commit
90e4b88114

+ 1122 - 0
Rx.NET/Source/src/System.Reactive/Joins/Pattern.Generated.cs

@@ -0,0 +1,1122 @@
+// Licensed to the .NET Foundation under one or more agreements.
+// The .NET Foundation licenses this file to you under the MIT License.
+// See the LICENSE file in the project root for more information. 
+
+namespace System.Reactive.Joins
+{
+    /* The following code is generated by a tool checked in to $/.../Source/Tools/CodeGenerators. */
+
+    #region Joins auto-generated code (8/4/2012 1:00:26 AM)
+
+    /// <summary>
+    /// Represents a join pattern over one observable sequence.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    public class Pattern<TSource1> : Pattern
+    {
+        internal Pattern(IObservable<TSource1> first)
+        {
+            First = first;
+        }
+
+        internal IObservable<TSource1> First { get; }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public Plan<TResult> Then<TResult>(Func<TSource1, TResult> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            return new Plan<TSource1, TResult>(this, selector);
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over two observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    public class Pattern<TSource1, TSource2> : Pattern
+    {
+        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second)
+        {
+            First = first;
+            Second = second;
+        }
+
+        internal IObservable<TSource1> First { get; }
+        internal IObservable<TSource2> Second { get; }
+
+        /// <summary>
+        /// Creates a pattern that matches when all three observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource3">The type of the elements in the third observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the two previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public Pattern<TSource1, TSource2, TSource3> And<TSource3>(IObservable<TSource3> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            return new Pattern<TSource1, TSource2, TSource3>(First, Second, other);
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TResult> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            return new Plan<TSource1, TSource2, TResult>(this, selector);
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over three observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    public class Pattern<TSource1, TSource2, TSource3> : Pattern
+    {
+        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third)
+        {
+            First = first;
+            Second = second;
+            Third = third;
+        }
+
+        internal IObservable<TSource1> First { get; }
+        internal IObservable<TSource2> Second { get; }
+        internal IObservable<TSource3> Third { get; }
+
+        /// <summary>
+        /// Creates a pattern that matches when all four observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource4">The type of the elements in the fourth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the three previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public Pattern<TSource1, TSource2, TSource3, TSource4> And<TSource4>(IObservable<TSource4> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            return new Pattern<TSource1, TSource2, TSource3, TSource4>(First, Second, Third, other);
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TResult> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            return new Plan<TSource1, TSource2, TSource3, TResult>(this, selector);
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over four observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    public class Pattern<TSource1, TSource2, TSource3, TSource4> : Pattern
+    {
+        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth)
+        {
+            First = first;
+            Second = second;
+            Third = third;
+            Fourth = fourth;
+        }
+
+        internal IObservable<TSource1> First { get; }
+        internal IObservable<TSource2> Second { get; }
+        internal IObservable<TSource3> Third { get; }
+        internal IObservable<TSource4> Fourth { get; }
+
+        /// <summary>
+        /// Creates a pattern that matches when all five observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource5">The type of the elements in the fifth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the four previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5> And<TSource5>(IObservable<TSource5> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5>(First, Second, Third, Fourth, other);
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TResult> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            return new Plan<TSource1, TSource2, TSource3, TSource4, TResult>(this, selector);
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over five observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5> : Pattern
+    {
+        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth)
+        {
+            First = first;
+            Second = second;
+            Third = third;
+            Fourth = fourth;
+            Fifth = fifth;
+        }
+
+        internal IObservable<TSource1> First { get; }
+        internal IObservable<TSource2> Second { get; }
+        internal IObservable<TSource3> Third { get; }
+        internal IObservable<TSource4> Fourth { get; }
+        internal IObservable<TSource5> Fifth { get; }
+
+        /// <summary>
+        /// Creates a pattern that matches when all six observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource6">The type of the elements in the sixth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the five previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6> And<TSource6>(IObservable<TSource6> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6>(First, Second, Third, Fourth, Fifth, other);
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TResult> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TResult>(this, selector);
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over six observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6> : Pattern
+    {
+        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth)
+        {
+            First = first;
+            Second = second;
+            Third = third;
+            Fourth = fourth;
+            Fifth = fifth;
+            Sixth = sixth;
+        }
+
+        internal IObservable<TSource1> First { get; }
+        internal IObservable<TSource2> Second { get; }
+        internal IObservable<TSource3> Third { get; }
+        internal IObservable<TSource4> Fourth { get; }
+        internal IObservable<TSource5> Fifth { get; }
+        internal IObservable<TSource6> Sixth { get; }
+
+        /// <summary>
+        /// Creates a pattern that matches when all seven observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource7">The type of the elements in the seventh observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the six previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7> And<TSource7>(IObservable<TSource7> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7>(First, Second, Third, Fourth, Fifth, Sixth, other);
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult>(this, selector);
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over seven observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7> : Pattern
+    {
+        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth, IObservable<TSource7> seventh)
+        {
+            First = first;
+            Second = second;
+            Third = third;
+            Fourth = fourth;
+            Fifth = fifth;
+            Sixth = sixth;
+            Seventh = seventh;
+        }
+
+        internal IObservable<TSource1> First { get; }
+        internal IObservable<TSource2> Second { get; }
+        internal IObservable<TSource3> Third { get; }
+        internal IObservable<TSource4> Fourth { get; }
+        internal IObservable<TSource5> Fifth { get; }
+        internal IObservable<TSource6> Sixth { get; }
+        internal IObservable<TSource7> Seventh { get; }
+
+        /// <summary>
+        /// Creates a pattern that matches when all eight observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource8">The type of the elements in the eighth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the seven previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8> And<TSource8>(IObservable<TSource8> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8>(First, Second, Third, Fourth, Fifth, Sixth, Seventh, other);
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult>(this, selector);
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over eight observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8> : Pattern
+    {
+        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth, IObservable<TSource7> seventh, IObservable<TSource8> eighth)
+        {
+            First = first;
+            Second = second;
+            Third = third;
+            Fourth = fourth;
+            Fifth = fifth;
+            Sixth = sixth;
+            Seventh = seventh;
+            Eighth = eighth;
+        }
+
+        internal IObservable<TSource1> First { get; }
+        internal IObservable<TSource2> Second { get; }
+        internal IObservable<TSource3> Third { get; }
+        internal IObservable<TSource4> Fourth { get; }
+        internal IObservable<TSource5> Fifth { get; }
+        internal IObservable<TSource6> Sixth { get; }
+        internal IObservable<TSource7> Seventh { get; }
+        internal IObservable<TSource8> Eighth { get; }
+
+        /// <summary>
+        /// Creates a pattern that matches when all nine observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource9">The type of the elements in the ninth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the eight previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9> And<TSource9>(IObservable<TSource9> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9>(First, Second, Third, Fourth, Fifth, Sixth, Seventh, Eighth, other);
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult>(this, selector);
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over nine observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9> : Pattern
+    {
+        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth, IObservable<TSource7> seventh, IObservable<TSource8> eighth, IObservable<TSource9> ninth)
+        {
+            First = first;
+            Second = second;
+            Third = third;
+            Fourth = fourth;
+            Fifth = fifth;
+            Sixth = sixth;
+            Seventh = seventh;
+            Eighth = eighth;
+            Ninth = ninth;
+        }
+
+        internal IObservable<TSource1> First { get; }
+        internal IObservable<TSource2> Second { get; }
+        internal IObservable<TSource3> Third { get; }
+        internal IObservable<TSource4> Fourth { get; }
+        internal IObservable<TSource5> Fifth { get; }
+        internal IObservable<TSource6> Sixth { get; }
+        internal IObservable<TSource7> Seventh { get; }
+        internal IObservable<TSource8> Eighth { get; }
+        internal IObservable<TSource9> Ninth { get; }
+
+        /// <summary>
+        /// Creates a pattern that matches when all ten observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource10">The type of the elements in the tenth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the nine previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10> And<TSource10>(IObservable<TSource10> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10>(First, Second, Third, Fourth, Fifth, Sixth, Seventh, Eighth, Ninth, other);
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult>(this, selector);
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over ten observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10> : Pattern
+    {
+        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth, IObservable<TSource7> seventh, IObservable<TSource8> eighth, IObservable<TSource9> ninth, IObservable<TSource10> tenth)
+        {
+            First = first;
+            Second = second;
+            Third = third;
+            Fourth = fourth;
+            Fifth = fifth;
+            Sixth = sixth;
+            Seventh = seventh;
+            Eighth = eighth;
+            Ninth = ninth;
+            Tenth = tenth;
+        }
+
+        internal IObservable<TSource1> First { get; }
+        internal IObservable<TSource2> Second { get; }
+        internal IObservable<TSource3> Third { get; }
+        internal IObservable<TSource4> Fourth { get; }
+        internal IObservable<TSource5> Fifth { get; }
+        internal IObservable<TSource6> Sixth { get; }
+        internal IObservable<TSource7> Seventh { get; }
+        internal IObservable<TSource8> Eighth { get; }
+        internal IObservable<TSource9> Ninth { get; }
+        internal IObservable<TSource10> Tenth { get; }
+
+        /// <summary>
+        /// Creates a pattern that matches when all eleven observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource11">The type of the elements in the eleventh observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the ten previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11> And<TSource11>(IObservable<TSource11> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11>(First, Second, Third, Fourth, Fifth, Sixth, Seventh, Eighth, Ninth, Tenth, other);
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult>(this, selector);
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over eleven observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11> : Pattern
+    {
+        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth, IObservable<TSource7> seventh, IObservable<TSource8> eighth, IObservable<TSource9> ninth, IObservable<TSource10> tenth, IObservable<TSource11> eleventh)
+        {
+            First = first;
+            Second = second;
+            Third = third;
+            Fourth = fourth;
+            Fifth = fifth;
+            Sixth = sixth;
+            Seventh = seventh;
+            Eighth = eighth;
+            Ninth = ninth;
+            Tenth = tenth;
+            Eleventh = eleventh;
+        }
+
+        internal IObservable<TSource1> First { get; }
+        internal IObservable<TSource2> Second { get; }
+        internal IObservable<TSource3> Third { get; }
+        internal IObservable<TSource4> Fourth { get; }
+        internal IObservable<TSource5> Fifth { get; }
+        internal IObservable<TSource6> Sixth { get; }
+        internal IObservable<TSource7> Seventh { get; }
+        internal IObservable<TSource8> Eighth { get; }
+        internal IObservable<TSource9> Ninth { get; }
+        internal IObservable<TSource10> Tenth { get; }
+        internal IObservable<TSource11> Eleventh { get; }
+
+        /// <summary>
+        /// Creates a pattern that matches when all twelve observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource12">The type of the elements in the twelfth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the eleven previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12> And<TSource12>(IObservable<TSource12> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12>(First, Second, Third, Fourth, Fifth, Sixth, Seventh, Eighth, Ninth, Tenth, Eleventh, other);
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult>(this, selector);
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over twelve observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+    /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
+    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12> : Pattern
+    {
+        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth, IObservable<TSource7> seventh, IObservable<TSource8> eighth, IObservable<TSource9> ninth, IObservable<TSource10> tenth, IObservable<TSource11> eleventh, IObservable<TSource12> twelfth)
+        {
+            First = first;
+            Second = second;
+            Third = third;
+            Fourth = fourth;
+            Fifth = fifth;
+            Sixth = sixth;
+            Seventh = seventh;
+            Eighth = eighth;
+            Ninth = ninth;
+            Tenth = tenth;
+            Eleventh = eleventh;
+            Twelfth = twelfth;
+        }
+
+        internal IObservable<TSource1> First { get; }
+        internal IObservable<TSource2> Second { get; }
+        internal IObservable<TSource3> Third { get; }
+        internal IObservable<TSource4> Fourth { get; }
+        internal IObservable<TSource5> Fifth { get; }
+        internal IObservable<TSource6> Sixth { get; }
+        internal IObservable<TSource7> Seventh { get; }
+        internal IObservable<TSource8> Eighth { get; }
+        internal IObservable<TSource9> Ninth { get; }
+        internal IObservable<TSource10> Tenth { get; }
+        internal IObservable<TSource11> Eleventh { get; }
+        internal IObservable<TSource12> Twelfth { get; }
+
+        /// <summary>
+        /// Creates a pattern that matches when all thirteen observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource13">The type of the elements in the thirteenth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the twelve previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13> And<TSource13>(IObservable<TSource13> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13>(First, Second, Third, Fourth, Fifth, Sixth, Seventh, Eighth, Ninth, Tenth, Eleventh, Twelfth, other);
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult>(this, selector);
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over thirteen observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+    /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
+    /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
+    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13> : Pattern
+    {
+        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth, IObservable<TSource7> seventh, IObservable<TSource8> eighth, IObservable<TSource9> ninth, IObservable<TSource10> tenth, IObservable<TSource11> eleventh, IObservable<TSource12> twelfth, IObservable<TSource13> thirteenth)
+        {
+            First = first;
+            Second = second;
+            Third = third;
+            Fourth = fourth;
+            Fifth = fifth;
+            Sixth = sixth;
+            Seventh = seventh;
+            Eighth = eighth;
+            Ninth = ninth;
+            Tenth = tenth;
+            Eleventh = eleventh;
+            Twelfth = twelfth;
+            Thirteenth = thirteenth;
+        }
+
+        internal IObservable<TSource1> First { get; }
+        internal IObservable<TSource2> Second { get; }
+        internal IObservable<TSource3> Third { get; }
+        internal IObservable<TSource4> Fourth { get; }
+        internal IObservable<TSource5> Fifth { get; }
+        internal IObservable<TSource6> Sixth { get; }
+        internal IObservable<TSource7> Seventh { get; }
+        internal IObservable<TSource8> Eighth { get; }
+        internal IObservable<TSource9> Ninth { get; }
+        internal IObservable<TSource10> Tenth { get; }
+        internal IObservable<TSource11> Eleventh { get; }
+        internal IObservable<TSource12> Twelfth { get; }
+        internal IObservable<TSource13> Thirteenth { get; }
+
+        /// <summary>
+        /// Creates a pattern that matches when all fourteen observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource14">The type of the elements in the fourteenth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the thirteen previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14> And<TSource14>(IObservable<TSource14> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14>(First, Second, Third, Fourth, Fifth, Sixth, Seventh, Eighth, Ninth, Tenth, Eleventh, Twelfth, Thirteenth, other);
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult>(this, selector);
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over fourteen observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+    /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
+    /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
+    /// <typeparam name="TSource14">The type of the elements in the fourteenth source sequence.</typeparam>
+    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14> : Pattern
+    {
+        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth, IObservable<TSource7> seventh, IObservable<TSource8> eighth, IObservable<TSource9> ninth, IObservable<TSource10> tenth, IObservable<TSource11> eleventh, IObservable<TSource12> twelfth, IObservable<TSource13> thirteenth, IObservable<TSource14> fourteenth)
+        {
+            First = first;
+            Second = second;
+            Third = third;
+            Fourth = fourth;
+            Fifth = fifth;
+            Sixth = sixth;
+            Seventh = seventh;
+            Eighth = eighth;
+            Ninth = ninth;
+            Tenth = tenth;
+            Eleventh = eleventh;
+            Twelfth = twelfth;
+            Thirteenth = thirteenth;
+            Fourteenth = fourteenth;
+        }
+
+        internal IObservable<TSource1> First { get; }
+        internal IObservable<TSource2> Second { get; }
+        internal IObservable<TSource3> Third { get; }
+        internal IObservable<TSource4> Fourth { get; }
+        internal IObservable<TSource5> Fifth { get; }
+        internal IObservable<TSource6> Sixth { get; }
+        internal IObservable<TSource7> Seventh { get; }
+        internal IObservable<TSource8> Eighth { get; }
+        internal IObservable<TSource9> Ninth { get; }
+        internal IObservable<TSource10> Tenth { get; }
+        internal IObservable<TSource11> Eleventh { get; }
+        internal IObservable<TSource12> Twelfth { get; }
+        internal IObservable<TSource13> Thirteenth { get; }
+        internal IObservable<TSource14> Fourteenth { get; }
+
+        /// <summary>
+        /// Creates a pattern that matches when all fifteen observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource15">The type of the elements in the fifteenth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the fourteen previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15> And<TSource15>(IObservable<TSource15> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15>(First, Second, Third, Fourth, Fifth, Sixth, Seventh, Eighth, Ninth, Tenth, Eleventh, Twelfth, Thirteenth, Fourteenth, other);
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult>(this, selector);
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over fifteen observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+    /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
+    /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
+    /// <typeparam name="TSource14">The type of the elements in the fourteenth source sequence.</typeparam>
+    /// <typeparam name="TSource15">The type of the elements in the fifteenth source sequence.</typeparam>
+    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15> : Pattern
+    {
+        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth, IObservable<TSource7> seventh, IObservable<TSource8> eighth, IObservable<TSource9> ninth, IObservable<TSource10> tenth, IObservable<TSource11> eleventh, IObservable<TSource12> twelfth, IObservable<TSource13> thirteenth, IObservable<TSource14> fourteenth, IObservable<TSource15> fifteenth)
+        {
+            First = first;
+            Second = second;
+            Third = third;
+            Fourth = fourth;
+            Fifth = fifth;
+            Sixth = sixth;
+            Seventh = seventh;
+            Eighth = eighth;
+            Ninth = ninth;
+            Tenth = tenth;
+            Eleventh = eleventh;
+            Twelfth = twelfth;
+            Thirteenth = thirteenth;
+            Fourteenth = fourteenth;
+            Fifteenth = fifteenth;
+        }
+
+        internal IObservable<TSource1> First { get; }
+        internal IObservable<TSource2> Second { get; }
+        internal IObservable<TSource3> Third { get; }
+        internal IObservable<TSource4> Fourth { get; }
+        internal IObservable<TSource5> Fifth { get; }
+        internal IObservable<TSource6> Sixth { get; }
+        internal IObservable<TSource7> Seventh { get; }
+        internal IObservable<TSource8> Eighth { get; }
+        internal IObservable<TSource9> Ninth { get; }
+        internal IObservable<TSource10> Tenth { get; }
+        internal IObservable<TSource11> Eleventh { get; }
+        internal IObservable<TSource12> Twelfth { get; }
+        internal IObservable<TSource13> Thirteenth { get; }
+        internal IObservable<TSource14> Fourteenth { get; }
+        internal IObservable<TSource15> Fifteenth { get; }
+
+        /// <summary>
+        /// Creates a pattern that matches when all sixteen observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource16">The type of the elements in the sixteenth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the fifteen previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16> And<TSource16>(IObservable<TSource16> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16>(First, Second, Third, Fourth, Fifth, Sixth, Seventh, Eighth, Ninth, Tenth, Eleventh, Twelfth, Thirteenth, Fourteenth, Fifteenth, other);
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult>(this, selector);
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over sixteen observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+    /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
+    /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
+    /// <typeparam name="TSource14">The type of the elements in the fourteenth source sequence.</typeparam>
+    /// <typeparam name="TSource15">The type of the elements in the fifteenth source sequence.</typeparam>
+    /// <typeparam name="TSource16">The type of the elements in the sixteenth source sequence.</typeparam>
+    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16> : Pattern
+    {
+        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth, IObservable<TSource7> seventh, IObservable<TSource8> eighth, IObservable<TSource9> ninth, IObservable<TSource10> tenth, IObservable<TSource11> eleventh, IObservable<TSource12> twelfth, IObservable<TSource13> thirteenth, IObservable<TSource14> fourteenth, IObservable<TSource15> fifteenth, IObservable<TSource16> sixteenth)
+        {
+            First = first;
+            Second = second;
+            Third = third;
+            Fourth = fourth;
+            Fifth = fifth;
+            Sixth = sixth;
+            Seventh = seventh;
+            Eighth = eighth;
+            Ninth = ninth;
+            Tenth = tenth;
+            Eleventh = eleventh;
+            Twelfth = twelfth;
+            Thirteenth = thirteenth;
+            Fourteenth = fourteenth;
+            Fifteenth = fifteenth;
+            Sixteenth = sixteenth;
+        }
+
+        internal IObservable<TSource1> First { get; }
+        internal IObservable<TSource2> Second { get; }
+        internal IObservable<TSource3> Third { get; }
+        internal IObservable<TSource4> Fourth { get; }
+        internal IObservable<TSource5> Fifth { get; }
+        internal IObservable<TSource6> Sixth { get; }
+        internal IObservable<TSource7> Seventh { get; }
+        internal IObservable<TSource8> Eighth { get; }
+        internal IObservable<TSource9> Ninth { get; }
+        internal IObservable<TSource10> Tenth { get; }
+        internal IObservable<TSource11> Eleventh { get; }
+        internal IObservable<TSource12> Twelfth { get; }
+        internal IObservable<TSource13> Thirteenth { get; }
+        internal IObservable<TSource14> Fourteenth { get; }
+        internal IObservable<TSource15> Fifteenth { get; }
+        internal IObservable<TSource16> Sixteenth { get; }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult>(this, selector);
+        }
+
+    }
+
+    #endregion
+}

+ 0 - 1116
Rx.NET/Source/src/System.Reactive/Joins/Pattern.cs

@@ -13,1120 +13,4 @@ namespace System.Reactive.Joins
         {
         {
         }
         }
     }
     }
-
-    /* The following code is generated by a tool checked in to $/.../Source/Tools/CodeGenerators. */
-
-    #region Joins auto-generated code (8/4/2012 1:00:26 AM)
-
-    /// <summary>
-    /// Represents a join pattern over one observable sequence.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    public class Pattern<TSource1> : Pattern
-    {
-        internal Pattern(IObservable<TSource1> first)
-        {
-            First = first;
-        }
-
-        internal IObservable<TSource1> First { get; }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public Plan<TResult> Then<TResult>(Func<TSource1, TResult> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            return new Plan<TSource1, TResult>(this, selector);
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over two observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    public class Pattern<TSource1, TSource2> : Pattern
-    {
-        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second)
-        {
-            First = first;
-            Second = second;
-        }
-
-        internal IObservable<TSource1> First { get; }
-        internal IObservable<TSource2> Second { get; }
-
-        /// <summary>
-        /// Creates a pattern that matches when all three observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource3">The type of the elements in the third observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the two previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public Pattern<TSource1, TSource2, TSource3> And<TSource3>(IObservable<TSource3> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            return new Pattern<TSource1, TSource2, TSource3>(First, Second, other);
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TResult> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            return new Plan<TSource1, TSource2, TResult>(this, selector);
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over three observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    public class Pattern<TSource1, TSource2, TSource3> : Pattern
-    {
-        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third)
-        {
-            First = first;
-            Second = second;
-            Third = third;
-        }
-
-        internal IObservable<TSource1> First { get; }
-        internal IObservable<TSource2> Second { get; }
-        internal IObservable<TSource3> Third { get; }
-
-        /// <summary>
-        /// Creates a pattern that matches when all four observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource4">The type of the elements in the fourth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the three previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public Pattern<TSource1, TSource2, TSource3, TSource4> And<TSource4>(IObservable<TSource4> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            return new Pattern<TSource1, TSource2, TSource3, TSource4>(First, Second, Third, other);
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TResult> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            return new Plan<TSource1, TSource2, TSource3, TResult>(this, selector);
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over four observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    public class Pattern<TSource1, TSource2, TSource3, TSource4> : Pattern
-    {
-        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth)
-        {
-            First = first;
-            Second = second;
-            Third = third;
-            Fourth = fourth;
-        }
-
-        internal IObservable<TSource1> First { get; }
-        internal IObservable<TSource2> Second { get; }
-        internal IObservable<TSource3> Third { get; }
-        internal IObservable<TSource4> Fourth { get; }
-
-        /// <summary>
-        /// Creates a pattern that matches when all five observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource5">The type of the elements in the fifth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the four previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5> And<TSource5>(IObservable<TSource5> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5>(First, Second, Third, Fourth, other);
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TResult> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            return new Plan<TSource1, TSource2, TSource3, TSource4, TResult>(this, selector);
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over five observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5> : Pattern
-    {
-        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth)
-        {
-            First = first;
-            Second = second;
-            Third = third;
-            Fourth = fourth;
-            Fifth = fifth;
-        }
-
-        internal IObservable<TSource1> First { get; }
-        internal IObservable<TSource2> Second { get; }
-        internal IObservable<TSource3> Third { get; }
-        internal IObservable<TSource4> Fourth { get; }
-        internal IObservable<TSource5> Fifth { get; }
-
-        /// <summary>
-        /// Creates a pattern that matches when all six observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource6">The type of the elements in the sixth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the five previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6> And<TSource6>(IObservable<TSource6> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6>(First, Second, Third, Fourth, Fifth, other);
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TResult> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TResult>(this, selector);
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over six observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6> : Pattern
-    {
-        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth)
-        {
-            First = first;
-            Second = second;
-            Third = third;
-            Fourth = fourth;
-            Fifth = fifth;
-            Sixth = sixth;
-        }
-
-        internal IObservable<TSource1> First { get; }
-        internal IObservable<TSource2> Second { get; }
-        internal IObservable<TSource3> Third { get; }
-        internal IObservable<TSource4> Fourth { get; }
-        internal IObservable<TSource5> Fifth { get; }
-        internal IObservable<TSource6> Sixth { get; }
-
-        /// <summary>
-        /// Creates a pattern that matches when all seven observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource7">The type of the elements in the seventh observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the six previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7> And<TSource7>(IObservable<TSource7> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7>(First, Second, Third, Fourth, Fifth, Sixth, other);
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult>(this, selector);
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over seven observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
-    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7> : Pattern
-    {
-        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth, IObservable<TSource7> seventh)
-        {
-            First = first;
-            Second = second;
-            Third = third;
-            Fourth = fourth;
-            Fifth = fifth;
-            Sixth = sixth;
-            Seventh = seventh;
-        }
-
-        internal IObservable<TSource1> First { get; }
-        internal IObservable<TSource2> Second { get; }
-        internal IObservable<TSource3> Third { get; }
-        internal IObservable<TSource4> Fourth { get; }
-        internal IObservable<TSource5> Fifth { get; }
-        internal IObservable<TSource6> Sixth { get; }
-        internal IObservable<TSource7> Seventh { get; }
-
-        /// <summary>
-        /// Creates a pattern that matches when all eight observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource8">The type of the elements in the eighth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the seven previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8> And<TSource8>(IObservable<TSource8> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8>(First, Second, Third, Fourth, Fifth, Sixth, Seventh, other);
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult>(this, selector);
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over eight observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
-    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
-    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8> : Pattern
-    {
-        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth, IObservable<TSource7> seventh, IObservable<TSource8> eighth)
-        {
-            First = first;
-            Second = second;
-            Third = third;
-            Fourth = fourth;
-            Fifth = fifth;
-            Sixth = sixth;
-            Seventh = seventh;
-            Eighth = eighth;
-        }
-
-        internal IObservable<TSource1> First { get; }
-        internal IObservable<TSource2> Second { get; }
-        internal IObservable<TSource3> Third { get; }
-        internal IObservable<TSource4> Fourth { get; }
-        internal IObservable<TSource5> Fifth { get; }
-        internal IObservable<TSource6> Sixth { get; }
-        internal IObservable<TSource7> Seventh { get; }
-        internal IObservable<TSource8> Eighth { get; }
-
-        /// <summary>
-        /// Creates a pattern that matches when all nine observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource9">The type of the elements in the ninth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the eight previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9> And<TSource9>(IObservable<TSource9> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9>(First, Second, Third, Fourth, Fifth, Sixth, Seventh, Eighth, other);
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult>(this, selector);
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over nine observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
-    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
-    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
-    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9> : Pattern
-    {
-        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth, IObservable<TSource7> seventh, IObservable<TSource8> eighth, IObservable<TSource9> ninth)
-        {
-            First = first;
-            Second = second;
-            Third = third;
-            Fourth = fourth;
-            Fifth = fifth;
-            Sixth = sixth;
-            Seventh = seventh;
-            Eighth = eighth;
-            Ninth = ninth;
-        }
-
-        internal IObservable<TSource1> First { get; }
-        internal IObservable<TSource2> Second { get; }
-        internal IObservable<TSource3> Third { get; }
-        internal IObservable<TSource4> Fourth { get; }
-        internal IObservable<TSource5> Fifth { get; }
-        internal IObservable<TSource6> Sixth { get; }
-        internal IObservable<TSource7> Seventh { get; }
-        internal IObservable<TSource8> Eighth { get; }
-        internal IObservable<TSource9> Ninth { get; }
-
-        /// <summary>
-        /// Creates a pattern that matches when all ten observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource10">The type of the elements in the tenth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the nine previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10> And<TSource10>(IObservable<TSource10> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10>(First, Second, Third, Fourth, Fifth, Sixth, Seventh, Eighth, Ninth, other);
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult>(this, selector);
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over ten observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
-    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
-    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
-    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
-    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10> : Pattern
-    {
-        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth, IObservable<TSource7> seventh, IObservable<TSource8> eighth, IObservable<TSource9> ninth, IObservable<TSource10> tenth)
-        {
-            First = first;
-            Second = second;
-            Third = third;
-            Fourth = fourth;
-            Fifth = fifth;
-            Sixth = sixth;
-            Seventh = seventh;
-            Eighth = eighth;
-            Ninth = ninth;
-            Tenth = tenth;
-        }
-
-        internal IObservable<TSource1> First { get; }
-        internal IObservable<TSource2> Second { get; }
-        internal IObservable<TSource3> Third { get; }
-        internal IObservable<TSource4> Fourth { get; }
-        internal IObservable<TSource5> Fifth { get; }
-        internal IObservable<TSource6> Sixth { get; }
-        internal IObservable<TSource7> Seventh { get; }
-        internal IObservable<TSource8> Eighth { get; }
-        internal IObservable<TSource9> Ninth { get; }
-        internal IObservable<TSource10> Tenth { get; }
-
-        /// <summary>
-        /// Creates a pattern that matches when all eleven observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource11">The type of the elements in the eleventh observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the ten previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11> And<TSource11>(IObservable<TSource11> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11>(First, Second, Third, Fourth, Fifth, Sixth, Seventh, Eighth, Ninth, Tenth, other);
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult>(this, selector);
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over eleven observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
-    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
-    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
-    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
-    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
-    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11> : Pattern
-    {
-        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth, IObservable<TSource7> seventh, IObservable<TSource8> eighth, IObservable<TSource9> ninth, IObservable<TSource10> tenth, IObservable<TSource11> eleventh)
-        {
-            First = first;
-            Second = second;
-            Third = third;
-            Fourth = fourth;
-            Fifth = fifth;
-            Sixth = sixth;
-            Seventh = seventh;
-            Eighth = eighth;
-            Ninth = ninth;
-            Tenth = tenth;
-            Eleventh = eleventh;
-        }
-
-        internal IObservable<TSource1> First { get; }
-        internal IObservable<TSource2> Second { get; }
-        internal IObservable<TSource3> Third { get; }
-        internal IObservable<TSource4> Fourth { get; }
-        internal IObservable<TSource5> Fifth { get; }
-        internal IObservable<TSource6> Sixth { get; }
-        internal IObservable<TSource7> Seventh { get; }
-        internal IObservable<TSource8> Eighth { get; }
-        internal IObservable<TSource9> Ninth { get; }
-        internal IObservable<TSource10> Tenth { get; }
-        internal IObservable<TSource11> Eleventh { get; }
-
-        /// <summary>
-        /// Creates a pattern that matches when all twelve observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource12">The type of the elements in the twelfth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the eleven previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12> And<TSource12>(IObservable<TSource12> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12>(First, Second, Third, Fourth, Fifth, Sixth, Seventh, Eighth, Ninth, Tenth, Eleventh, other);
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult>(this, selector);
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over twelve observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
-    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
-    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
-    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
-    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
-    /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
-    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12> : Pattern
-    {
-        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth, IObservable<TSource7> seventh, IObservable<TSource8> eighth, IObservable<TSource9> ninth, IObservable<TSource10> tenth, IObservable<TSource11> eleventh, IObservable<TSource12> twelfth)
-        {
-            First = first;
-            Second = second;
-            Third = third;
-            Fourth = fourth;
-            Fifth = fifth;
-            Sixth = sixth;
-            Seventh = seventh;
-            Eighth = eighth;
-            Ninth = ninth;
-            Tenth = tenth;
-            Eleventh = eleventh;
-            Twelfth = twelfth;
-        }
-
-        internal IObservable<TSource1> First { get; }
-        internal IObservable<TSource2> Second { get; }
-        internal IObservable<TSource3> Third { get; }
-        internal IObservable<TSource4> Fourth { get; }
-        internal IObservable<TSource5> Fifth { get; }
-        internal IObservable<TSource6> Sixth { get; }
-        internal IObservable<TSource7> Seventh { get; }
-        internal IObservable<TSource8> Eighth { get; }
-        internal IObservable<TSource9> Ninth { get; }
-        internal IObservable<TSource10> Tenth { get; }
-        internal IObservable<TSource11> Eleventh { get; }
-        internal IObservable<TSource12> Twelfth { get; }
-
-        /// <summary>
-        /// Creates a pattern that matches when all thirteen observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource13">The type of the elements in the thirteenth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the twelve previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13> And<TSource13>(IObservable<TSource13> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13>(First, Second, Third, Fourth, Fifth, Sixth, Seventh, Eighth, Ninth, Tenth, Eleventh, Twelfth, other);
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult>(this, selector);
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over thirteen observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
-    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
-    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
-    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
-    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
-    /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
-    /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
-    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13> : Pattern
-    {
-        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth, IObservable<TSource7> seventh, IObservable<TSource8> eighth, IObservable<TSource9> ninth, IObservable<TSource10> tenth, IObservable<TSource11> eleventh, IObservable<TSource12> twelfth, IObservable<TSource13> thirteenth)
-        {
-            First = first;
-            Second = second;
-            Third = third;
-            Fourth = fourth;
-            Fifth = fifth;
-            Sixth = sixth;
-            Seventh = seventh;
-            Eighth = eighth;
-            Ninth = ninth;
-            Tenth = tenth;
-            Eleventh = eleventh;
-            Twelfth = twelfth;
-            Thirteenth = thirteenth;
-        }
-
-        internal IObservable<TSource1> First { get; }
-        internal IObservable<TSource2> Second { get; }
-        internal IObservable<TSource3> Third { get; }
-        internal IObservable<TSource4> Fourth { get; }
-        internal IObservable<TSource5> Fifth { get; }
-        internal IObservable<TSource6> Sixth { get; }
-        internal IObservable<TSource7> Seventh { get; }
-        internal IObservable<TSource8> Eighth { get; }
-        internal IObservable<TSource9> Ninth { get; }
-        internal IObservable<TSource10> Tenth { get; }
-        internal IObservable<TSource11> Eleventh { get; }
-        internal IObservable<TSource12> Twelfth { get; }
-        internal IObservable<TSource13> Thirteenth { get; }
-
-        /// <summary>
-        /// Creates a pattern that matches when all fourteen observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource14">The type of the elements in the fourteenth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the thirteen previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14> And<TSource14>(IObservable<TSource14> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14>(First, Second, Third, Fourth, Fifth, Sixth, Seventh, Eighth, Ninth, Tenth, Eleventh, Twelfth, Thirteenth, other);
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult>(this, selector);
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over fourteen observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
-    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
-    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
-    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
-    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
-    /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
-    /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
-    /// <typeparam name="TSource14">The type of the elements in the fourteenth source sequence.</typeparam>
-    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14> : Pattern
-    {
-        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth, IObservable<TSource7> seventh, IObservable<TSource8> eighth, IObservable<TSource9> ninth, IObservable<TSource10> tenth, IObservable<TSource11> eleventh, IObservable<TSource12> twelfth, IObservable<TSource13> thirteenth, IObservable<TSource14> fourteenth)
-        {
-            First = first;
-            Second = second;
-            Third = third;
-            Fourth = fourth;
-            Fifth = fifth;
-            Sixth = sixth;
-            Seventh = seventh;
-            Eighth = eighth;
-            Ninth = ninth;
-            Tenth = tenth;
-            Eleventh = eleventh;
-            Twelfth = twelfth;
-            Thirteenth = thirteenth;
-            Fourteenth = fourteenth;
-        }
-
-        internal IObservable<TSource1> First { get; }
-        internal IObservable<TSource2> Second { get; }
-        internal IObservable<TSource3> Third { get; }
-        internal IObservable<TSource4> Fourth { get; }
-        internal IObservable<TSource5> Fifth { get; }
-        internal IObservable<TSource6> Sixth { get; }
-        internal IObservable<TSource7> Seventh { get; }
-        internal IObservable<TSource8> Eighth { get; }
-        internal IObservable<TSource9> Ninth { get; }
-        internal IObservable<TSource10> Tenth { get; }
-        internal IObservable<TSource11> Eleventh { get; }
-        internal IObservable<TSource12> Twelfth { get; }
-        internal IObservable<TSource13> Thirteenth { get; }
-        internal IObservable<TSource14> Fourteenth { get; }
-
-        /// <summary>
-        /// Creates a pattern that matches when all fifteen observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource15">The type of the elements in the fifteenth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the fourteen previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15> And<TSource15>(IObservable<TSource15> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15>(First, Second, Third, Fourth, Fifth, Sixth, Seventh, Eighth, Ninth, Tenth, Eleventh, Twelfth, Thirteenth, Fourteenth, other);
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult>(this, selector);
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over fifteen observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
-    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
-    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
-    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
-    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
-    /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
-    /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
-    /// <typeparam name="TSource14">The type of the elements in the fourteenth source sequence.</typeparam>
-    /// <typeparam name="TSource15">The type of the elements in the fifteenth source sequence.</typeparam>
-    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15> : Pattern
-    {
-        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth, IObservable<TSource7> seventh, IObservable<TSource8> eighth, IObservable<TSource9> ninth, IObservable<TSource10> tenth, IObservable<TSource11> eleventh, IObservable<TSource12> twelfth, IObservable<TSource13> thirteenth, IObservable<TSource14> fourteenth, IObservable<TSource15> fifteenth)
-        {
-            First = first;
-            Second = second;
-            Third = third;
-            Fourth = fourth;
-            Fifth = fifth;
-            Sixth = sixth;
-            Seventh = seventh;
-            Eighth = eighth;
-            Ninth = ninth;
-            Tenth = tenth;
-            Eleventh = eleventh;
-            Twelfth = twelfth;
-            Thirteenth = thirteenth;
-            Fourteenth = fourteenth;
-            Fifteenth = fifteenth;
-        }
-
-        internal IObservable<TSource1> First { get; }
-        internal IObservable<TSource2> Second { get; }
-        internal IObservable<TSource3> Third { get; }
-        internal IObservable<TSource4> Fourth { get; }
-        internal IObservable<TSource5> Fifth { get; }
-        internal IObservable<TSource6> Sixth { get; }
-        internal IObservable<TSource7> Seventh { get; }
-        internal IObservable<TSource8> Eighth { get; }
-        internal IObservable<TSource9> Ninth { get; }
-        internal IObservable<TSource10> Tenth { get; }
-        internal IObservable<TSource11> Eleventh { get; }
-        internal IObservable<TSource12> Twelfth { get; }
-        internal IObservable<TSource13> Thirteenth { get; }
-        internal IObservable<TSource14> Fourteenth { get; }
-        internal IObservable<TSource15> Fifteenth { get; }
-
-        /// <summary>
-        /// Creates a pattern that matches when all sixteen observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource16">The type of the elements in the sixteenth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the fifteen previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16> And<TSource16>(IObservable<TSource16> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            return new Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16>(First, Second, Third, Fourth, Fifth, Sixth, Seventh, Eighth, Ninth, Tenth, Eleventh, Twelfth, Thirteenth, Fourteenth, Fifteenth, other);
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult>(this, selector);
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over sixteen observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
-    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
-    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
-    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
-    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
-    /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
-    /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
-    /// <typeparam name="TSource14">The type of the elements in the fourteenth source sequence.</typeparam>
-    /// <typeparam name="TSource15">The type of the elements in the fifteenth source sequence.</typeparam>
-    /// <typeparam name="TSource16">The type of the elements in the sixteenth source sequence.</typeparam>
-    public class Pattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16> : Pattern
-    {
-        internal Pattern(IObservable<TSource1> first, IObservable<TSource2> second, IObservable<TSource3> third, IObservable<TSource4> fourth, IObservable<TSource5> fifth, IObservable<TSource6> sixth, IObservable<TSource7> seventh, IObservable<TSource8> eighth, IObservable<TSource9> ninth, IObservable<TSource10> tenth, IObservable<TSource11> eleventh, IObservable<TSource12> twelfth, IObservable<TSource13> thirteenth, IObservable<TSource14> fourteenth, IObservable<TSource15> fifteenth, IObservable<TSource16> sixteenth)
-        {
-            First = first;
-            Second = second;
-            Third = third;
-            Fourth = fourth;
-            Fifth = fifth;
-            Sixth = sixth;
-            Seventh = seventh;
-            Eighth = eighth;
-            Ninth = ninth;
-            Tenth = tenth;
-            Eleventh = eleventh;
-            Twelfth = twelfth;
-            Thirteenth = thirteenth;
-            Fourteenth = fourteenth;
-            Fifteenth = fifteenth;
-            Sixteenth = sixteenth;
-        }
-
-        internal IObservable<TSource1> First { get; }
-        internal IObservable<TSource2> Second { get; }
-        internal IObservable<TSource3> Third { get; }
-        internal IObservable<TSource4> Fourth { get; }
-        internal IObservable<TSource5> Fifth { get; }
-        internal IObservable<TSource6> Sixth { get; }
-        internal IObservable<TSource7> Seventh { get; }
-        internal IObservable<TSource8> Eighth { get; }
-        internal IObservable<TSource9> Ninth { get; }
-        internal IObservable<TSource10> Tenth { get; }
-        internal IObservable<TSource11> Eleventh { get; }
-        internal IObservable<TSource12> Twelfth { get; }
-        internal IObservable<TSource13> Thirteenth { get; }
-        internal IObservable<TSource14> Fourteenth { get; }
-        internal IObservable<TSource15> Fifteenth { get; }
-        internal IObservable<TSource16> Sixteenth { get; }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public Plan<TResult> Then<TResult>(Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            return new Plan<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult>(this, selector);
-        }
-
-    }
-
-    #endregion
 }
 }

+ 1084 - 0
Rx.NET/Source/src/System.Reactive/Joins/QueryablePattern.Generated.cs

@@ -0,0 +1,1084 @@
+// Licensed to the .NET Foundation under one or more agreements.
+// The .NET Foundation licenses this file to you under the MIT License.
+// See the LICENSE file in the project root for more information. 
+
+using System.Linq.Expressions;
+using System.Reactive.Linq;
+
+namespace System.Reactive.Joins
+{
+    /* The following code is generated by a tool checked in to $/.../Source/Tools/CodeGenerators. */
+
+    #region Joins auto-generated code (8/4/2012 1:00:32 AM)
+
+    /// <summary>
+    /// Represents a join pattern over two observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    public class QueryablePattern<TSource1, TSource2> : QueryablePattern
+    {
+        internal QueryablePattern(Expression expression)
+            : base(expression)
+        {
+        }
+
+        /// <summary>
+        /// Creates a pattern that matches when all three observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource3">The type of the elements in the third observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the two previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public QueryablePattern<TSource1, TSource2, TSource3> And<TSource3>(IObservable<TSource3> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2>);
+            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource3));
+            return new QueryablePattern<TSource1, TSource2, TSource3>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    Qbservable.GetSourceExpression(other)
+                )
+            );
+
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TResult>> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2>);
+            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
+            return new QueryablePlan<TResult>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    selector
+                )
+            );
+
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over three observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    public class QueryablePattern<TSource1, TSource2, TSource3> : QueryablePattern
+    {
+        internal QueryablePattern(Expression expression)
+            : base(expression)
+        {
+        }
+
+        /// <summary>
+        /// Creates a pattern that matches when all four observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource4">The type of the elements in the fourth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the three previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public QueryablePattern<TSource1, TSource2, TSource3, TSource4> And<TSource4>(IObservable<TSource4> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3>);
+            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource4));
+            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    Qbservable.GetSourceExpression(other)
+                )
+            );
+
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TResult>> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3>);
+            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
+            return new QueryablePlan<TResult>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    selector
+                )
+            );
+
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over four observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4> : QueryablePattern
+    {
+        internal QueryablePattern(Expression expression)
+            : base(expression)
+        {
+        }
+
+        /// <summary>
+        /// Creates a pattern that matches when all five observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource5">The type of the elements in the fifth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the four previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5> And<TSource5>(IObservable<TSource5> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4>);
+            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource5));
+            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    Qbservable.GetSourceExpression(other)
+                )
+            );
+
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TResult>> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4>);
+            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
+            return new QueryablePlan<TResult>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    selector
+                )
+            );
+
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over five observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5> : QueryablePattern
+    {
+        internal QueryablePattern(Expression expression)
+            : base(expression)
+        {
+        }
+
+        /// <summary>
+        /// Creates a pattern that matches when all six observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource6">The type of the elements in the sixth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the five previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6> And<TSource6>(IObservable<TSource6> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5>);
+            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource6));
+            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    Qbservable.GetSourceExpression(other)
+                )
+            );
+
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TResult>> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5>);
+            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
+            return new QueryablePlan<TResult>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    selector
+                )
+            );
+
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over six observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6> : QueryablePattern
+    {
+        internal QueryablePattern(Expression expression)
+            : base(expression)
+        {
+        }
+
+        /// <summary>
+        /// Creates a pattern that matches when all seven observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource7">The type of the elements in the seventh observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the six previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7> And<TSource7>(IObservable<TSource7> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6>);
+            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource7));
+            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    Qbservable.GetSourceExpression(other)
+                )
+            );
+
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult>> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6>);
+            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
+            return new QueryablePlan<TResult>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    selector
+                )
+            );
+
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over seven observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7> : QueryablePattern
+    {
+        internal QueryablePattern(Expression expression)
+            : base(expression)
+        {
+        }
+
+        /// <summary>
+        /// Creates a pattern that matches when all eight observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource8">The type of the elements in the eighth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the seven previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8> And<TSource8>(IObservable<TSource8> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7>);
+            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource8));
+            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    Qbservable.GetSourceExpression(other)
+                )
+            );
+
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult>> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7>);
+            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
+            return new QueryablePlan<TResult>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    selector
+                )
+            );
+
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over eight observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8> : QueryablePattern
+    {
+        internal QueryablePattern(Expression expression)
+            : base(expression)
+        {
+        }
+
+        /// <summary>
+        /// Creates a pattern that matches when all nine observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource9">The type of the elements in the ninth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the eight previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9> And<TSource9>(IObservable<TSource9> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8>);
+            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource9));
+            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    Qbservable.GetSourceExpression(other)
+                )
+            );
+
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult>> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8>);
+            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
+            return new QueryablePlan<TResult>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    selector
+                )
+            );
+
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over nine observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9> : QueryablePattern
+    {
+        internal QueryablePattern(Expression expression)
+            : base(expression)
+        {
+        }
+
+        /// <summary>
+        /// Creates a pattern that matches when all ten observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource10">The type of the elements in the tenth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the nine previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10> And<TSource10>(IObservable<TSource10> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9>);
+            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource10));
+            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    Qbservable.GetSourceExpression(other)
+                )
+            );
+
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult>> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9>);
+            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
+            return new QueryablePlan<TResult>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    selector
+                )
+            );
+
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over ten observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10> : QueryablePattern
+    {
+        internal QueryablePattern(Expression expression)
+            : base(expression)
+        {
+        }
+
+        /// <summary>
+        /// Creates a pattern that matches when all eleven observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource11">The type of the elements in the eleventh observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the ten previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11> And<TSource11>(IObservable<TSource11> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10>);
+            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource11));
+            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    Qbservable.GetSourceExpression(other)
+                )
+            );
+
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult>> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10>);
+            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
+            return new QueryablePlan<TResult>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    selector
+                )
+            );
+
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over eleven observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11> : QueryablePattern
+    {
+        internal QueryablePattern(Expression expression)
+            : base(expression)
+        {
+        }
+
+        /// <summary>
+        /// Creates a pattern that matches when all twelve observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource12">The type of the elements in the twelfth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the eleven previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12> And<TSource12>(IObservable<TSource12> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11>);
+            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource12));
+            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    Qbservable.GetSourceExpression(other)
+                )
+            );
+
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult>> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11>);
+            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
+            return new QueryablePlan<TResult>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    selector
+                )
+            );
+
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over twelve observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+    /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
+    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12> : QueryablePattern
+    {
+        internal QueryablePattern(Expression expression)
+            : base(expression)
+        {
+        }
+
+        /// <summary>
+        /// Creates a pattern that matches when all thirteen observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource13">The type of the elements in the thirteenth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the twelve previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13> And<TSource13>(IObservable<TSource13> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12>);
+            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource13));
+            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    Qbservable.GetSourceExpression(other)
+                )
+            );
+
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult>> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12>);
+            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
+            return new QueryablePlan<TResult>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    selector
+                )
+            );
+
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over thirteen observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+    /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
+    /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
+    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13> : QueryablePattern
+    {
+        internal QueryablePattern(Expression expression)
+            : base(expression)
+        {
+        }
+
+        /// <summary>
+        /// Creates a pattern that matches when all fourteen observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource14">The type of the elements in the fourteenth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the thirteen previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14> And<TSource14>(IObservable<TSource14> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13>);
+            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource14));
+            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    Qbservable.GetSourceExpression(other)
+                )
+            );
+
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult>> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13>);
+            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
+            return new QueryablePlan<TResult>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    selector
+                )
+            );
+
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over fourteen observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+    /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
+    /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
+    /// <typeparam name="TSource14">The type of the elements in the fourteenth source sequence.</typeparam>
+    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14> : QueryablePattern
+    {
+        internal QueryablePattern(Expression expression)
+            : base(expression)
+        {
+        }
+
+        /// <summary>
+        /// Creates a pattern that matches when all fifteen observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource15">The type of the elements in the fifteenth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the fourteen previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15> And<TSource15>(IObservable<TSource15> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14>);
+            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource15));
+            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    Qbservable.GetSourceExpression(other)
+                )
+            );
+
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult>> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14>);
+            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
+            return new QueryablePlan<TResult>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    selector
+                )
+            );
+
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over fifteen observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+    /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
+    /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
+    /// <typeparam name="TSource14">The type of the elements in the fourteenth source sequence.</typeparam>
+    /// <typeparam name="TSource15">The type of the elements in the fifteenth source sequence.</typeparam>
+    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15> : QueryablePattern
+    {
+        internal QueryablePattern(Expression expression)
+            : base(expression)
+        {
+        }
+
+        /// <summary>
+        /// Creates a pattern that matches when all sixteen observable sequences have an available element.
+        /// </summary>
+        /// <typeparam name="TSource16">The type of the elements in the sixteenth observable sequence.</typeparam>
+        /// <param name="other">Observable sequence to match with the fifteen previous sequences.</param>
+        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
+        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16> And<TSource16>(IObservable<TSource16> other)
+        {
+            if (other == null)
+            {
+                throw new ArgumentNullException(nameof(other));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15>);
+            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource16));
+            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    Qbservable.GetSourceExpression(other)
+                )
+            );
+
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult>> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15>);
+            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
+            return new QueryablePlan<TResult>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    selector
+                )
+            );
+
+        }
+
+    }
+
+    /// <summary>
+    /// Represents a join pattern over sixteen observable sequences.
+    /// </summary>
+    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+    /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
+    /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
+    /// <typeparam name="TSource14">The type of the elements in the fourteenth source sequence.</typeparam>
+    /// <typeparam name="TSource15">The type of the elements in the fifteenth source sequence.</typeparam>
+    /// <typeparam name="TSource16">The type of the elements in the sixteenth source sequence.</typeparam>
+    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16> : QueryablePattern
+    {
+        internal QueryablePattern(Expression expression)
+            : base(expression)
+        {
+        }
+
+        /// <summary>
+        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
+        /// </summary>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
+        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
+        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult>> selector)
+        {
+            if (selector == null)
+            {
+                throw new ArgumentNullException(nameof(selector));
+            }
+
+            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16>);
+            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
+            return new QueryablePlan<TResult>(
+                Expression.Call(
+                    Expression,
+                    m,
+                    selector
+                )
+            );
+
+        }
+
+    }
+
+    #endregion
+}

+ 0 - 1080
Rx.NET/Source/src/System.Reactive/Joins/QueryablePattern.cs

@@ -2,10 +2,7 @@
 // The .NET Foundation licenses this file to you under the MIT License.
 // The .NET Foundation licenses this file to you under the MIT License.
 // See the LICENSE file in the project root for more information. 
 // See the LICENSE file in the project root for more information. 
 
 
-#pragma warning disable 1591
-
 using System.Linq.Expressions;
 using System.Linq.Expressions;
-using System.Reactive.Linq;
 
 
 namespace System.Reactive.Joins
 namespace System.Reactive.Joins
 {
 {
@@ -28,1081 +25,4 @@ namespace System.Reactive.Joins
         /// </summary>
         /// </summary>
         public Expression Expression { get; }
         public Expression Expression { get; }
     }
     }
-
-    /* The following code is generated by a tool checked in to $/.../Source/Tools/CodeGenerators. */
-
-    #region Joins auto-generated code (8/4/2012 1:00:32 AM)
-
-    /// <summary>
-    /// Represents a join pattern over two observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    public class QueryablePattern<TSource1, TSource2> : QueryablePattern
-    {
-        internal QueryablePattern(Expression expression)
-            : base(expression)
-        {
-        }
-
-        /// <summary>
-        /// Creates a pattern that matches when all three observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource3">The type of the elements in the third observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the two previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public QueryablePattern<TSource1, TSource2, TSource3> And<TSource3>(IObservable<TSource3> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2>);
-            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource3));
-            return new QueryablePattern<TSource1, TSource2, TSource3>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    Qbservable.GetSourceExpression(other)
-                )
-            );
-
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TResult>> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2>);
-            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
-            return new QueryablePlan<TResult>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    selector
-                )
-            );
-
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over three observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    public class QueryablePattern<TSource1, TSource2, TSource3> : QueryablePattern
-    {
-        internal QueryablePattern(Expression expression)
-            : base(expression)
-        {
-        }
-
-        /// <summary>
-        /// Creates a pattern that matches when all four observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource4">The type of the elements in the fourth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the three previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public QueryablePattern<TSource1, TSource2, TSource3, TSource4> And<TSource4>(IObservable<TSource4> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3>);
-            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource4));
-            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    Qbservable.GetSourceExpression(other)
-                )
-            );
-
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TResult>> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3>);
-            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
-            return new QueryablePlan<TResult>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    selector
-                )
-            );
-
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over four observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4> : QueryablePattern
-    {
-        internal QueryablePattern(Expression expression)
-            : base(expression)
-        {
-        }
-
-        /// <summary>
-        /// Creates a pattern that matches when all five observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource5">The type of the elements in the fifth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the four previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5> And<TSource5>(IObservable<TSource5> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4>);
-            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource5));
-            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    Qbservable.GetSourceExpression(other)
-                )
-            );
-
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TResult>> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4>);
-            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
-            return new QueryablePlan<TResult>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    selector
-                )
-            );
-
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over five observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5> : QueryablePattern
-    {
-        internal QueryablePattern(Expression expression)
-            : base(expression)
-        {
-        }
-
-        /// <summary>
-        /// Creates a pattern that matches when all six observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource6">The type of the elements in the sixth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the five previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6> And<TSource6>(IObservable<TSource6> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5>);
-            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource6));
-            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    Qbservable.GetSourceExpression(other)
-                )
-            );
-
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TResult>> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5>);
-            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
-            return new QueryablePlan<TResult>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    selector
-                )
-            );
-
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over six observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6> : QueryablePattern
-    {
-        internal QueryablePattern(Expression expression)
-            : base(expression)
-        {
-        }
-
-        /// <summary>
-        /// Creates a pattern that matches when all seven observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource7">The type of the elements in the seventh observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the six previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7> And<TSource7>(IObservable<TSource7> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6>);
-            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource7));
-            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    Qbservable.GetSourceExpression(other)
-                )
-            );
-
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult>> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6>);
-            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
-            return new QueryablePlan<TResult>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    selector
-                )
-            );
-
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over seven observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
-    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7> : QueryablePattern
-    {
-        internal QueryablePattern(Expression expression)
-            : base(expression)
-        {
-        }
-
-        /// <summary>
-        /// Creates a pattern that matches when all eight observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource8">The type of the elements in the eighth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the seven previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8> And<TSource8>(IObservable<TSource8> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7>);
-            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource8));
-            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    Qbservable.GetSourceExpression(other)
-                )
-            );
-
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult>> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7>);
-            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
-            return new QueryablePlan<TResult>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    selector
-                )
-            );
-
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over eight observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
-    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
-    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8> : QueryablePattern
-    {
-        internal QueryablePattern(Expression expression)
-            : base(expression)
-        {
-        }
-
-        /// <summary>
-        /// Creates a pattern that matches when all nine observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource9">The type of the elements in the ninth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the eight previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9> And<TSource9>(IObservable<TSource9> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8>);
-            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource9));
-            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    Qbservable.GetSourceExpression(other)
-                )
-            );
-
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult>> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8>);
-            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
-            return new QueryablePlan<TResult>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    selector
-                )
-            );
-
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over nine observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
-    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
-    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
-    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9> : QueryablePattern
-    {
-        internal QueryablePattern(Expression expression)
-            : base(expression)
-        {
-        }
-
-        /// <summary>
-        /// Creates a pattern that matches when all ten observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource10">The type of the elements in the tenth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the nine previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10> And<TSource10>(IObservable<TSource10> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9>);
-            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource10));
-            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    Qbservable.GetSourceExpression(other)
-                )
-            );
-
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult>> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9>);
-            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
-            return new QueryablePlan<TResult>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    selector
-                )
-            );
-
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over ten observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
-    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
-    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
-    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
-    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10> : QueryablePattern
-    {
-        internal QueryablePattern(Expression expression)
-            : base(expression)
-        {
-        }
-
-        /// <summary>
-        /// Creates a pattern that matches when all eleven observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource11">The type of the elements in the eleventh observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the ten previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11> And<TSource11>(IObservable<TSource11> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10>);
-            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource11));
-            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    Qbservable.GetSourceExpression(other)
-                )
-            );
-
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult>> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10>);
-            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
-            return new QueryablePlan<TResult>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    selector
-                )
-            );
-
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over eleven observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
-    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
-    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
-    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
-    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
-    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11> : QueryablePattern
-    {
-        internal QueryablePattern(Expression expression)
-            : base(expression)
-        {
-        }
-
-        /// <summary>
-        /// Creates a pattern that matches when all twelve observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource12">The type of the elements in the twelfth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the eleven previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12> And<TSource12>(IObservable<TSource12> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11>);
-            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource12));
-            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    Qbservable.GetSourceExpression(other)
-                )
-            );
-
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult>> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11>);
-            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
-            return new QueryablePlan<TResult>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    selector
-                )
-            );
-
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over twelve observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
-    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
-    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
-    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
-    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
-    /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
-    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12> : QueryablePattern
-    {
-        internal QueryablePattern(Expression expression)
-            : base(expression)
-        {
-        }
-
-        /// <summary>
-        /// Creates a pattern that matches when all thirteen observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource13">The type of the elements in the thirteenth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the twelve previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13> And<TSource13>(IObservable<TSource13> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12>);
-            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource13));
-            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    Qbservable.GetSourceExpression(other)
-                )
-            );
-
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult>> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12>);
-            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
-            return new QueryablePlan<TResult>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    selector
-                )
-            );
-
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over thirteen observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
-    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
-    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
-    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
-    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
-    /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
-    /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
-    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13> : QueryablePattern
-    {
-        internal QueryablePattern(Expression expression)
-            : base(expression)
-        {
-        }
-
-        /// <summary>
-        /// Creates a pattern that matches when all fourteen observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource14">The type of the elements in the fourteenth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the thirteen previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14> And<TSource14>(IObservable<TSource14> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13>);
-            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource14));
-            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    Qbservable.GetSourceExpression(other)
-                )
-            );
-
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult>> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13>);
-            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
-            return new QueryablePlan<TResult>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    selector
-                )
-            );
-
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over fourteen observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
-    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
-    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
-    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
-    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
-    /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
-    /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
-    /// <typeparam name="TSource14">The type of the elements in the fourteenth source sequence.</typeparam>
-    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14> : QueryablePattern
-    {
-        internal QueryablePattern(Expression expression)
-            : base(expression)
-        {
-        }
-
-        /// <summary>
-        /// Creates a pattern that matches when all fifteen observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource15">The type of the elements in the fifteenth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the fourteen previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15> And<TSource15>(IObservable<TSource15> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14>);
-            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource15));
-            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    Qbservable.GetSourceExpression(other)
-                )
-            );
-
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult>> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14>);
-            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
-            return new QueryablePlan<TResult>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    selector
-                )
-            );
-
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over fifteen observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
-    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
-    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
-    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
-    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
-    /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
-    /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
-    /// <typeparam name="TSource14">The type of the elements in the fourteenth source sequence.</typeparam>
-    /// <typeparam name="TSource15">The type of the elements in the fifteenth source sequence.</typeparam>
-    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15> : QueryablePattern
-    {
-        internal QueryablePattern(Expression expression)
-            : base(expression)
-        {
-        }
-
-        /// <summary>
-        /// Creates a pattern that matches when all sixteen observable sequences have an available element.
-        /// </summary>
-        /// <typeparam name="TSource16">The type of the elements in the sixteenth observable sequence.</typeparam>
-        /// <param name="other">Observable sequence to match with the fifteen previous sequences.</param>
-        /// <returns>Pattern object that matches when all observable sequences have an available element.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="other"/> is null.</exception>
-        public QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16> And<TSource16>(IObservable<TSource16> other)
-        {
-            if (other == null)
-            {
-                throw new ArgumentNullException(nameof(other));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15>);
-            var m = t.GetMethod(nameof(And)).MakeGenericMethod(typeof(TSource16));
-            return new QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    Qbservable.GetSourceExpression(other)
-                )
-            );
-
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult>> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15>);
-            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
-            return new QueryablePlan<TResult>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    selector
-                )
-            );
-
-        }
-
-    }
-
-    /// <summary>
-    /// Represents a join pattern over sixteen observable sequences.
-    /// </summary>
-    /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
-    /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
-    /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
-    /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
-    /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
-    /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
-    /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
-    /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
-    /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
-    /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
-    /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
-    /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
-    /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
-    /// <typeparam name="TSource14">The type of the elements in the fourteenth source sequence.</typeparam>
-    /// <typeparam name="TSource15">The type of the elements in the fifteenth source sequence.</typeparam>
-    /// <typeparam name="TSource16">The type of the elements in the sixteenth source sequence.</typeparam>
-    public class QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16> : QueryablePattern
-    {
-        internal QueryablePattern(Expression expression)
-            : base(expression)
-        {
-        }
-
-        /// <summary>
-        /// Matches when all observable sequences have an available element and projects the elements by invoking the selector function.
-        /// </summary>
-        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
-        /// <param name="selector">Selector that will be invoked for elements in the source sequences.</param>
-        /// <returns>Plan that produces the projected results, to be fed (with other plans) to the When operator.</returns>
-        /// <exception cref="ArgumentNullException"><paramref name="selector"/> is null.</exception>
-        public QueryablePlan<TResult> Then<TResult>(Expression<Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult>> selector)
-        {
-            if (selector == null)
-            {
-                throw new ArgumentNullException(nameof(selector));
-            }
-
-            var t = typeof(QueryablePattern<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16>);
-            var m = t.GetMethod(nameof(Then)).MakeGenericMethod(typeof(TResult));
-            return new QueryablePlan<TResult>(
-                Expression.Call(
-                    Expression,
-                    m,
-                    selector
-                )
-            );
-
-        }
-
-    }
-
-    #endregion
 }
 }
-
-#pragma warning restore 1591

+ 0 - 4
Rx.NET/Source/src/System.Reactive/Joins/QueryablePlan.cs

@@ -2,8 +2,6 @@
 // The .NET Foundation licenses this file to you under the MIT License.
 // The .NET Foundation licenses this file to you under the MIT License.
 // See the LICENSE file in the project root for more information. 
 // See the LICENSE file in the project root for more information. 
 
 
-#pragma warning disable 1591
-
 using System.Linq.Expressions;
 using System.Linq.Expressions;
 
 
 namespace System.Reactive.Joins
 namespace System.Reactive.Joins
@@ -25,5 +23,3 @@ namespace System.Reactive.Joins
         public Expression Expression { get; }
         public Expression Expression { get; }
     }
     }
 }
 }
-
-#pragma warning restore 1591

+ 1198 - 0
Rx.NET/Source/src/System.Reactive/Linq/Observable.Multiple.CombineLatest.Generated.cs

@@ -0,0 +1,1198 @@
+// Licensed to the .NET Foundation under one or more agreements.
+// The .NET Foundation licenses this file to you under the MIT License.
+// See the LICENSE file in the project root for more information. 
+
+namespace System.Reactive.Linq
+{
+    public static partial class Observable
+    {
+        /* The following code is generated by a tool checked in to $/.../Source/Tools/CodeGenerators. */
+
+        #region CombineLatest auto-generated code (8/3/2012 6:37:08 PM)
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever any of the observable sequences produces an element.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="resultSelector">Function to invoke whenever any of the sources produces an element.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="resultSelector"/> is null.</exception>
+        /// <remarks>If a non-empty source completes, its very last value will be used for creating subsequent combinations until all sources terminate.</remarks>
+        public static IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, Func<TSource1, TSource2, TSource3, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.CombineLatest(source1, source2, source3, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever any of the observable sequences produces an element.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="resultSelector">Function to invoke whenever any of the sources produces an element.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="resultSelector"/> is null.</exception>
+        /// <remarks>If a non-empty source completes, its very last value will be used for creating subsequent combinations until all sources terminate.</remarks>
+        public static IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, Func<TSource1, TSource2, TSource3, TSource4, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.CombineLatest(source1, source2, source3, source4, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever any of the observable sequences produces an element.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="resultSelector">Function to invoke whenever any of the sources produces an element.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="resultSelector"/> is null.</exception>
+        /// <remarks>If a non-empty source completes, its very last value will be used for creating subsequent combinations until all sources terminate.</remarks>
+        public static IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.CombineLatest(source1, source2, source3, source4, source5, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever any of the observable sequences produces an element.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="resultSelector">Function to invoke whenever any of the sources produces an element.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="resultSelector"/> is null.</exception>
+        /// <remarks>If a non-empty source completes, its very last value will be used for creating subsequent combinations until all sources terminate.</remarks>
+        public static IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.CombineLatest(source1, source2, source3, source4, source5, source6, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever any of the observable sequences produces an element.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="source7">Seventh observable source.</param>
+        /// <param name="resultSelector">Function to invoke whenever any of the sources produces an element.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="source7"/> or <paramref name="resultSelector"/> is null.</exception>
+        /// <remarks>If a non-empty source completes, its very last value will be used for creating subsequent combinations until all sources terminate.</remarks>
+        public static IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (source7 == null)
+            {
+                throw new ArgumentNullException(nameof(source7));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.CombineLatest(source1, source2, source3, source4, source5, source6, source7, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever any of the observable sequences produces an element.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+        /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="source7">Seventh observable source.</param>
+        /// <param name="source8">Eighth observable source.</param>
+        /// <param name="resultSelector">Function to invoke whenever any of the sources produces an element.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="source7"/> or <paramref name="source8"/> or <paramref name="resultSelector"/> is null.</exception>
+        /// <remarks>If a non-empty source completes, its very last value will be used for creating subsequent combinations until all sources terminate.</remarks>
+        public static IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (source7 == null)
+            {
+                throw new ArgumentNullException(nameof(source7));
+            }
+
+            if (source8 == null)
+            {
+                throw new ArgumentNullException(nameof(source8));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.CombineLatest(source1, source2, source3, source4, source5, source6, source7, source8, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever any of the observable sequences produces an element.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+        /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+        /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="source7">Seventh observable source.</param>
+        /// <param name="source8">Eighth observable source.</param>
+        /// <param name="source9">Ninth observable source.</param>
+        /// <param name="resultSelector">Function to invoke whenever any of the sources produces an element.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="source7"/> or <paramref name="source8"/> or <paramref name="source9"/> or <paramref name="resultSelector"/> is null.</exception>
+        /// <remarks>If a non-empty source completes, its very last value will be used for creating subsequent combinations until all sources terminate.</remarks>
+        public static IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (source7 == null)
+            {
+                throw new ArgumentNullException(nameof(source7));
+            }
+
+            if (source8 == null)
+            {
+                throw new ArgumentNullException(nameof(source8));
+            }
+
+            if (source9 == null)
+            {
+                throw new ArgumentNullException(nameof(source9));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.CombineLatest(source1, source2, source3, source4, source5, source6, source7, source8, source9, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever any of the observable sequences produces an element.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+        /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+        /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+        /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="source7">Seventh observable source.</param>
+        /// <param name="source8">Eighth observable source.</param>
+        /// <param name="source9">Ninth observable source.</param>
+        /// <param name="source10">Tenth observable source.</param>
+        /// <param name="resultSelector">Function to invoke whenever any of the sources produces an element.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="source7"/> or <paramref name="source8"/> or <paramref name="source9"/> or <paramref name="source10"/> or <paramref name="resultSelector"/> is null.</exception>
+        /// <remarks>If a non-empty source completes, its very last value will be used for creating subsequent combinations until all sources terminate.</remarks>
+        public static IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (source7 == null)
+            {
+                throw new ArgumentNullException(nameof(source7));
+            }
+
+            if (source8 == null)
+            {
+                throw new ArgumentNullException(nameof(source8));
+            }
+
+            if (source9 == null)
+            {
+                throw new ArgumentNullException(nameof(source9));
+            }
+
+            if (source10 == null)
+            {
+                throw new ArgumentNullException(nameof(source10));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.CombineLatest(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever any of the observable sequences produces an element.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+        /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+        /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+        /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+        /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="source7">Seventh observable source.</param>
+        /// <param name="source8">Eighth observable source.</param>
+        /// <param name="source9">Ninth observable source.</param>
+        /// <param name="source10">Tenth observable source.</param>
+        /// <param name="source11">Eleventh observable source.</param>
+        /// <param name="resultSelector">Function to invoke whenever any of the sources produces an element.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="source7"/> or <paramref name="source8"/> or <paramref name="source9"/> or <paramref name="source10"/> or <paramref name="source11"/> or <paramref name="resultSelector"/> is null.</exception>
+        /// <remarks>If a non-empty source completes, its very last value will be used for creating subsequent combinations until all sources terminate.</remarks>
+        public static IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (source7 == null)
+            {
+                throw new ArgumentNullException(nameof(source7));
+            }
+
+            if (source8 == null)
+            {
+                throw new ArgumentNullException(nameof(source8));
+            }
+
+            if (source9 == null)
+            {
+                throw new ArgumentNullException(nameof(source9));
+            }
+
+            if (source10 == null)
+            {
+                throw new ArgumentNullException(nameof(source10));
+            }
+
+            if (source11 == null)
+            {
+                throw new ArgumentNullException(nameof(source11));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.CombineLatest(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever any of the observable sequences produces an element.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+        /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+        /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+        /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+        /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+        /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="source7">Seventh observable source.</param>
+        /// <param name="source8">Eighth observable source.</param>
+        /// <param name="source9">Ninth observable source.</param>
+        /// <param name="source10">Tenth observable source.</param>
+        /// <param name="source11">Eleventh observable source.</param>
+        /// <param name="source12">Twelfth observable source.</param>
+        /// <param name="resultSelector">Function to invoke whenever any of the sources produces an element.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="source7"/> or <paramref name="source8"/> or <paramref name="source9"/> or <paramref name="source10"/> or <paramref name="source11"/> or <paramref name="source12"/> or <paramref name="resultSelector"/> is null.</exception>
+        /// <remarks>If a non-empty source completes, its very last value will be used for creating subsequent combinations until all sources terminate.</remarks>
+        public static IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (source7 == null)
+            {
+                throw new ArgumentNullException(nameof(source7));
+            }
+
+            if (source8 == null)
+            {
+                throw new ArgumentNullException(nameof(source8));
+            }
+
+            if (source9 == null)
+            {
+                throw new ArgumentNullException(nameof(source9));
+            }
+
+            if (source10 == null)
+            {
+                throw new ArgumentNullException(nameof(source10));
+            }
+
+            if (source11 == null)
+            {
+                throw new ArgumentNullException(nameof(source11));
+            }
+
+            if (source12 == null)
+            {
+                throw new ArgumentNullException(nameof(source12));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.CombineLatest(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever any of the observable sequences produces an element.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+        /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+        /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+        /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+        /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+        /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
+        /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="source7">Seventh observable source.</param>
+        /// <param name="source8">Eighth observable source.</param>
+        /// <param name="source9">Ninth observable source.</param>
+        /// <param name="source10">Tenth observable source.</param>
+        /// <param name="source11">Eleventh observable source.</param>
+        /// <param name="source12">Twelfth observable source.</param>
+        /// <param name="source13">Thirteenth observable source.</param>
+        /// <param name="resultSelector">Function to invoke whenever any of the sources produces an element.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="source7"/> or <paramref name="source8"/> or <paramref name="source9"/> or <paramref name="source10"/> or <paramref name="source11"/> or <paramref name="source12"/> or <paramref name="source13"/> or <paramref name="resultSelector"/> is null.</exception>
+        /// <remarks>If a non-empty source completes, its very last value will be used for creating subsequent combinations until all sources terminate.</remarks>
+        public static IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (source7 == null)
+            {
+                throw new ArgumentNullException(nameof(source7));
+            }
+
+            if (source8 == null)
+            {
+                throw new ArgumentNullException(nameof(source8));
+            }
+
+            if (source9 == null)
+            {
+                throw new ArgumentNullException(nameof(source9));
+            }
+
+            if (source10 == null)
+            {
+                throw new ArgumentNullException(nameof(source10));
+            }
+
+            if (source11 == null)
+            {
+                throw new ArgumentNullException(nameof(source11));
+            }
+
+            if (source12 == null)
+            {
+                throw new ArgumentNullException(nameof(source12));
+            }
+
+            if (source13 == null)
+            {
+                throw new ArgumentNullException(nameof(source13));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.CombineLatest(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever any of the observable sequences produces an element.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+        /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+        /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+        /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+        /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+        /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
+        /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
+        /// <typeparam name="TSource14">The type of the elements in the fourteenth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="source7">Seventh observable source.</param>
+        /// <param name="source8">Eighth observable source.</param>
+        /// <param name="source9">Ninth observable source.</param>
+        /// <param name="source10">Tenth observable source.</param>
+        /// <param name="source11">Eleventh observable source.</param>
+        /// <param name="source12">Twelfth observable source.</param>
+        /// <param name="source13">Thirteenth observable source.</param>
+        /// <param name="source14">Fourteenth observable source.</param>
+        /// <param name="resultSelector">Function to invoke whenever any of the sources produces an element.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="source7"/> or <paramref name="source8"/> or <paramref name="source9"/> or <paramref name="source10"/> or <paramref name="source11"/> or <paramref name="source12"/> or <paramref name="source13"/> or <paramref name="source14"/> or <paramref name="resultSelector"/> is null.</exception>
+        /// <remarks>If a non-empty source completes, its very last value will be used for creating subsequent combinations until all sources terminate.</remarks>
+        public static IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, IObservable<TSource14> source14, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (source7 == null)
+            {
+                throw new ArgumentNullException(nameof(source7));
+            }
+
+            if (source8 == null)
+            {
+                throw new ArgumentNullException(nameof(source8));
+            }
+
+            if (source9 == null)
+            {
+                throw new ArgumentNullException(nameof(source9));
+            }
+
+            if (source10 == null)
+            {
+                throw new ArgumentNullException(nameof(source10));
+            }
+
+            if (source11 == null)
+            {
+                throw new ArgumentNullException(nameof(source11));
+            }
+
+            if (source12 == null)
+            {
+                throw new ArgumentNullException(nameof(source12));
+            }
+
+            if (source13 == null)
+            {
+                throw new ArgumentNullException(nameof(source13));
+            }
+
+            if (source14 == null)
+            {
+                throw new ArgumentNullException(nameof(source14));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.CombineLatest(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, source14, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever any of the observable sequences produces an element.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+        /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+        /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+        /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+        /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+        /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
+        /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
+        /// <typeparam name="TSource14">The type of the elements in the fourteenth source sequence.</typeparam>
+        /// <typeparam name="TSource15">The type of the elements in the fifteenth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="source7">Seventh observable source.</param>
+        /// <param name="source8">Eighth observable source.</param>
+        /// <param name="source9">Ninth observable source.</param>
+        /// <param name="source10">Tenth observable source.</param>
+        /// <param name="source11">Eleventh observable source.</param>
+        /// <param name="source12">Twelfth observable source.</param>
+        /// <param name="source13">Thirteenth observable source.</param>
+        /// <param name="source14">Fourteenth observable source.</param>
+        /// <param name="source15">Fifteenth observable source.</param>
+        /// <param name="resultSelector">Function to invoke whenever any of the sources produces an element.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="source7"/> or <paramref name="source8"/> or <paramref name="source9"/> or <paramref name="source10"/> or <paramref name="source11"/> or <paramref name="source12"/> or <paramref name="source13"/> or <paramref name="source14"/> or <paramref name="source15"/> or <paramref name="resultSelector"/> is null.</exception>
+        /// <remarks>If a non-empty source completes, its very last value will be used for creating subsequent combinations until all sources terminate.</remarks>
+        public static IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, IObservable<TSource14> source14, IObservable<TSource15> source15, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (source7 == null)
+            {
+                throw new ArgumentNullException(nameof(source7));
+            }
+
+            if (source8 == null)
+            {
+                throw new ArgumentNullException(nameof(source8));
+            }
+
+            if (source9 == null)
+            {
+                throw new ArgumentNullException(nameof(source9));
+            }
+
+            if (source10 == null)
+            {
+                throw new ArgumentNullException(nameof(source10));
+            }
+
+            if (source11 == null)
+            {
+                throw new ArgumentNullException(nameof(source11));
+            }
+
+            if (source12 == null)
+            {
+                throw new ArgumentNullException(nameof(source12));
+            }
+
+            if (source13 == null)
+            {
+                throw new ArgumentNullException(nameof(source13));
+            }
+
+            if (source14 == null)
+            {
+                throw new ArgumentNullException(nameof(source14));
+            }
+
+            if (source15 == null)
+            {
+                throw new ArgumentNullException(nameof(source15));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.CombineLatest(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, source14, source15, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever any of the observable sequences produces an element.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+        /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+        /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+        /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+        /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+        /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
+        /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
+        /// <typeparam name="TSource14">The type of the elements in the fourteenth source sequence.</typeparam>
+        /// <typeparam name="TSource15">The type of the elements in the fifteenth source sequence.</typeparam>
+        /// <typeparam name="TSource16">The type of the elements in the sixteenth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="source7">Seventh observable source.</param>
+        /// <param name="source8">Eighth observable source.</param>
+        /// <param name="source9">Ninth observable source.</param>
+        /// <param name="source10">Tenth observable source.</param>
+        /// <param name="source11">Eleventh observable source.</param>
+        /// <param name="source12">Twelfth observable source.</param>
+        /// <param name="source13">Thirteenth observable source.</param>
+        /// <param name="source14">Fourteenth observable source.</param>
+        /// <param name="source15">Fifteenth observable source.</param>
+        /// <param name="source16">Sixteenth observable source.</param>
+        /// <param name="resultSelector">Function to invoke whenever any of the sources produces an element.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="source7"/> or <paramref name="source8"/> or <paramref name="source9"/> or <paramref name="source10"/> or <paramref name="source11"/> or <paramref name="source12"/> or <paramref name="source13"/> or <paramref name="source14"/> or <paramref name="source15"/> or <paramref name="source16"/> or <paramref name="resultSelector"/> is null.</exception>
+        /// <remarks>If a non-empty source completes, its very last value will be used for creating subsequent combinations until all sources terminate.</remarks>
+        public static IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, IObservable<TSource14> source14, IObservable<TSource15> source15, IObservable<TSource16> source16, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (source7 == null)
+            {
+                throw new ArgumentNullException(nameof(source7));
+            }
+
+            if (source8 == null)
+            {
+                throw new ArgumentNullException(nameof(source8));
+            }
+
+            if (source9 == null)
+            {
+                throw new ArgumentNullException(nameof(source9));
+            }
+
+            if (source10 == null)
+            {
+                throw new ArgumentNullException(nameof(source10));
+            }
+
+            if (source11 == null)
+            {
+                throw new ArgumentNullException(nameof(source11));
+            }
+
+            if (source12 == null)
+            {
+                throw new ArgumentNullException(nameof(source12));
+            }
+
+            if (source13 == null)
+            {
+                throw new ArgumentNullException(nameof(source13));
+            }
+
+            if (source14 == null)
+            {
+                throw new ArgumentNullException(nameof(source14));
+            }
+
+            if (source15 == null)
+            {
+                throw new ArgumentNullException(nameof(source15));
+            }
+
+            if (source16 == null)
+            {
+                throw new ArgumentNullException(nameof(source16));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.CombineLatest(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, source14, source15, source16, resultSelector);
+        }
+
+        #endregion
+    }
+}

+ 1184 - 0
Rx.NET/Source/src/System.Reactive/Linq/Observable.Multiple.Zip.Generated.cs

@@ -0,0 +1,1184 @@
+// Licensed to the .NET Foundation under one or more agreements.
+// The .NET Foundation licenses this file to you under the MIT License.
+// See the LICENSE file in the project root for more information. 
+
+namespace System.Reactive.Linq
+{
+    public static partial class Observable
+    {
+        /* The following code is generated by a tool checked in to $/.../Source/Tools/CodeGenerators. */
+
+        #region Zip auto-generated code (8/3/2012 6:37:02 PM)
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever all of the observable sequences have produced an element at a corresponding index.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="resultSelector">Function to invoke for each series of elements at corresponding indexes in the sources.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="resultSelector"/> is null.</exception>
+        public static IObservable<TResult> Zip<TSource1, TSource2, TSource3, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, Func<TSource1, TSource2, TSource3, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.Zip(source1, source2, source3, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever all of the observable sequences have produced an element at a corresponding index.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="resultSelector">Function to invoke for each series of elements at corresponding indexes in the sources.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="resultSelector"/> is null.</exception>
+        public static IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, Func<TSource1, TSource2, TSource3, TSource4, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.Zip(source1, source2, source3, source4, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever all of the observable sequences have produced an element at a corresponding index.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="resultSelector">Function to invoke for each series of elements at corresponding indexes in the sources.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="resultSelector"/> is null.</exception>
+        public static IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.Zip(source1, source2, source3, source4, source5, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever all of the observable sequences have produced an element at a corresponding index.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="resultSelector">Function to invoke for each series of elements at corresponding indexes in the sources.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="resultSelector"/> is null.</exception>
+        public static IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.Zip(source1, source2, source3, source4, source5, source6, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever all of the observable sequences have produced an element at a corresponding index.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="source7">Seventh observable source.</param>
+        /// <param name="resultSelector">Function to invoke for each series of elements at corresponding indexes in the sources.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="source7"/> or <paramref name="resultSelector"/> is null.</exception>
+        public static IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (source7 == null)
+            {
+                throw new ArgumentNullException(nameof(source7));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.Zip(source1, source2, source3, source4, source5, source6, source7, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever all of the observable sequences have produced an element at a corresponding index.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+        /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="source7">Seventh observable source.</param>
+        /// <param name="source8">Eighth observable source.</param>
+        /// <param name="resultSelector">Function to invoke for each series of elements at corresponding indexes in the sources.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="source7"/> or <paramref name="source8"/> or <paramref name="resultSelector"/> is null.</exception>
+        public static IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (source7 == null)
+            {
+                throw new ArgumentNullException(nameof(source7));
+            }
+
+            if (source8 == null)
+            {
+                throw new ArgumentNullException(nameof(source8));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.Zip(source1, source2, source3, source4, source5, source6, source7, source8, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever all of the observable sequences have produced an element at a corresponding index.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+        /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+        /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="source7">Seventh observable source.</param>
+        /// <param name="source8">Eighth observable source.</param>
+        /// <param name="source9">Ninth observable source.</param>
+        /// <param name="resultSelector">Function to invoke for each series of elements at corresponding indexes in the sources.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="source7"/> or <paramref name="source8"/> or <paramref name="source9"/> or <paramref name="resultSelector"/> is null.</exception>
+        public static IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (source7 == null)
+            {
+                throw new ArgumentNullException(nameof(source7));
+            }
+
+            if (source8 == null)
+            {
+                throw new ArgumentNullException(nameof(source8));
+            }
+
+            if (source9 == null)
+            {
+                throw new ArgumentNullException(nameof(source9));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.Zip(source1, source2, source3, source4, source5, source6, source7, source8, source9, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever all of the observable sequences have produced an element at a corresponding index.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+        /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+        /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+        /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="source7">Seventh observable source.</param>
+        /// <param name="source8">Eighth observable source.</param>
+        /// <param name="source9">Ninth observable source.</param>
+        /// <param name="source10">Tenth observable source.</param>
+        /// <param name="resultSelector">Function to invoke for each series of elements at corresponding indexes in the sources.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="source7"/> or <paramref name="source8"/> or <paramref name="source9"/> or <paramref name="source10"/> or <paramref name="resultSelector"/> is null.</exception>
+        public static IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (source7 == null)
+            {
+                throw new ArgumentNullException(nameof(source7));
+            }
+
+            if (source8 == null)
+            {
+                throw new ArgumentNullException(nameof(source8));
+            }
+
+            if (source9 == null)
+            {
+                throw new ArgumentNullException(nameof(source9));
+            }
+
+            if (source10 == null)
+            {
+                throw new ArgumentNullException(nameof(source10));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.Zip(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever all of the observable sequences have produced an element at a corresponding index.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+        /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+        /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+        /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+        /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="source7">Seventh observable source.</param>
+        /// <param name="source8">Eighth observable source.</param>
+        /// <param name="source9">Ninth observable source.</param>
+        /// <param name="source10">Tenth observable source.</param>
+        /// <param name="source11">Eleventh observable source.</param>
+        /// <param name="resultSelector">Function to invoke for each series of elements at corresponding indexes in the sources.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="source7"/> or <paramref name="source8"/> or <paramref name="source9"/> or <paramref name="source10"/> or <paramref name="source11"/> or <paramref name="resultSelector"/> is null.</exception>
+        public static IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (source7 == null)
+            {
+                throw new ArgumentNullException(nameof(source7));
+            }
+
+            if (source8 == null)
+            {
+                throw new ArgumentNullException(nameof(source8));
+            }
+
+            if (source9 == null)
+            {
+                throw new ArgumentNullException(nameof(source9));
+            }
+
+            if (source10 == null)
+            {
+                throw new ArgumentNullException(nameof(source10));
+            }
+
+            if (source11 == null)
+            {
+                throw new ArgumentNullException(nameof(source11));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.Zip(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever all of the observable sequences have produced an element at a corresponding index.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+        /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+        /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+        /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+        /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+        /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="source7">Seventh observable source.</param>
+        /// <param name="source8">Eighth observable source.</param>
+        /// <param name="source9">Ninth observable source.</param>
+        /// <param name="source10">Tenth observable source.</param>
+        /// <param name="source11">Eleventh observable source.</param>
+        /// <param name="source12">Twelfth observable source.</param>
+        /// <param name="resultSelector">Function to invoke for each series of elements at corresponding indexes in the sources.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="source7"/> or <paramref name="source8"/> or <paramref name="source9"/> or <paramref name="source10"/> or <paramref name="source11"/> or <paramref name="source12"/> or <paramref name="resultSelector"/> is null.</exception>
+        public static IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (source7 == null)
+            {
+                throw new ArgumentNullException(nameof(source7));
+            }
+
+            if (source8 == null)
+            {
+                throw new ArgumentNullException(nameof(source8));
+            }
+
+            if (source9 == null)
+            {
+                throw new ArgumentNullException(nameof(source9));
+            }
+
+            if (source10 == null)
+            {
+                throw new ArgumentNullException(nameof(source10));
+            }
+
+            if (source11 == null)
+            {
+                throw new ArgumentNullException(nameof(source11));
+            }
+
+            if (source12 == null)
+            {
+                throw new ArgumentNullException(nameof(source12));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.Zip(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever all of the observable sequences have produced an element at a corresponding index.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+        /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+        /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+        /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+        /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+        /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
+        /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="source7">Seventh observable source.</param>
+        /// <param name="source8">Eighth observable source.</param>
+        /// <param name="source9">Ninth observable source.</param>
+        /// <param name="source10">Tenth observable source.</param>
+        /// <param name="source11">Eleventh observable source.</param>
+        /// <param name="source12">Twelfth observable source.</param>
+        /// <param name="source13">Thirteenth observable source.</param>
+        /// <param name="resultSelector">Function to invoke for each series of elements at corresponding indexes in the sources.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="source7"/> or <paramref name="source8"/> or <paramref name="source9"/> or <paramref name="source10"/> or <paramref name="source11"/> or <paramref name="source12"/> or <paramref name="source13"/> or <paramref name="resultSelector"/> is null.</exception>
+        public static IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (source7 == null)
+            {
+                throw new ArgumentNullException(nameof(source7));
+            }
+
+            if (source8 == null)
+            {
+                throw new ArgumentNullException(nameof(source8));
+            }
+
+            if (source9 == null)
+            {
+                throw new ArgumentNullException(nameof(source9));
+            }
+
+            if (source10 == null)
+            {
+                throw new ArgumentNullException(nameof(source10));
+            }
+
+            if (source11 == null)
+            {
+                throw new ArgumentNullException(nameof(source11));
+            }
+
+            if (source12 == null)
+            {
+                throw new ArgumentNullException(nameof(source12));
+            }
+
+            if (source13 == null)
+            {
+                throw new ArgumentNullException(nameof(source13));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.Zip(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever all of the observable sequences have produced an element at a corresponding index.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+        /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+        /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+        /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+        /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+        /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
+        /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
+        /// <typeparam name="TSource14">The type of the elements in the fourteenth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="source7">Seventh observable source.</param>
+        /// <param name="source8">Eighth observable source.</param>
+        /// <param name="source9">Ninth observable source.</param>
+        /// <param name="source10">Tenth observable source.</param>
+        /// <param name="source11">Eleventh observable source.</param>
+        /// <param name="source12">Twelfth observable source.</param>
+        /// <param name="source13">Thirteenth observable source.</param>
+        /// <param name="source14">Fourteenth observable source.</param>
+        /// <param name="resultSelector">Function to invoke for each series of elements at corresponding indexes in the sources.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="source7"/> or <paramref name="source8"/> or <paramref name="source9"/> or <paramref name="source10"/> or <paramref name="source11"/> or <paramref name="source12"/> or <paramref name="source13"/> or <paramref name="source14"/> or <paramref name="resultSelector"/> is null.</exception>
+        public static IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, IObservable<TSource14> source14, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (source7 == null)
+            {
+                throw new ArgumentNullException(nameof(source7));
+            }
+
+            if (source8 == null)
+            {
+                throw new ArgumentNullException(nameof(source8));
+            }
+
+            if (source9 == null)
+            {
+                throw new ArgumentNullException(nameof(source9));
+            }
+
+            if (source10 == null)
+            {
+                throw new ArgumentNullException(nameof(source10));
+            }
+
+            if (source11 == null)
+            {
+                throw new ArgumentNullException(nameof(source11));
+            }
+
+            if (source12 == null)
+            {
+                throw new ArgumentNullException(nameof(source12));
+            }
+
+            if (source13 == null)
+            {
+                throw new ArgumentNullException(nameof(source13));
+            }
+
+            if (source14 == null)
+            {
+                throw new ArgumentNullException(nameof(source14));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.Zip(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, source14, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever all of the observable sequences have produced an element at a corresponding index.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+        /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+        /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+        /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+        /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+        /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
+        /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
+        /// <typeparam name="TSource14">The type of the elements in the fourteenth source sequence.</typeparam>
+        /// <typeparam name="TSource15">The type of the elements in the fifteenth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="source7">Seventh observable source.</param>
+        /// <param name="source8">Eighth observable source.</param>
+        /// <param name="source9">Ninth observable source.</param>
+        /// <param name="source10">Tenth observable source.</param>
+        /// <param name="source11">Eleventh observable source.</param>
+        /// <param name="source12">Twelfth observable source.</param>
+        /// <param name="source13">Thirteenth observable source.</param>
+        /// <param name="source14">Fourteenth observable source.</param>
+        /// <param name="source15">Fifteenth observable source.</param>
+        /// <param name="resultSelector">Function to invoke for each series of elements at corresponding indexes in the sources.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="source7"/> or <paramref name="source8"/> or <paramref name="source9"/> or <paramref name="source10"/> or <paramref name="source11"/> or <paramref name="source12"/> or <paramref name="source13"/> or <paramref name="source14"/> or <paramref name="source15"/> or <paramref name="resultSelector"/> is null.</exception>
+        public static IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, IObservable<TSource14> source14, IObservable<TSource15> source15, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (source7 == null)
+            {
+                throw new ArgumentNullException(nameof(source7));
+            }
+
+            if (source8 == null)
+            {
+                throw new ArgumentNullException(nameof(source8));
+            }
+
+            if (source9 == null)
+            {
+                throw new ArgumentNullException(nameof(source9));
+            }
+
+            if (source10 == null)
+            {
+                throw new ArgumentNullException(nameof(source10));
+            }
+
+            if (source11 == null)
+            {
+                throw new ArgumentNullException(nameof(source11));
+            }
+
+            if (source12 == null)
+            {
+                throw new ArgumentNullException(nameof(source12));
+            }
+
+            if (source13 == null)
+            {
+                throw new ArgumentNullException(nameof(source13));
+            }
+
+            if (source14 == null)
+            {
+                throw new ArgumentNullException(nameof(source14));
+            }
+
+            if (source15 == null)
+            {
+                throw new ArgumentNullException(nameof(source15));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.Zip(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, source14, source15, resultSelector);
+        }
+
+        /// <summary>
+        /// Merges the specified observable sequences into one observable sequence by using the selector function whenever all of the observable sequences have produced an element at a corresponding index.
+        /// </summary>
+        /// <typeparam name="TSource1">The type of the elements in the first source sequence.</typeparam>
+        /// <typeparam name="TSource2">The type of the elements in the second source sequence.</typeparam>
+        /// <typeparam name="TSource3">The type of the elements in the third source sequence.</typeparam>
+        /// <typeparam name="TSource4">The type of the elements in the fourth source sequence.</typeparam>
+        /// <typeparam name="TSource5">The type of the elements in the fifth source sequence.</typeparam>
+        /// <typeparam name="TSource6">The type of the elements in the sixth source sequence.</typeparam>
+        /// <typeparam name="TSource7">The type of the elements in the seventh source sequence.</typeparam>
+        /// <typeparam name="TSource8">The type of the elements in the eighth source sequence.</typeparam>
+        /// <typeparam name="TSource9">The type of the elements in the ninth source sequence.</typeparam>
+        /// <typeparam name="TSource10">The type of the elements in the tenth source sequence.</typeparam>
+        /// <typeparam name="TSource11">The type of the elements in the eleventh source sequence.</typeparam>
+        /// <typeparam name="TSource12">The type of the elements in the twelfth source sequence.</typeparam>
+        /// <typeparam name="TSource13">The type of the elements in the thirteenth source sequence.</typeparam>
+        /// <typeparam name="TSource14">The type of the elements in the fourteenth source sequence.</typeparam>
+        /// <typeparam name="TSource15">The type of the elements in the fifteenth source sequence.</typeparam>
+        /// <typeparam name="TSource16">The type of the elements in the sixteenth source sequence.</typeparam>
+        /// <typeparam name="TResult">The type of the elements in the result sequence, returned by the selector function.</typeparam>
+        /// <param name="source1">First observable source.</param>
+        /// <param name="source2">Second observable source.</param>
+        /// <param name="source3">Third observable source.</param>
+        /// <param name="source4">Fourth observable source.</param>
+        /// <param name="source5">Fifth observable source.</param>
+        /// <param name="source6">Sixth observable source.</param>
+        /// <param name="source7">Seventh observable source.</param>
+        /// <param name="source8">Eighth observable source.</param>
+        /// <param name="source9">Ninth observable source.</param>
+        /// <param name="source10">Tenth observable source.</param>
+        /// <param name="source11">Eleventh observable source.</param>
+        /// <param name="source12">Twelfth observable source.</param>
+        /// <param name="source13">Thirteenth observable source.</param>
+        /// <param name="source14">Fourteenth observable source.</param>
+        /// <param name="source15">Fifteenth observable source.</param>
+        /// <param name="source16">Sixteenth observable source.</param>
+        /// <param name="resultSelector">Function to invoke for each series of elements at corresponding indexes in the sources.</param>
+        /// <returns>An observable sequence containing the result of combining elements of the sources using the specified result selector function.</returns>
+        /// <exception cref="ArgumentNullException"><paramref name="source1"/> or <paramref name="source2"/> or <paramref name="source3"/> or <paramref name="source4"/> or <paramref name="source5"/> or <paramref name="source6"/> or <paramref name="source7"/> or <paramref name="source8"/> or <paramref name="source9"/> or <paramref name="source10"/> or <paramref name="source11"/> or <paramref name="source12"/> or <paramref name="source13"/> or <paramref name="source14"/> or <paramref name="source15"/> or <paramref name="source16"/> or <paramref name="resultSelector"/> is null.</exception>
+        public static IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult>(this IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, IObservable<TSource14> source14, IObservable<TSource15> source15, IObservable<TSource16> source16, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult> resultSelector)
+        {
+            if (source1 == null)
+            {
+                throw new ArgumentNullException(nameof(source1));
+            }
+
+            if (source2 == null)
+            {
+                throw new ArgumentNullException(nameof(source2));
+            }
+
+            if (source3 == null)
+            {
+                throw new ArgumentNullException(nameof(source3));
+            }
+
+            if (source4 == null)
+            {
+                throw new ArgumentNullException(nameof(source4));
+            }
+
+            if (source5 == null)
+            {
+                throw new ArgumentNullException(nameof(source5));
+            }
+
+            if (source6 == null)
+            {
+                throw new ArgumentNullException(nameof(source6));
+            }
+
+            if (source7 == null)
+            {
+                throw new ArgumentNullException(nameof(source7));
+            }
+
+            if (source8 == null)
+            {
+                throw new ArgumentNullException(nameof(source8));
+            }
+
+            if (source9 == null)
+            {
+                throw new ArgumentNullException(nameof(source9));
+            }
+
+            if (source10 == null)
+            {
+                throw new ArgumentNullException(nameof(source10));
+            }
+
+            if (source11 == null)
+            {
+                throw new ArgumentNullException(nameof(source11));
+            }
+
+            if (source12 == null)
+            {
+                throw new ArgumentNullException(nameof(source12));
+            }
+
+            if (source13 == null)
+            {
+                throw new ArgumentNullException(nameof(source13));
+            }
+
+            if (source14 == null)
+            {
+                throw new ArgumentNullException(nameof(source14));
+            }
+
+            if (source15 == null)
+            {
+                throw new ArgumentNullException(nameof(source15));
+            }
+
+            if (source16 == null)
+            {
+                throw new ArgumentNullException(nameof(source16));
+            }
+
+            if (resultSelector == null)
+            {
+                throw new ArgumentNullException(nameof(resultSelector));
+            }
+
+            return s_impl.Zip(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, source14, source15, source16, resultSelector);
+        }
+
+        #endregion
+    }
+}

File diff suppressed because it is too large
+ 484 - 2846
Rx.NET/Source/src/System.Reactive/Linq/Observable.Multiple.cs


+ 87 - 0
Rx.NET/Source/src/System.Reactive/Linq/QueryLanguage.Multiple.CombineLatest.Generated.cs

@@ -0,0 +1,87 @@
+// Licensed to the .NET Foundation under one or more agreements.
+// The .NET Foundation licenses this file to you under the MIT License.
+// See the LICENSE file in the project root for more information. 
+
+namespace System.Reactive.Linq
+{
+    using ObservableImpl;
+
+    internal partial class QueryLanguage
+    {
+        /* The following code is generated by a tool checked in to $/.../Source/Tools/CodeGenerators. */
+
+        #region CombineLatest auto-generated code (6/10/2012 7:25:03 PM)
+
+        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, Func<TSource1, TSource2, TSource3, TResult> resultSelector)
+        {
+            return new CombineLatest<TSource1, TSource2, TSource3, TResult>(source1, source2, source3, resultSelector);
+        }
+
+        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, Func<TSource1, TSource2, TSource3, TSource4, TResult> resultSelector)
+        {
+            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TResult>(source1, source2, source3, source4, resultSelector);
+        }
+
+        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TResult> resultSelector)
+        {
+            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TResult>(source1, source2, source3, source4, source5, resultSelector);
+        }
+
+        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult> resultSelector)
+        {
+            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult>(source1, source2, source3, source4, source5, source6, resultSelector);
+        }
+
+        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult> resultSelector)
+        {
+            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult>(source1, source2, source3, source4, source5, source6, source7, resultSelector);
+        }
+
+        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult> resultSelector)
+        {
+            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, resultSelector);
+        }
+
+        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult> resultSelector)
+        {
+            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, resultSelector);
+        }
+
+        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult> resultSelector)
+        {
+            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, resultSelector);
+        }
+
+        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult> resultSelector)
+        {
+            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, resultSelector);
+        }
+
+        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult> resultSelector)
+        {
+            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, resultSelector);
+        }
+
+        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult> resultSelector)
+        {
+            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, resultSelector);
+        }
+
+        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, IObservable<TSource14> source14, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult> resultSelector)
+        {
+            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, source14, resultSelector);
+        }
+
+        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, IObservable<TSource14> source14, IObservable<TSource15> source15, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult> resultSelector)
+        {
+            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, source14, source15, resultSelector);
+        }
+
+        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, IObservable<TSource14> source14, IObservable<TSource15> source15, IObservable<TSource16> source16, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult> resultSelector)
+        {
+            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, source14, source15, source16, resultSelector);
+        }
+
+        #endregion
+    }
+}

+ 87 - 0
Rx.NET/Source/src/System.Reactive/Linq/QueryLanguage.Multiple.Zip.Generated.cs

@@ -0,0 +1,87 @@
+// Licensed to the .NET Foundation under one or more agreements.
+// The .NET Foundation licenses this file to you under the MIT License.
+// See the LICENSE file in the project root for more information. 
+
+namespace System.Reactive.Linq
+{
+    using ObservableImpl;
+
+    internal partial class QueryLanguage
+    {
+        /* The following code is generated by a tool checked in to $/.../Source/Tools/CodeGenerators. */
+
+        #region Zip auto-generated code (6/10/2012 8:15:28 PM)
+
+        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, Func<TSource1, TSource2, TSource3, TResult> resultSelector)
+        {
+            return new Zip<TSource1, TSource2, TSource3, TResult>(source1, source2, source3, resultSelector);
+        }
+
+        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, Func<TSource1, TSource2, TSource3, TSource4, TResult> resultSelector)
+        {
+            return new Zip<TSource1, TSource2, TSource3, TSource4, TResult>(source1, source2, source3, source4, resultSelector);
+        }
+
+        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TResult> resultSelector)
+        {
+            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TResult>(source1, source2, source3, source4, source5, resultSelector);
+        }
+
+        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult> resultSelector)
+        {
+            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult>(source1, source2, source3, source4, source5, source6, resultSelector);
+        }
+
+        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult> resultSelector)
+        {
+            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult>(source1, source2, source3, source4, source5, source6, source7, resultSelector);
+        }
+
+        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult> resultSelector)
+        {
+            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, resultSelector);
+        }
+
+        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult> resultSelector)
+        {
+            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, resultSelector);
+        }
+
+        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult> resultSelector)
+        {
+            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, resultSelector);
+        }
+
+        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult> resultSelector)
+        {
+            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, resultSelector);
+        }
+
+        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult> resultSelector)
+        {
+            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, resultSelector);
+        }
+
+        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult> resultSelector)
+        {
+            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, resultSelector);
+        }
+
+        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, IObservable<TSource14> source14, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult> resultSelector)
+        {
+            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, source14, resultSelector);
+        }
+
+        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, IObservable<TSource14> source14, IObservable<TSource15> source15, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult> resultSelector)
+        {
+            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, source14, source15, resultSelector);
+        }
+
+        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, IObservable<TSource14> source14, IObservable<TSource15> source15, IObservable<TSource16> source16, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult> resultSelector)
+        {
+            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, source14, source15, source16, resultSelector);
+        }
+
+        #endregion
+    }
+}

+ 0 - 152
Rx.NET/Source/src/System.Reactive/Linq/QueryLanguage.Multiple.cs

@@ -88,82 +88,6 @@ namespace System.Reactive.Linq
             return new CombineLatest<TFirst, TSecond, TResult>(first, second, resultSelector);
             return new CombineLatest<TFirst, TSecond, TResult>(first, second, resultSelector);
         }
         }
 
 
-        /* The following code is generated by a tool checked in to $/.../Source/Tools/CodeGenerators. */
-
-        #region CombineLatest auto-generated code (6/10/2012 7:25:03 PM)
-
-        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, Func<TSource1, TSource2, TSource3, TResult> resultSelector)
-        {
-            return new CombineLatest<TSource1, TSource2, TSource3, TResult>(source1, source2, source3, resultSelector);
-        }
-
-        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, Func<TSource1, TSource2, TSource3, TSource4, TResult> resultSelector)
-        {
-            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TResult>(source1, source2, source3, source4, resultSelector);
-        }
-
-        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TResult> resultSelector)
-        {
-            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TResult>(source1, source2, source3, source4, source5, resultSelector);
-        }
-
-        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult> resultSelector)
-        {
-            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult>(source1, source2, source3, source4, source5, source6, resultSelector);
-        }
-
-        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult> resultSelector)
-        {
-            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult>(source1, source2, source3, source4, source5, source6, source7, resultSelector);
-        }
-
-        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult> resultSelector)
-        {
-            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, resultSelector);
-        }
-
-        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult> resultSelector)
-        {
-            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, resultSelector);
-        }
-
-        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult> resultSelector)
-        {
-            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, resultSelector);
-        }
-
-        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult> resultSelector)
-        {
-            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, resultSelector);
-        }
-
-        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult> resultSelector)
-        {
-            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, resultSelector);
-        }
-
-        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult> resultSelector)
-        {
-            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, resultSelector);
-        }
-
-        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, IObservable<TSource14> source14, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult> resultSelector)
-        {
-            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, source14, resultSelector);
-        }
-
-        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, IObservable<TSource14> source14, IObservable<TSource15> source15, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult> resultSelector)
-        {
-            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, source14, source15, resultSelector);
-        }
-
-        public virtual IObservable<TResult> CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, IObservable<TSource14> source14, IObservable<TSource15> source15, IObservable<TSource16> source16, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult> resultSelector)
-        {
-            return new CombineLatest<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, source14, source15, source16, resultSelector);
-        }
-
-        #endregion
-
         public virtual IObservable<TResult> CombineLatest<TSource, TResult>(IEnumerable<IObservable<TSource>> sources, Func<IList<TSource>, TResult> resultSelector)
         public virtual IObservable<TResult> CombineLatest<TSource, TResult>(IEnumerable<IObservable<TSource>> sources, Func<IList<TSource>, TResult> resultSelector)
         {
         {
             return CombineLatest_(sources, resultSelector);
             return CombineLatest_(sources, resultSelector);
@@ -415,82 +339,6 @@ namespace System.Reactive.Linq
             return new Zip<TSource>(sources);
             return new Zip<TSource>(sources);
         }
         }
 
 
-        /* The following code is generated by a tool checked in to $/.../Source/Tools/CodeGenerators. */
-
-        #region Zip auto-generated code (6/10/2012 8:15:28 PM)
-
-        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, Func<TSource1, TSource2, TSource3, TResult> resultSelector)
-        {
-            return new Zip<TSource1, TSource2, TSource3, TResult>(source1, source2, source3, resultSelector);
-        }
-
-        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, Func<TSource1, TSource2, TSource3, TSource4, TResult> resultSelector)
-        {
-            return new Zip<TSource1, TSource2, TSource3, TSource4, TResult>(source1, source2, source3, source4, resultSelector);
-        }
-
-        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TResult> resultSelector)
-        {
-            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TResult>(source1, source2, source3, source4, source5, resultSelector);
-        }
-
-        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult> resultSelector)
-        {
-            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TResult>(source1, source2, source3, source4, source5, source6, resultSelector);
-        }
-
-        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult> resultSelector)
-        {
-            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TResult>(source1, source2, source3, source4, source5, source6, source7, resultSelector);
-        }
-
-        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult> resultSelector)
-        {
-            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, resultSelector);
-        }
-
-        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult> resultSelector)
-        {
-            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, resultSelector);
-        }
-
-        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult> resultSelector)
-        {
-            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, resultSelector);
-        }
-
-        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult> resultSelector)
-        {
-            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, resultSelector);
-        }
-
-        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult> resultSelector)
-        {
-            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, resultSelector);
-        }
-
-        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult> resultSelector)
-        {
-            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, resultSelector);
-        }
-
-        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, IObservable<TSource14> source14, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult> resultSelector)
-        {
-            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, source14, resultSelector);
-        }
-
-        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, IObservable<TSource14> source14, IObservable<TSource15> source15, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult> resultSelector)
-        {
-            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, source14, source15, resultSelector);
-        }
-
-        public virtual IObservable<TResult> Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult>(IObservable<TSource1> source1, IObservable<TSource2> source2, IObservable<TSource3> source3, IObservable<TSource4> source4, IObservable<TSource5> source5, IObservable<TSource6> source6, IObservable<TSource7> source7, IObservable<TSource8> source8, IObservable<TSource9> source9, IObservable<TSource10> source10, IObservable<TSource11> source11, IObservable<TSource12> source12, IObservable<TSource13> source13, IObservable<TSource14> source14, IObservable<TSource15> source15, IObservable<TSource16> source16, Func<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult> resultSelector)
-        {
-            return new Zip<TSource1, TSource2, TSource3, TSource4, TSource5, TSource6, TSource7, TSource8, TSource9, TSource10, TSource11, TSource12, TSource13, TSource14, TSource15, TSource16, TResult>(source1, source2, source3, source4, source5, source6, source7, source8, source9, source10, source11, source12, source13, source14, source15, source16, resultSelector);
-        }
-
-        #endregion
-
         public virtual IObservable<TResult> Zip<TFirst, TSecond, TResult>(IObservable<TFirst> first, IEnumerable<TSecond> second, Func<TFirst, TSecond, TResult> resultSelector)
         public virtual IObservable<TResult> Zip<TFirst, TSecond, TResult>(IObservable<TFirst> first, IEnumerable<TSecond> second, Func<TFirst, TSecond, TResult> resultSelector)
         {
         {
             return new Zip<TFirst, TSecond, TResult>.Enumerable(first, second, resultSelector);
             return new Zip<TFirst, TSecond, TResult>.Enumerable(first, second, resultSelector);

Some files were not shown because too many files changed in this diff