// Copyright 2022 gRPC authors. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. #ifndef GRPC_SRC_CORE_LIB_GPR_LOG_INTERNAL_H #define GRPC_SRC_CORE_LIB_GPR_LOG_INTERNAL_H #include #include #include #include /// abort() the process if x is zero, with rudimentary logging to prevent /// circular dependencies with gpr_log. /// Intended for internal invariants. If the error can be recovered from, /// without the possibility of corruption, or might best be reflected via /// an exception in a higher-level language, consider returning error code. #define GPR_ASSERT_INTERNAL(x) \ do { \ if (GPR_UNLIKELY(!(x))) { \ fprintf(stderr, "assertion failed: %s", #x); \ abort(); \ } \ } while (0) #ifndef NDEBUG #define GPR_DEBUG_ASSERT_INTERNAL(x) GPR_ASSERT_INTERNAL(x) #else #define GPR_DEBUG_ASSERT_INTERNAL(x) #endif #define GPR_LOG_ERROR_INTERNAL(format, ...) \ do { \ char f[] = __FILE__; \ char* display_file = f; \ char* slash_pos = strrchr(f, '/'); \ if (slash_pos != nullptr) display_file = slash_pos + 1; \ char prefix[60]; \ sprintf(prefix, "INTERNAL %37s:%d]", display_file, __LINE__); \ fprintf(stderr, "%-60s " format "\n", prefix, __VA_ARGS__); \ } while (0) #endif // GRPC_SRC_CORE_LIB_GPR_LOG_INTERNAL_H