File: MS\Internal\Automation\SynchronizedInputProviderWrapper.cs
Web Access
Project: src\src\Microsoft.DotNet.Wpf\src\PresentationCore\PresentationCore.csproj (PresentationCore)
// 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.
 
//
// 
//
// Description: SynchronizedInput pattern provider wrapper for WCP
//
//
 
using System;
using System.Windows.Threading;
 
using System.Windows.Media;
using System.Windows.Automation;
using System.Windows.Automation.Provider;
using System.Windows.Automation.Peers;
 
namespace MS.Internal.Automation
{
    // Automation/WCP Wrapper class: Implements that UIAutomation I...Provider
    // interface, and calls through to a WCP AutomationPeer which implements the corresponding
    // I...Provider inteface. Marshalls the call from the RPC thread onto the
    // target AutomationPeer's context.
    //
    // Class has two major parts to it:
    // * Implementation of the I...Provider, which uses Dispatcher.Invoke
    //   to call a private method (lives in second half of the class) via a delegate,
    //   if necessary, packages any params into an object param. Return type of Invoke
    //   must be cast from object to appropriate type.
    // * private methods - one for each interface entry point - which get called back
    //   on the right context. These call through to the peer that's actually
    //   implenting the I...Provider version of the interface. 
    internal class SynchronizedInputProviderWrapper: MarshalByRefObject, ISynchronizedInputProvider
    {
        //------------------------------------------------------
        //
        //  Constructors
        //
        //------------------------------------------------------
 
        #region Constructors
 
        private SynchronizedInputProviderWrapper( AutomationPeer peer, ISynchronizedInputProvider iface )
        {
            _peer = peer;
            _iface = iface;
        }
 
        #endregion Constructors
 
 
        //------------------------------------------------------
        //
        //  Interface ISynchronizedInputProvider
        //
        //------------------------------------------------------
 
        #region Interface ISynchronizedInputProvider
 
        public void StartListening(SynchronizedInputType inputType)
        {
            ElementUtil.Invoke( _peer, new DispatcherOperationCallback( StartListening ), inputType );
}
 
        public void Cancel()
        {
            ElementUtil.Invoke( _peer, new DispatcherOperationCallback( Cancel ), null );
}
        #endregion Interface ISynchronizedInputProvider
 
 
        //------------------------------------------------------
        //
        //  Internal Methods
        //
        //------------------------------------------------------
 
        #region Internal Methods
 
        internal static object Wrap( AutomationPeer peer, object iface )
        {
            return new SynchronizedInputProviderWrapper( peer, (ISynchronizedInputProvider) iface );
        }
 
        #endregion Internal Methods
 
        //------------------------------------------------------
        //
        //  Private Methods
        //
        //------------------------------------------------------
 
        #region Private Methods
 
        private object StartListening( object arg )
        {
            _iface.StartListening((SynchronizedInputType)arg);
            return null;
}
        private object Cancel( object unused )
        {
            _iface.Cancel();
            return null;
}
        #endregion Private Methods
 
 
        //------------------------------------------------------
        //
        //  Private Fields
        //
        //------------------------------------------------------
 
        #region Private Fields
 
        private AutomationPeer _peer;
        private ISynchronizedInputProvider _iface;
 
        #endregion Private Fields
    }
}