| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143 | // Copyright (c) Microsoft Open Technologies, Inc. All rights reserved. See License.txt in the project root for license information.#if !NO_PERFusing System;using System.Reactive.Concurrency;using System.Reactive.Disposables;using System.Reflection;using System.Threading;//// BREAKING CHANGE v2 > v1.x - FromEvent[Pattern] now has an implicit SubscribeOn and Publish operation.//// See FromEvent.cs for more information.//namespace System.Reactive.Linq.ObservableImpl{    class FromEventPattern    {        public class Impl<TDelegate, TEventArgs> : ClassicEventProducer<TDelegate, EventPattern<TEventArgs>>#if !NO_EVENTARGS_CONSTRAINT            where TEventArgs : EventArgs#endif        {            private readonly Func<EventHandler<TEventArgs>, TDelegate> _conversion;            public Impl(Action<TDelegate> addHandler, Action<TDelegate> removeHandler, IScheduler scheduler)                : base(addHandler, removeHandler, scheduler)            {            }            public Impl(Func<EventHandler<TEventArgs>, TDelegate> conversion, Action<TDelegate> addHandler, Action<TDelegate> removeHandler, IScheduler scheduler)                : base(addHandler, removeHandler, scheduler)            {                _conversion = conversion;            }            protected override TDelegate GetHandler(Action<EventPattern<TEventArgs>> onNext)            {                var handler = default(TDelegate);                if (_conversion == null)                {                    Action<object, TEventArgs> h = (sender, eventArgs) => onNext(new EventPattern<TEventArgs>(sender, eventArgs));                    handler = ReflectionUtils.CreateDelegate<TDelegate>(h, typeof(Action<object, TEventArgs>).GetMethod("Invoke"));                }                else                {                    handler = _conversion((sender, eventArgs) => onNext(new EventPattern<TEventArgs>(sender, eventArgs)));                }                return handler;            }        }        public class Impl<TDelegate, TSender, TEventArgs> : ClassicEventProducer<TDelegate, EventPattern<TSender, TEventArgs>>#if !NO_EVENTARGS_CONSTRAINT            where TEventArgs : EventArgs#endif        {            public Impl(Action<TDelegate> addHandler, Action<TDelegate> removeHandler, IScheduler scheduler)                : base(addHandler, removeHandler, scheduler)            {            }            protected override TDelegate GetHandler(Action<EventPattern<TSender, TEventArgs>> onNext)            {                Action<TSender, TEventArgs> h = (sender, eventArgs) => onNext(new EventPattern<TSender, TEventArgs>(sender, eventArgs));                return ReflectionUtils.CreateDelegate<TDelegate>(h, typeof(Action<TSender, TEventArgs>).GetMethod("Invoke"));            }        }        public class Handler<TSender, TEventArgs, TResult> : EventProducer<Delegate, TResult>        {            private readonly object _target;            private readonly Type _delegateType;            private readonly MethodInfo _addMethod;            private readonly MethodInfo _removeMethod;            private readonly Func<TSender, TEventArgs, TResult> _getResult;#if HAS_WINRT            private readonly bool _isWinRT;#endif            public Handler(object target, Type delegateType, MethodInfo addMethod, MethodInfo removeMethod, Func<TSender, TEventArgs, TResult> getResult, bool isWinRT, IScheduler scheduler)                : base(scheduler)            {#if HAS_WINRT                _isWinRT = isWinRT;#else                System.Diagnostics.Debug.Assert(!isWinRT);#endif                _target = target;                _delegateType = delegateType;                _addMethod = addMethod;                _removeMethod = removeMethod;                _getResult = getResult;            }            protected override Delegate GetHandler(Action<TResult> onNext)            {                Action<TSender, TEventArgs> h = (sender, eventArgs) => onNext(_getResult(sender, eventArgs));                return ReflectionUtils.CreateDelegate(_delegateType, h, typeof(Action<TSender, TEventArgs>).GetMethod("Invoke"));            }            protected override IDisposable AddHandler(Delegate handler)            {                var removeHandler = default(Action);                try                {#if HAS_WINRT                    if (_isWinRT)                    {                        var token = _addMethod.Invoke(_target, new object[] { handler });                        removeHandler = () => _removeMethod.Invoke(_target, new object[] { token });                    }                    else#endif                    {                        _addMethod.Invoke(_target, new object[] { handler });                        removeHandler = () => _removeMethod.Invoke(_target, new object[] { handler });                    }                }                catch (TargetInvocationException tie)                {                    throw tie.InnerException;                }                return Disposable.Create(() =>                {                    try                    {                        removeHandler();                    }                    catch (TargetInvocationException tie)                    {                        throw tie.InnerException;                    }                });            }        }    }}#endif
 |