GRPC C++  0.10.0.0
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros
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_ASYNC_GENERIC_SERVICE_H
35 #define GRPCXX_ASYNC_GENERIC_SERVICE_H
36 
37 #include <grpc++/byte_buffer.h>
38 #include <grpc++/stream.h>
39 
40 struct grpc_server;
41 
42 namespace grpc {
43 
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 
55  grpc::string method_;
56  grpc::string host_;
57 };
58 
60  public:
61  // TODO(yangg) Once we can add multiple completion queues to the server
62  // in c core, add a CompletionQueue* argument to the ctor here.
63  // TODO(yangg) support methods list.
64  AsyncGenericService(const grpc::string& methods) : server_(nullptr) {}
65 
67  GenericServerAsyncReaderWriter* reader_writer,
68  CompletionQueue* call_cq,
69  ServerCompletionQueue* notification_cq, void* tag);
70 
71  private:
72  friend class Server;
73  Server* server_;
74 };
75 
76 } // namespace grpc
77 
78 #endif // GRPCXX_ASYNC_GENERIC_SERVICE_H
std::string string
Definition: config.h:112
Definition: server_context.h:60
AsyncGenericService(const grpc::string &methods)
Definition: async_generic_service.h:64
#define GRPC_FINAL
Definition: config.h:71
Definition: async_generic_service.h:59
void RequestCall(GenericServerContext *ctx, GenericServerAsyncReaderWriter *reader_writer, CompletionQueue *call_cq, ServerCompletionQueue *notification_cq, void *tag)
Definition: async_generic_service.cc:40
Definition: server.h:61
ServerAsyncReaderWriter< ByteBuffer, ByteBuffer > GenericServerAsyncReaderWriter
Definition: async_generic_service.h:45
Definition: server_context.h:86
Definition: async_generic_service.h:47
Definition: completion_queue.h:87
Definition: completion_queue.h:162
const grpc::string & host() const
Definition: async_generic_service.h:50
const grpc::string & method() const
Definition: async_generic_service.h:49