3 * Copyright 2017 gRPC authors.
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
9 * http://www.apache.org/licenses/LICENSE-2.0
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.
19 #ifndef GRPCPP_SUPPORT_ERROR_DETAILS_IMPL_H
20 #define GRPCPP_SUPPORT_ERROR_DETAILS_IMPL_H
22 #include <grpcpp/support/status.h>
32 /// Map a \a grpc::Status to a \a google::rpc::Status.
33 /// The given \a to object will be cleared.
34 /// On success, returns status with OK.
35 /// Returns status with \a INVALID_ARGUMENT, if failed to deserialize.
36 /// Returns status with \a FAILED_PRECONDITION, if \a to is nullptr.
37 grpc::Status ExtractErrorDetails(const grpc::Status& from,
38 ::google::rpc::Status* to);
40 /// Map \a google::rpc::Status to a \a grpc::Status.
41 /// Returns OK on success.
42 /// Returns status with \a FAILED_PRECONDITION if \a to is nullptr.
43 grpc::Status SetErrorDetails(const ::google::rpc::Status& from,
46 } // namespace grpc_impl
48 #endif // GRPCPP_SUPPORT_ERROR_DETAILS_IMPL_H