GRPC C++  1.8.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 extern "C" {
29 struct grpc_byte_buffer;
30 }
31 
32 namespace grpc {
33 
42  public:
44  virtual void assert_fail(const char* failed_assertion, const char* file,
45  int line) = 0;
46 
47  virtual const grpc_completion_queue_factory*
49  const grpc_completion_queue_attributes* attributes) = 0;
51  const grpc_completion_queue_factory* factory,
52  const grpc_completion_queue_attributes* attributes, void* reserved) = 0;
54  void* reserved) = 0;
56  void* reserved) = 0;
59  void* tag,
60  gpr_timespec deadline,
61  void* reserved) = 0;
62 
63  virtual void* gpr_malloc(size_t size) = 0;
64  virtual void gpr_free(void* p) = 0;
65 
66  // These are only to be used to fix edge cases involving grpc_init and
67  // grpc_shutdown. Calling grpc_init from the codegen interface before
68  // the real grpc_init is called will cause a crash, so if you use this
69  // function, ensure that it is not the first call to grpc_init.
70  virtual void grpc_init() = 0;
71  virtual void grpc_shutdown() = 0;
72 
73  virtual void gpr_mu_init(gpr_mu* mu) = 0;
74  virtual void gpr_mu_destroy(gpr_mu* mu) = 0;
75  virtual void gpr_mu_lock(gpr_mu* mu) = 0;
76  virtual void gpr_mu_unlock(gpr_mu* mu) = 0;
77  virtual void gpr_cv_init(gpr_cv* cv) = 0;
78  virtual void gpr_cv_destroy(gpr_cv* cv) = 0;
79  virtual int gpr_cv_wait(gpr_cv* cv, gpr_mu* mu,
80  gpr_timespec abs_deadline) = 0;
81  virtual void gpr_cv_signal(gpr_cv* cv) = 0;
82  virtual void gpr_cv_broadcast(gpr_cv* cv) = 0;
83 
85  virtual void grpc_byte_buffer_destroy(grpc_byte_buffer* bb) = 0;
86 
88  grpc_byte_buffer* buffer)
91  grpc_byte_buffer_reader* reader) = 0;
93  grpc_slice* slice) = 0;
94 
96  size_t nslices) = 0;
97  virtual grpc_slice grpc_slice_new_with_user_data(void* p, size_t len,
98  void (*destroy)(void*),
99  void* user_data) = 0;
101  grpc_status_code status,
102  const char* description,
103  void* reserved) = 0;
104  virtual void grpc_call_ref(grpc_call* call) = 0;
105  virtual void grpc_call_unref(grpc_call* call) = 0;
106  virtual void* grpc_call_arena_alloc(grpc_call* call, size_t length) = 0;
107  virtual grpc_slice grpc_empty_slice() = 0;
108  virtual grpc_slice grpc_slice_malloc(size_t length) = 0;
109  virtual void grpc_slice_unref(grpc_slice slice) = 0;
110  virtual grpc_slice grpc_slice_ref(grpc_slice slice) = 0;
111  virtual grpc_slice grpc_slice_split_tail(grpc_slice* s, size_t split) = 0;
112  virtual grpc_slice grpc_slice_split_head(grpc_slice* s, size_t split) = 0;
113  virtual grpc_slice grpc_slice_sub(grpc_slice s, size_t begin, size_t end) = 0;
114  virtual void grpc_slice_buffer_add(grpc_slice_buffer* sb,
115  grpc_slice slice) = 0;
116  virtual void grpc_slice_buffer_pop(grpc_slice_buffer* sb) = 0;
117  virtual grpc_slice grpc_slice_from_static_buffer(const void* buffer,
118  size_t length) = 0;
119  virtual grpc_slice grpc_slice_from_copied_buffer(const void* buffer,
120  size_t length) = 0;
121 
122  virtual void grpc_metadata_array_init(grpc_metadata_array* array) = 0;
123  virtual void grpc_metadata_array_destroy(grpc_metadata_array* array) = 0;
124 
125  virtual const Status& ok() = 0;
126  virtual const Status& cancelled() = 0;
127 
128  virtual gpr_timespec gpr_inf_future(gpr_clock_type type) = 0;
129  virtual gpr_timespec gpr_time_0(gpr_clock_type type) = 0;
130 };
131 
133 
135 #define GPR_CODEGEN_ASSERT(x) \
136  do { \
137  if (!(x)) { \
138  grpc::g_core_codegen_interface->assert_fail(#x, __FILE__, __LINE__); \
139  } \
140  } while (0)
141 
142 } // namespace grpc
143 
144 #endif // GRPCXX_IMPL_CODEGEN_CORE_CODEGEN_INTERFACE_H
struct grpc_call grpc_call
A Call represents an RPC.
Definition: grpc_types.h:71
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:636
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:423
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:81
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:41
Definition: grpc_types.h:437
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:99
virtual void grpc_completion_queue_destroy(grpc_completion_queue *cq)=0
Definition: grpc_types.h:625
grpc_call_error
Result of a grpc call.
Definition: grpc_types.h:316
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:414
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:41
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:57
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