| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 | #region Copyright notice and license// Copyright 2015, Google Inc.// All rights reserved.//// Redistribution and use in source and binary forms, with or without// modification, are permitted provided that the following conditions are// met:////     * Redistributions of source code must retain the above copyright// notice, this list of conditions and the following disclaimer.//     * Redistributions in binary form must reproduce the above// copyright notice, this list of conditions and the following disclaimer// in the documentation and/or other materials provided with the// distribution.//     * Neither the name of Google Inc. nor the names of its// contributors may be used to endorse or promote products derived from// this software without specific prior written permission.//// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.#endregionusing System;using System.Runtime.CompilerServices;using System.Threading.Tasks;namespace Grpc.Core{    /// <summary>    /// Return type for client streaming calls.    /// </summary>    public sealed class AsyncClientStreamingCall<TRequest, TResponse> : IDisposable    {        readonly IClientStreamWriter<TRequest> requestStream;        readonly Task<TResponse> responseAsync;        readonly Func<Status> getStatusFunc;        readonly Func<Metadata> getTrailersFunc;        readonly Action disposeAction;        public AsyncClientStreamingCall(IClientStreamWriter<TRequest> requestStream, Task<TResponse> responseAsync, Func<Status> getStatusFunc, Func<Metadata> getTrailersFunc, Action disposeAction)        {            this.requestStream = requestStream;            this.responseAsync = responseAsync;            this.getStatusFunc = getStatusFunc;            this.getTrailersFunc = getTrailersFunc;            this.disposeAction = disposeAction;        }        /// <summary>        /// Asynchronous call result.        /// </summary>        public Task<TResponse> ResponseAsync        {            get            {                return this.responseAsync;            }        }        /// <summary>        /// Async stream to send streaming requests.        /// </summary>        public IClientStreamWriter<TRequest> RequestStream        {            get            {                return requestStream;            }        }        /// <summary>        /// Allows awaiting this object directly.        /// </summary>        /// <returns></returns>        public TaskAwaiter<TResponse> GetAwaiter()        {            return responseAsync.GetAwaiter();        }        /// <summary>        /// Gets the call status if the call has already finished.        /// Throws InvalidOperationException otherwise.        /// </summary>        public Status GetStatus()        {            return getStatusFunc();        }        /// <summary>        /// Gets the call trailing metadata if the call has already finished.        /// Throws InvalidOperationException otherwise.        /// </summary>        public Metadata GetTrailers()        {            return getTrailersFunc();        }        /// <summary>        /// Provides means to cleanup after the call.        /// If the call has already finished normally (request stream has been completed and call result has been received), doesn't do anything.        /// Otherwise, requests cancellation of the call which should terminate all pending async operations associated with the call.        /// As a result, all resources being used by the call should be released eventually.        /// </summary>        public void Dispose()        {            disposeAction.Invoke();        }    }}
 |