// Copyright 2018 Google LLC. All Rights Reserved. This file and proprietary // source code may only be used and distributed under the Widevine Master // License Agreement. // // Log - Platform independent interface for a Logging class // #ifndef WVCDM_UTIL_LOG_H_ #define WVCDM_UTIL_LOG_H_ namespace wvcdm { // Simple logging class. The implementation is platform dependent. typedef enum { LOG_ERROR, LOG_WARN, LOG_INFO, LOG_DEBUG, LOG_VERBOSE } LogPriority; extern LogPriority g_cutoff; // Enable/disable verbose logging (LOGV). // This function is supplied for cases where the system layer does not // initialize logging. This is also needed to initialize logging in // unit tests. void InitLogging(); void Log(const char* file, const char* function, int line, LogPriority level, const char* fmt, ...); // Log APIs #ifndef LOGE #define LOGE(...) Log(__FILE__, __func__, __LINE__, \ wvcdm::LOG_ERROR, __VA_ARGS__) #define LOGW(...) Log(__FILE__, __func__, __LINE__, \ wvcdm::LOG_WARN, __VA_ARGS__) #define LOGI(...) Log(__FILE__, __func__, __LINE__, \ wvcdm::LOG_INFO, __VA_ARGS__) #define LOGD(...) Log(__FILE__, __func__, __LINE__, \ wvcdm::LOG_DEBUG, __VA_ARGS__) #define LOGV(...) Log(__FILE__, __func__, __LINE__, \ wvcdm::LOG_VERBOSE, __VA_ARGS__) #endif } // namespace wvcdm #endif // WVCDM_UTIL_LOG_H_