// Copyright 2023 The Pigweed 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 // // https://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. #pragma once #include #include // If static_assert wasn't defined by zephyr/sys/__assert.h that means it's not // supported, just ignore it. #ifndef static_assert #define static_assert(...) #endif #include #undef LOG_DBG #undef LOG_INF #undef LOG_WRN #undef LOG_ERR #define Z_PW_LOG(_level, fn, format, ...) \ do { \ if (!Z_LOG_CONST_LEVEL_CHECK(_level)) { \ break; \ } \ fn(format, ##__VA_ARGS__); \ } while (false) #define LOG_DBG(format, ...) \ Z_PW_LOG(LOG_LEVEL_DBG, PW_LOG_DEBUG, format, ##__VA_ARGS__) #define LOG_INF(format, ...) \ Z_PW_LOG(LOG_LEVEL_INF, PW_LOG_INFO, format, ##__VA_ARGS__) #define LOG_WRN(format, ...) \ Z_PW_LOG(LOG_LEVEL_WRN, PW_LOG_WARN, format, ##__VA_ARGS__) #define LOG_ERR(format, ...) \ Z_PW_LOG(LOG_LEVEL_ERR, PW_LOG_ERROR, format, ##__VA_ARGS__)