123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050 |
- // Licensed to the .NET Foundation under one or more agreements.
- // The .NET Foundation licenses this file to you under the Apache 2.0 License.
- // See the LICENSE file in the project root for more information.
- #pragma warning disable 1591
- using System.Linq.Expressions;
- using System.Reactive.Linq;
- namespace System.Reactive.Joins
- {
- /// <summary>
- /// Abstract base class for join patterns represented by an expression tree.
- /// </summary>
- public abstract class QueryablePattern
- {
- /// <summary>
- /// Creates a new join pattern object using the specified expression tree represention.
- /// </summary>
- /// <param name="expression">Expression tree representing the join pattern.</param>
- protected QueryablePattern(Expression expression)
- {
- Expression = expression;
- }
- /// <summary>
- /// Gets the expression tree representing the join pattern.
- /// </summary>
- public Expression Expression { get; private set; }
- }
- /* 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("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("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("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("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("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("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("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("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("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("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("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("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("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("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("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("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("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("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("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("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("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("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("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("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("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("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("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("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("Then").MakeGenericMethod(typeof(TResult));
- return new QueryablePlan<TResult>(
- Expression.Call(
- Expression,
- m,
- selector
- )
- );
- }
- }
- #endregion
- }
- #pragma warning restore 1591
|