GRPC C++  1.0.0
async_generic_service.h
Go to the documentation of this file.
1 /*
2  *
3  * Copyright 2015, Google Inc.
4  * All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions are
8  * met:
9  *
10  * * Redistributions of source code must retain the above copyright
11  * notice, this list of conditions and the following disclaimer.
12  * * Redistributions in binary form must reproduce the above
13  * copyright notice, this list of conditions and the following disclaimer
14  * in the documentation and/or other materials provided with the
15  * distribution.
16  * * Neither the name of Google Inc. nor the names of its
17  * contributors may be used to endorse or promote products derived from
18  * this software without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31  *
32  */
33 
34 #ifndef GRPCXX_GENERIC_ASYNC_GENERIC_SERVICE_H
35 #define GRPCXX_GENERIC_ASYNC_GENERIC_SERVICE_H
36 
39 
40 struct grpc_server;
41 
42 namespace grpc {
43 
44 typedef ServerAsyncReaderWriter<ByteBuffer, ByteBuffer>
46 
48  public:
49  const grpc::string& method() const { return method_; }
50  const grpc::string& host() const { return host_; }
51 
52  private:
53  friend class Server;
54  friend class ServerInterface;
55 
56  grpc::string method_;
57  grpc::string host_;
58 };
59 
61  public:
62  AsyncGenericService() : server_(nullptr) {}
63 
64  void RequestCall(GenericServerContext* ctx,
65  GenericServerAsyncReaderWriter* reader_writer,
66  CompletionQueue* call_cq,
67  ServerCompletionQueue* notification_cq, void* tag);
68 
69  private:
70  friend class Server;
71  Server* server_;
72 };
73 
74 } // namespace grpc
75 
76 #endif // GRPCXX_GENERIC_ASYNC_GENERIC_SERVICE_H
AsyncGenericService()
Definition: async_generic_service.h:62
std::string string
Definition: config.h:118
Definition: async_stream.h:468
struct grpc_server grpc_server
A server listens to some port and responds to request calls.
Definition: grpc_types.h:57
Definition: async_generic_service.h:60
Models a gRPC server.
Definition: server.h:67
Definition: alarm.h:48
ServerAsyncReaderWriter< ByteBuffer, ByteBuffer > GenericServerAsyncReaderWriter
Definition: async_generic_service.h:45
Definition: server_context.h:91
Models a gRPC server.
Definition: server_interface.h:58
Definition: async_generic_service.h:47
A thin wrapper around grpc_completion_queue (see / src/core/surface/completion_queue.h).
Definition: completion_queue.h:97
#define GRPC_FINAL
Definition: config.h:72
A specific type of completion queue used by the processing of notifications by servers.
Definition: completion_queue.h:235
const grpc::string & host() const
Definition: async_generic_service.h:50
const grpc::string & method() const
Definition: async_generic_service.h:49