GRPC C++  1.9.0
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
core_codegen_interface.h
Go to the documentation of this file.
1 /*
2  *
3  * Copyright 2015 gRPC authors.
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  * http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  *
17  */
18 
19 #ifndef GRPCXX_IMPL_CODEGEN_CORE_CODEGEN_INTERFACE_H
20 #define GRPCXX_IMPL_CODEGEN_CORE_CODEGEN_INTERFACE_H
21 
26 #include <grpc/impl/codegen/sync.h>
27 
28 namespace grpc {
29 
38  public:
40  virtual void assert_fail(const char* failed_assertion, const char* file,
41  int line) = 0;
42 
43  virtual const grpc_completion_queue_factory*
45  const grpc_completion_queue_attributes* attributes) = 0;
47  const grpc_completion_queue_factory* factory,
48  const grpc_completion_queue_attributes* attributes, void* reserved) = 0;
50  void* reserved) = 0;
52  void* reserved) = 0;
55  void* tag,
56  gpr_timespec deadline,
57  void* reserved) = 0;
58 
59  virtual void* gpr_malloc(size_t size) = 0;
60  virtual void gpr_free(void* p) = 0;
61 
62  // These are only to be used to fix edge cases involving grpc_init and
63  // grpc_shutdown. Calling grpc_init from the codegen interface before
64  // the real grpc_init is called will cause a crash, so if you use this
65  // function, ensure that it is not the first call to grpc_init.
66  virtual void grpc_init() = 0;
67  virtual void grpc_shutdown() = 0;
68 
69  virtual void gpr_mu_init(gpr_mu* mu) = 0;
70  virtual void gpr_mu_destroy(gpr_mu* mu) = 0;
71  virtual void gpr_mu_lock(gpr_mu* mu) = 0;
72  virtual void gpr_mu_unlock(gpr_mu* mu) = 0;
73  virtual void gpr_cv_init(gpr_cv* cv) = 0;
74  virtual void gpr_cv_destroy(gpr_cv* cv) = 0;
75  virtual int gpr_cv_wait(gpr_cv* cv, gpr_mu* mu,
76  gpr_timespec abs_deadline) = 0;
77  virtual void gpr_cv_signal(gpr_cv* cv) = 0;
78  virtual void gpr_cv_broadcast(gpr_cv* cv) = 0;
79 
81  virtual void grpc_byte_buffer_destroy(grpc_byte_buffer* bb) = 0;
82 
84  grpc_byte_buffer* buffer)
87  grpc_byte_buffer_reader* reader) = 0;
89  grpc_slice* slice) = 0;
90 
92  size_t nslices) = 0;
93  virtual grpc_slice grpc_slice_new_with_user_data(void* p, size_t len,
94  void (*destroy)(void*),
95  void* user_data) = 0;
97  grpc_status_code status,
98  const char* description,
99  void* reserved) = 0;
100  virtual void grpc_call_ref(grpc_call* call) = 0;
101  virtual void grpc_call_unref(grpc_call* call) = 0;
102  virtual void* grpc_call_arena_alloc(grpc_call* call, size_t length) = 0;
103  virtual grpc_slice grpc_empty_slice() = 0;
104  virtual grpc_slice grpc_slice_malloc(size_t length) = 0;
105  virtual void grpc_slice_unref(grpc_slice slice) = 0;
106  virtual grpc_slice grpc_slice_ref(grpc_slice slice) = 0;
107  virtual grpc_slice grpc_slice_split_tail(grpc_slice* s, size_t split) = 0;
108  virtual grpc_slice grpc_slice_split_head(grpc_slice* s, size_t split) = 0;
109  virtual grpc_slice grpc_slice_sub(grpc_slice s, size_t begin, size_t end) = 0;
110  virtual void grpc_slice_buffer_add(grpc_slice_buffer* sb,
111  grpc_slice slice) = 0;
112  virtual void grpc_slice_buffer_pop(grpc_slice_buffer* sb) = 0;
113  virtual grpc_slice grpc_slice_from_static_buffer(const void* buffer,
114  size_t length) = 0;
115  virtual grpc_slice grpc_slice_from_copied_buffer(const void* buffer,
116  size_t length) = 0;
117 
118  virtual void grpc_metadata_array_init(grpc_metadata_array* array) = 0;
119  virtual void grpc_metadata_array_destroy(grpc_metadata_array* array) = 0;
120 
121  virtual const Status& ok() = 0;
122  virtual const Status& cancelled() = 0;
123 
124  virtual gpr_timespec gpr_inf_future(gpr_clock_type type) = 0;
125  virtual gpr_timespec gpr_time_0(gpr_clock_type type) = 0;
126 };
127 
129 
131 #define GPR_CODEGEN_ASSERT(x) \
132  do { \
133  if (!(x)) { \
134  grpc::g_core_codegen_interface->assert_fail(#x, __FILE__, __LINE__); \
135  } \
136  } while (0)
137 
138 } // namespace grpc
139 
140 #endif // GRPCXX_IMPL_CODEGEN_CORE_CODEGEN_INTERFACE_H
struct grpc_call grpc_call
A Call represents an RPC.
Definition: grpc_types.h:70
virtual void grpc_slice_buffer_pop(grpc_slice_buffer *sb)=0
virtual const grpc_completion_queue_factory * grpc_completion_queue_factory_lookup(const grpc_completion_queue_attributes *attributes)=0
virtual grpc_slice grpc_slice_sub(grpc_slice s, size_t begin, size_t end)=0
grpc_status_code
Definition: status.h:26
virtual void gpr_mu_unlock(gpr_mu *mu)=0
virtual grpc_slice grpc_slice_malloc(size_t length)=0
virtual void grpc_init()=0
virtual void grpc_call_ref(grpc_call *call)=0
struct grpc_completion_queue_factory grpc_completion_queue_factory
The completion queue factory structure is opaque to the callers of grpc.
Definition: grpc_types.h:635
virtual gpr_timespec gpr_inf_future(gpr_clock_type type)=0
virtual void grpc_metadata_array_destroy(grpc_metadata_array *array)=0
virtual void gpr_cv_init(gpr_cv *cv)=0
virtual void grpc_byte_buffer_reader_destroy(grpc_byte_buffer_reader *reader)=0
virtual grpc_slice grpc_slice_new_with_user_data(void *p, size_t len, void(*destroy)(void *), void *user_data)=0
virtual grpc_slice grpc_slice_from_copied_buffer(const void *buffer, size_t length)=0
The result of an operation.
Definition: grpc_types.h:422
virtual grpc_slice grpc_empty_slice()=0
virtual void gpr_cv_signal(gpr_cv *cv)=0
A grpc_slice s, if initialized, represents the byte range s.bytes[0..s.length-1]. ...
Definition: slice.h:80
virtual grpc_completion_queue * grpc_completion_queue_create_for_pluck(void *reserved)=0
virtual void grpc_call_unref(grpc_call *call)=0
virtual const Status & cancelled()=0
virtual void gpr_cv_broadcast(gpr_cv *cv)=0
Definition: grpc_types.h:40
Definition: grpc_types.h:436
virtual void gpr_mu_destroy(gpr_mu *mu)=0
Represents an expandable array of slices, to be interpreted as a single item.
Definition: slice.h:98
virtual void grpc_completion_queue_destroy(grpc_completion_queue *cq)=0
Definition: grpc_types.h:624
grpc_call_error
Result of a grpc call.
Definition: grpc_types.h:315
virtual int gpr_cv_wait(gpr_cv *cv, gpr_mu *mu, gpr_timespec abs_deadline)=0
virtual void grpc_byte_buffer_destroy(grpc_byte_buffer *bb)=0
pthread_cond_t gpr_cv
Definition: sync_posix.h:27
virtual grpc_slice grpc_slice_from_static_buffer(const void *buffer, size_t length)=0
Definition: sync_windows.h:24
virtual grpc_completion_queue * grpc_completion_queue_create(const grpc_completion_queue_factory *factory, const grpc_completion_queue_attributes *attributes, void *reserved)=0
virtual void gpr_mu_lock(gpr_mu *mu)=0
virtual void assert_fail(const char *failed_assertion, const char *file, int line)=0
Upon a failed assertion, log the error.
CoreCodegenInterface * g_core_codegen_interface
Definition: call.h:46
virtual grpc_byte_buffer * grpc_raw_byte_buffer_create(grpc_slice *slice, size_t nslices)=0
#define GRPC_MUST_USE_RESULT
Definition: port_platform.h:432
virtual grpc_byte_buffer * grpc_byte_buffer_copy(grpc_byte_buffer *bb)=0
virtual void gpr_cv_destroy(gpr_cv *cv)=0
virtual grpc_slice grpc_slice_ref(grpc_slice slice)=0
virtual void * grpc_call_arena_alloc(grpc_call *call, size_t length)=0
virtual grpc_slice grpc_slice_split_tail(grpc_slice *s, size_t split)=0
virtual void grpc_slice_unref(grpc_slice slice)=0
virtual void gpr_mu_init(gpr_mu *mu)=0
virtual void grpc_shutdown()=0
virtual void grpc_slice_buffer_add(grpc_slice_buffer *sb, grpc_slice slice)=0
Interface between the codegen library and the minimal subset of core features required by the generat...
Definition: core_codegen_interface.h:37
Did it work? If it didn't, why?
Definition: status.h:30
Analogous to struct timespec.
Definition: gpr_types.h:47
virtual const Status & ok()=0
gpr_clock_type
The clocks we support.
Definition: gpr_types.h:31
virtual int grpc_byte_buffer_reader_next(grpc_byte_buffer_reader *reader, grpc_slice *slice)=0
virtual void grpc_metadata_array_init(grpc_metadata_array *array)=0
Definition: byte_buffer_reader.h:28
virtual void gpr_free(void *p)=0
virtual int grpc_byte_buffer_reader_init(grpc_byte_buffer_reader *reader, grpc_byte_buffer *buffer) GRPC_MUST_USE_RESULT=0
struct grpc_completion_queue grpc_completion_queue
Completion Queues enable notification of the completion of asynchronous actions.
Definition: grpc_types.h:56
virtual gpr_timespec gpr_time_0(gpr_clock_type type)=0
virtual grpc_slice grpc_slice_split_head(grpc_slice *s, size_t split)=0
virtual grpc_call_error grpc_call_cancel_with_status(grpc_call *call, grpc_status_code status, const char *description, void *reserved)=0
virtual grpc_event grpc_completion_queue_pluck(grpc_completion_queue *cq, void *tag, gpr_timespec deadline, void *reserved)=0
virtual grpc_completion_queue * grpc_completion_queue_create_for_next(void *reserved)=0
virtual void * gpr_malloc(size_t size)=0