xref: /aosp_15_r20/external/grpc-grpc/include/grpc/compression.h (revision cc02d7e222339f7a4f6ba5f422e6413f4bd931f2)
1*cc02d7e2SAndroid Build Coastguard Worker /*
2*cc02d7e2SAndroid Build Coastguard Worker  *
3*cc02d7e2SAndroid Build Coastguard Worker  * Copyright 2015 gRPC authors.
4*cc02d7e2SAndroid Build Coastguard Worker  *
5*cc02d7e2SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
6*cc02d7e2SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
7*cc02d7e2SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
8*cc02d7e2SAndroid Build Coastguard Worker  *
9*cc02d7e2SAndroid Build Coastguard Worker  *     http://www.apache.org/licenses/LICENSE-2.0
10*cc02d7e2SAndroid Build Coastguard Worker  *
11*cc02d7e2SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
12*cc02d7e2SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
13*cc02d7e2SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14*cc02d7e2SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
15*cc02d7e2SAndroid Build Coastguard Worker  * limitations under the License.
16*cc02d7e2SAndroid Build Coastguard Worker  *
17*cc02d7e2SAndroid Build Coastguard Worker  */
18*cc02d7e2SAndroid Build Coastguard Worker 
19*cc02d7e2SAndroid Build Coastguard Worker #ifndef GRPC_COMPRESSION_H
20*cc02d7e2SAndroid Build Coastguard Worker #define GRPC_COMPRESSION_H
21*cc02d7e2SAndroid Build Coastguard Worker 
22*cc02d7e2SAndroid Build Coastguard Worker #include <stdlib.h>
23*cc02d7e2SAndroid Build Coastguard Worker 
24*cc02d7e2SAndroid Build Coastguard Worker #include <grpc/impl/compression_types.h>  // IWYU pragma: export
25*cc02d7e2SAndroid Build Coastguard Worker #include <grpc/slice.h>
26*cc02d7e2SAndroid Build Coastguard Worker #include <grpc/support/port_platform.h>
27*cc02d7e2SAndroid Build Coastguard Worker 
28*cc02d7e2SAndroid Build Coastguard Worker #ifdef __cplusplus
29*cc02d7e2SAndroid Build Coastguard Worker extern "C" {
30*cc02d7e2SAndroid Build Coastguard Worker #endif
31*cc02d7e2SAndroid Build Coastguard Worker 
32*cc02d7e2SAndroid Build Coastguard Worker /** Return if an algorithm is message compression algorithm. */
33*cc02d7e2SAndroid Build Coastguard Worker GRPCAPI int grpc_compression_algorithm_is_message(
34*cc02d7e2SAndroid Build Coastguard Worker     grpc_compression_algorithm algorithm);
35*cc02d7e2SAndroid Build Coastguard Worker 
36*cc02d7e2SAndroid Build Coastguard Worker /** Return if an algorithm is stream compression algorithm. */
37*cc02d7e2SAndroid Build Coastguard Worker GRPCAPI int grpc_compression_algorithm_is_stream(
38*cc02d7e2SAndroid Build Coastguard Worker     grpc_compression_algorithm algorithm);
39*cc02d7e2SAndroid Build Coastguard Worker 
40*cc02d7e2SAndroid Build Coastguard Worker /** Parses the \a slice as a grpc_compression_algorithm instance and updating \a
41*cc02d7e2SAndroid Build Coastguard Worker  * algorithm. Returns 1 upon success, 0 otherwise. */
42*cc02d7e2SAndroid Build Coastguard Worker GRPCAPI int grpc_compression_algorithm_parse(
43*cc02d7e2SAndroid Build Coastguard Worker     grpc_slice name, grpc_compression_algorithm* algorithm);
44*cc02d7e2SAndroid Build Coastguard Worker 
45*cc02d7e2SAndroid Build Coastguard Worker /** Updates \a name with the encoding name corresponding to a valid \a
46*cc02d7e2SAndroid Build Coastguard Worker  * algorithm. Note that \a name is statically allocated and must *not* be freed.
47*cc02d7e2SAndroid Build Coastguard Worker  * Returns 1 upon success, 0 otherwise. */
48*cc02d7e2SAndroid Build Coastguard Worker GRPCAPI int grpc_compression_algorithm_name(
49*cc02d7e2SAndroid Build Coastguard Worker     grpc_compression_algorithm algorithm, const char** name);
50*cc02d7e2SAndroid Build Coastguard Worker 
51*cc02d7e2SAndroid Build Coastguard Worker /** Returns the compression algorithm corresponding to \a level for the
52*cc02d7e2SAndroid Build Coastguard Worker  * compression algorithms encoded in the \a accepted_encodings bitset.*/
53*cc02d7e2SAndroid Build Coastguard Worker GRPCAPI grpc_compression_algorithm grpc_compression_algorithm_for_level(
54*cc02d7e2SAndroid Build Coastguard Worker     grpc_compression_level level, uint32_t accepted_encodings);
55*cc02d7e2SAndroid Build Coastguard Worker 
56*cc02d7e2SAndroid Build Coastguard Worker GRPCAPI void grpc_compression_options_init(grpc_compression_options* opts);
57*cc02d7e2SAndroid Build Coastguard Worker 
58*cc02d7e2SAndroid Build Coastguard Worker /** Mark \a algorithm as enabled in \a opts. */
59*cc02d7e2SAndroid Build Coastguard Worker GRPCAPI void grpc_compression_options_enable_algorithm(
60*cc02d7e2SAndroid Build Coastguard Worker     grpc_compression_options* opts, grpc_compression_algorithm algorithm);
61*cc02d7e2SAndroid Build Coastguard Worker 
62*cc02d7e2SAndroid Build Coastguard Worker /** Mark \a algorithm as disabled in \a opts. */
63*cc02d7e2SAndroid Build Coastguard Worker GRPCAPI void grpc_compression_options_disable_algorithm(
64*cc02d7e2SAndroid Build Coastguard Worker     grpc_compression_options* opts, grpc_compression_algorithm algorithm);
65*cc02d7e2SAndroid Build Coastguard Worker 
66*cc02d7e2SAndroid Build Coastguard Worker /** Returns true if \a algorithm is marked as enabled in \a opts. */
67*cc02d7e2SAndroid Build Coastguard Worker GRPCAPI int grpc_compression_options_is_algorithm_enabled(
68*cc02d7e2SAndroid Build Coastguard Worker     const grpc_compression_options* opts, grpc_compression_algorithm algorithm);
69*cc02d7e2SAndroid Build Coastguard Worker 
70*cc02d7e2SAndroid Build Coastguard Worker #ifdef __cplusplus
71*cc02d7e2SAndroid Build Coastguard Worker }
72*cc02d7e2SAndroid Build Coastguard Worker #endif
73*cc02d7e2SAndroid Build Coastguard Worker 
74*cc02d7e2SAndroid Build Coastguard Worker #endif /* GRPC_COMPRESSION_H */
75