| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331 | // Generated by the protocol buffer compiler.  DO NOT EDIT!// source: route_guide.proto// Original file comments:// Copyright 2015 gRPC authors.//// Licensed under the Apache License, Version 2.0 (the "License");// you may not use this file except in compliance with the License.// You may obtain a copy of the License at////     http://www.apache.org/licenses/LICENSE-2.0//// Unless required by applicable law or agreed to in writing, software// distributed under the License is distributed on an "AS IS" BASIS,// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.// See the License for the specific language governing permissions and// limitations under the License.//#region Designer generated codeusing System;using System.Threading;using System.Threading.Tasks;using grpc = global::Grpc.Core;namespace Routeguide {  /// <summary>  /// Interface exported by the server.  /// </summary>  public static partial class RouteGuide  {    static readonly string __ServiceName = "routeguide.RouteGuide";    static readonly grpc::Marshaller<global::Routeguide.Point> __Marshaller_Point = grpc::Marshallers.Create((arg) => global::Google.Protobuf.MessageExtensions.ToByteArray(arg), global::Routeguide.Point.Parser.ParseFrom);    static readonly grpc::Marshaller<global::Routeguide.Feature> __Marshaller_Feature = grpc::Marshallers.Create((arg) => global::Google.Protobuf.MessageExtensions.ToByteArray(arg), global::Routeguide.Feature.Parser.ParseFrom);    static readonly grpc::Marshaller<global::Routeguide.Rectangle> __Marshaller_Rectangle = grpc::Marshallers.Create((arg) => global::Google.Protobuf.MessageExtensions.ToByteArray(arg), global::Routeguide.Rectangle.Parser.ParseFrom);    static readonly grpc::Marshaller<global::Routeguide.RouteSummary> __Marshaller_RouteSummary = grpc::Marshallers.Create((arg) => global::Google.Protobuf.MessageExtensions.ToByteArray(arg), global::Routeguide.RouteSummary.Parser.ParseFrom);    static readonly grpc::Marshaller<global::Routeguide.RouteNote> __Marshaller_RouteNote = grpc::Marshallers.Create((arg) => global::Google.Protobuf.MessageExtensions.ToByteArray(arg), global::Routeguide.RouteNote.Parser.ParseFrom);    static readonly grpc::Method<global::Routeguide.Point, global::Routeguide.Feature> __Method_GetFeature = new grpc::Method<global::Routeguide.Point, global::Routeguide.Feature>(        grpc::MethodType.Unary,        __ServiceName,        "GetFeature",        __Marshaller_Point,        __Marshaller_Feature);    static readonly grpc::Method<global::Routeguide.Rectangle, global::Routeguide.Feature> __Method_ListFeatures = new grpc::Method<global::Routeguide.Rectangle, global::Routeguide.Feature>(        grpc::MethodType.ServerStreaming,        __ServiceName,        "ListFeatures",        __Marshaller_Rectangle,        __Marshaller_Feature);    static readonly grpc::Method<global::Routeguide.Point, global::Routeguide.RouteSummary> __Method_RecordRoute = new grpc::Method<global::Routeguide.Point, global::Routeguide.RouteSummary>(        grpc::MethodType.ClientStreaming,        __ServiceName,        "RecordRoute",        __Marshaller_Point,        __Marshaller_RouteSummary);    static readonly grpc::Method<global::Routeguide.RouteNote, global::Routeguide.RouteNote> __Method_RouteChat = new grpc::Method<global::Routeguide.RouteNote, global::Routeguide.RouteNote>(        grpc::MethodType.DuplexStreaming,        __ServiceName,        "RouteChat",        __Marshaller_RouteNote,        __Marshaller_RouteNote);    /// <summary>Service descriptor</summary>    public static global::Google.Protobuf.Reflection.ServiceDescriptor Descriptor    {      get { return global::Routeguide.RouteGuideReflection.Descriptor.Services[0]; }    }    /// <summary>Base class for server-side implementations of RouteGuide</summary>    public abstract partial class RouteGuideBase    {      /// <summary>      /// A simple RPC.      ///      /// Obtains the feature at a given position.      ///      /// A feature with an empty name is returned if there's no feature at the given      /// position.      /// </summary>      /// <param name="request">The request received from the client.</param>      /// <param name="context">The context of the server-side call handler being invoked.</param>      /// <returns>The response to send back to the client (wrapped by a task).</returns>      public virtual global::System.Threading.Tasks.Task<global::Routeguide.Feature> GetFeature(global::Routeguide.Point request, grpc::ServerCallContext context)      {        throw new grpc::RpcException(new grpc::Status(grpc::StatusCode.Unimplemented, ""));      }      /// <summary>      /// A server-to-client streaming RPC.      ///      /// Obtains the Features available within the given Rectangle.  Results are      /// streamed rather than returned at once (e.g. in a response message with a      /// repeated field), as the rectangle may cover a large area and contain a      /// huge number of features.      /// </summary>      /// <param name="request">The request received from the client.</param>      /// <param name="responseStream">Used for sending responses back to the client.</param>      /// <param name="context">The context of the server-side call handler being invoked.</param>      /// <returns>A task indicating completion of the handler.</returns>      public virtual global::System.Threading.Tasks.Task ListFeatures(global::Routeguide.Rectangle request, grpc::IServerStreamWriter<global::Routeguide.Feature> responseStream, grpc::ServerCallContext context)      {        throw new grpc::RpcException(new grpc::Status(grpc::StatusCode.Unimplemented, ""));      }      /// <summary>      /// A client-to-server streaming RPC.      ///      /// Accepts a stream of Points on a route being traversed, returning a      /// RouteSummary when traversal is completed.      /// </summary>      /// <param name="requestStream">Used for reading requests from the client.</param>      /// <param name="context">The context of the server-side call handler being invoked.</param>      /// <returns>The response to send back to the client (wrapped by a task).</returns>      public virtual global::System.Threading.Tasks.Task<global::Routeguide.RouteSummary> RecordRoute(grpc::IAsyncStreamReader<global::Routeguide.Point> requestStream, grpc::ServerCallContext context)      {        throw new grpc::RpcException(new grpc::Status(grpc::StatusCode.Unimplemented, ""));      }      /// <summary>      /// A Bidirectional streaming RPC.      ///      /// Accepts a stream of RouteNotes sent while a route is being traversed,      /// while receiving other RouteNotes (e.g. from other users).      /// </summary>      /// <param name="requestStream">Used for reading requests from the client.</param>      /// <param name="responseStream">Used for sending responses back to the client.</param>      /// <param name="context">The context of the server-side call handler being invoked.</param>      /// <returns>A task indicating completion of the handler.</returns>      public virtual global::System.Threading.Tasks.Task RouteChat(grpc::IAsyncStreamReader<global::Routeguide.RouteNote> requestStream, grpc::IServerStreamWriter<global::Routeguide.RouteNote> responseStream, grpc::ServerCallContext context)      {        throw new grpc::RpcException(new grpc::Status(grpc::StatusCode.Unimplemented, ""));      }    }    /// <summary>Client for RouteGuide</summary>    public partial class RouteGuideClient : grpc::ClientBase<RouteGuideClient>    {      /// <summary>Creates a new client for RouteGuide</summary>      /// <param name="channel">The channel to use to make remote calls.</param>      public RouteGuideClient(grpc::Channel channel) : base(channel)      {      }      /// <summary>Creates a new client for RouteGuide that uses a custom <c>CallInvoker</c>.</summary>      /// <param name="callInvoker">The callInvoker to use to make remote calls.</param>      public RouteGuideClient(grpc::CallInvoker callInvoker) : base(callInvoker)      {      }      /// <summary>Protected parameterless constructor to allow creation of test doubles.</summary>      protected RouteGuideClient() : base()      {      }      /// <summary>Protected constructor to allow creation of configured clients.</summary>      /// <param name="configuration">The client configuration.</param>      protected RouteGuideClient(ClientBaseConfiguration configuration) : base(configuration)      {      }      /// <summary>      /// A simple RPC.      ///      /// Obtains the feature at a given position.      ///      /// A feature with an empty name is returned if there's no feature at the given      /// position.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="headers">The initial metadata to send with the call. This parameter is optional.</param>      /// <param name="deadline">An optional deadline for the call. The call will be cancelled if deadline is hit.</param>      /// <param name="cancellationToken">An optional token for canceling the call.</param>      /// <returns>The response received from the server.</returns>      public virtual global::Routeguide.Feature GetFeature(global::Routeguide.Point request, grpc::Metadata headers = null, DateTime? deadline = null, CancellationToken cancellationToken = default(CancellationToken))      {        return GetFeature(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      /// <summary>      /// A simple RPC.      ///      /// Obtains the feature at a given position.      ///      /// A feature with an empty name is returned if there's no feature at the given      /// position.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="options">The options for the call.</param>      /// <returns>The response received from the server.</returns>      public virtual global::Routeguide.Feature GetFeature(global::Routeguide.Point request, grpc::CallOptions options)      {        return CallInvoker.BlockingUnaryCall(__Method_GetFeature, null, options, request);      }      /// <summary>      /// A simple RPC.      ///      /// Obtains the feature at a given position.      ///      /// A feature with an empty name is returned if there's no feature at the given      /// position.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="headers">The initial metadata to send with the call. This parameter is optional.</param>      /// <param name="deadline">An optional deadline for the call. The call will be cancelled if deadline is hit.</param>      /// <param name="cancellationToken">An optional token for canceling the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncUnaryCall<global::Routeguide.Feature> GetFeatureAsync(global::Routeguide.Point request, grpc::Metadata headers = null, DateTime? deadline = null, CancellationToken cancellationToken = default(CancellationToken))      {        return GetFeatureAsync(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      /// <summary>      /// A simple RPC.      ///      /// Obtains the feature at a given position.      ///      /// A feature with an empty name is returned if there's no feature at the given      /// position.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="options">The options for the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncUnaryCall<global::Routeguide.Feature> GetFeatureAsync(global::Routeguide.Point request, grpc::CallOptions options)      {        return CallInvoker.AsyncUnaryCall(__Method_GetFeature, null, options, request);      }      /// <summary>      /// A server-to-client streaming RPC.      ///      /// Obtains the Features available within the given Rectangle.  Results are      /// streamed rather than returned at once (e.g. in a response message with a      /// repeated field), as the rectangle may cover a large area and contain a      /// huge number of features.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="headers">The initial metadata to send with the call. This parameter is optional.</param>      /// <param name="deadline">An optional deadline for the call. The call will be cancelled if deadline is hit.</param>      /// <param name="cancellationToken">An optional token for canceling the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncServerStreamingCall<global::Routeguide.Feature> ListFeatures(global::Routeguide.Rectangle request, grpc::Metadata headers = null, DateTime? deadline = null, CancellationToken cancellationToken = default(CancellationToken))      {        return ListFeatures(request, new grpc::CallOptions(headers, deadline, cancellationToken));      }      /// <summary>      /// A server-to-client streaming RPC.      ///      /// Obtains the Features available within the given Rectangle.  Results are      /// streamed rather than returned at once (e.g. in a response message with a      /// repeated field), as the rectangle may cover a large area and contain a      /// huge number of features.      /// </summary>      /// <param name="request">The request to send to the server.</param>      /// <param name="options">The options for the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncServerStreamingCall<global::Routeguide.Feature> ListFeatures(global::Routeguide.Rectangle request, grpc::CallOptions options)      {        return CallInvoker.AsyncServerStreamingCall(__Method_ListFeatures, null, options, request);      }      /// <summary>      /// A client-to-server streaming RPC.      ///      /// Accepts a stream of Points on a route being traversed, returning a      /// RouteSummary when traversal is completed.      /// </summary>      /// <param name="headers">The initial metadata to send with the call. This parameter is optional.</param>      /// <param name="deadline">An optional deadline for the call. The call will be cancelled if deadline is hit.</param>      /// <param name="cancellationToken">An optional token for canceling the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncClientStreamingCall<global::Routeguide.Point, global::Routeguide.RouteSummary> RecordRoute(grpc::Metadata headers = null, DateTime? deadline = null, CancellationToken cancellationToken = default(CancellationToken))      {        return RecordRoute(new grpc::CallOptions(headers, deadline, cancellationToken));      }      /// <summary>      /// A client-to-server streaming RPC.      ///      /// Accepts a stream of Points on a route being traversed, returning a      /// RouteSummary when traversal is completed.      /// </summary>      /// <param name="options">The options for the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncClientStreamingCall<global::Routeguide.Point, global::Routeguide.RouteSummary> RecordRoute(grpc::CallOptions options)      {        return CallInvoker.AsyncClientStreamingCall(__Method_RecordRoute, null, options);      }      /// <summary>      /// A Bidirectional streaming RPC.      ///      /// Accepts a stream of RouteNotes sent while a route is being traversed,      /// while receiving other RouteNotes (e.g. from other users).      /// </summary>      /// <param name="headers">The initial metadata to send with the call. This parameter is optional.</param>      /// <param name="deadline">An optional deadline for the call. The call will be cancelled if deadline is hit.</param>      /// <param name="cancellationToken">An optional token for canceling the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncDuplexStreamingCall<global::Routeguide.RouteNote, global::Routeguide.RouteNote> RouteChat(grpc::Metadata headers = null, DateTime? deadline = null, CancellationToken cancellationToken = default(CancellationToken))      {        return RouteChat(new grpc::CallOptions(headers, deadline, cancellationToken));      }      /// <summary>      /// A Bidirectional streaming RPC.      ///      /// Accepts a stream of RouteNotes sent while a route is being traversed,      /// while receiving other RouteNotes (e.g. from other users).      /// </summary>      /// <param name="options">The options for the call.</param>      /// <returns>The call object.</returns>      public virtual grpc::AsyncDuplexStreamingCall<global::Routeguide.RouteNote, global::Routeguide.RouteNote> RouteChat(grpc::CallOptions options)      {        return CallInvoker.AsyncDuplexStreamingCall(__Method_RouteChat, null, options);      }      /// <summary>Creates a new instance of client from given <c>ClientBaseConfiguration</c>.</summary>      protected override RouteGuideClient NewInstance(ClientBaseConfiguration configuration)      {        return new RouteGuideClient(configuration);      }    }    /// <summary>Creates service definition that can be registered with a server</summary>    /// <param name="serviceImpl">An object implementing the server-side handling logic.</param>    public static grpc::ServerServiceDefinition BindService(RouteGuideBase serviceImpl)    {      return grpc::ServerServiceDefinition.CreateBuilder()          .AddMethod(__Method_GetFeature, serviceImpl.GetFeature)          .AddMethod(__Method_ListFeatures, serviceImpl.ListFeatures)          .AddMethod(__Method_RecordRoute, serviceImpl.RecordRoute)          .AddMethod(__Method_RouteChat, serviceImpl.RouteChat).Build();    }  }}#endregion
 |