log.h

来自「Android 一些工具」· C头文件 代码 · 共 347 行

H
347
字号
/* * Copyright (C) 2005 The Android Open Source Project * * 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. *///// C/C++ logging functions.  See the logging documentation for API details.//// We'd like these to be available from C code (in case we import some from// somewhere), so this has a C interface.//// The output will be correct when the log file is shared between multiple// threads and/or multiple processes so long as the operating system// supports O_APPEND.  These calls have mutex-protected data structures// and so are NOT reentrant.  Do not use LOG in a signal handler.//#ifndef _LIBS_CUTILS_LOG_H#define _LIBS_CUTILS_LOG_H#include <stdio.h>#include <time.h>#include <sys/types.h>#include <unistd.h>#ifdef HAVE_PTHREADS#include <pthread.h>#endif#include <stdarg.h>#include <cutils/uio.h>#include <cutils/logd.h>#ifdef __cplusplusextern "C" {#endif// ---------------------------------------------------------------------/* * Normally we strip LOGV (VERBOSE messages) from release builds. * You can modify this (for example with "#define LOG_NDEBUG 0" * at the top of your source file) to change that behavior. */#ifndef LOG_NDEBUG#ifdef NDEBUG#define LOG_NDEBUG 1#else#define LOG_NDEBUG 0#endif#endif/* * This is the local tag used for the following simplified * logging macros.  You can change this preprocessor definition * before using the other macros to change the tag. */#ifndef LOG_TAG#define LOG_TAG NULL#endif// ---------------------------------------------------------------------/* * Simplified macro to send a verbose log message using the current LOG_TAG. */#ifndef LOGV#if LOG_NDEBUG#define LOGV(...)   ((void)0)#else#define LOGV(...) ((void)LOG(LOG_VERBOSE, LOG_TAG, __VA_ARGS__))#endif#endif#define CONDITION(cond)     (__builtin_expect((cond)!=0, 0))#ifndef LOGV_IF#if LOG_NDEBUG#define LOGV_IF(cond, ...)   ((void)0)#else#define LOGV_IF(cond, ...) \    ( (CONDITION(cond)) \    ? ((void)LOG(LOG_VERBOSE, LOG_TAG, __VA_ARGS__)) \    : (void)0 )#endif#endif/* * Simplified macro to send a debug log message using the current LOG_TAG. */#ifndef LOGD#define LOGD(...) ((void)LOG(LOG_DEBUG, LOG_TAG, __VA_ARGS__))#endif#ifndef LOGD_IF#define LOGD_IF(cond, ...) \    ( (CONDITION(cond)) \    ? ((void)LOG(LOG_DEBUG, LOG_TAG, __VA_ARGS__)) \    : (void)0 )#endif/* * Simplified macro to send an info log message using the current LOG_TAG. */#ifndef LOGI#define LOGI(...) ((void)LOG(LOG_INFO, LOG_TAG, __VA_ARGS__))#endif#ifndef LOGI_IF#define LOGI_IF(cond, ...) \    ( (CONDITION(cond)) \    ? ((void)LOG(LOG_INFO, LOG_TAG, __VA_ARGS__)) \    : (void)0 )#endif/* * Simplified macro to send a warning log message using the current LOG_TAG. */#ifndef LOGW#define LOGW(...) ((void)LOG(LOG_WARN, LOG_TAG, __VA_ARGS__))#endif#ifndef LOGW_IF#define LOGW_IF(cond, ...) \    ( (CONDITION(cond)) \    ? ((void)LOG(LOG_WARN, LOG_TAG, __VA_ARGS__)) \    : (void)0 )#endif/* * Simplified macro to send an error log message using the current LOG_TAG. */#ifndef LOGE#define LOGE(...) ((void)LOG(LOG_ERROR, LOG_TAG, __VA_ARGS__))#endif#ifndef LOGE_IF#define LOGE_IF(cond, ...) \    ( (CONDITION(cond)) \    ? ((void)LOG(LOG_ERROR, LOG_TAG, __VA_ARGS__)) \    : (void)0 )#endif// ---------------------------------------------------------------------/* * Conditional based on whether the current LOG_TAG is enabled at * verbose priority. */#ifndef IF_LOGV#if LOG_NDEBUG#define IF_LOGV() if (false)#else#define IF_LOGV() IF_LOG(LOG_VERBOSE, LOG_TAG)#endif#endif/* * Conditional based on whether the current LOG_TAG is enabled at * debug priority. */#ifndef IF_LOGD#define IF_LOGD() IF_LOG(LOG_DEBUG, LOG_TAG)#endif/* * Conditional based on whether the current LOG_TAG is enabled at * info priority. */#ifndef IF_LOGI#define IF_LOGI() IF_LOG(LOG_INFO, LOG_TAG)#endif/* * Conditional based on whether the current LOG_TAG is enabled at * warn priority. */#ifndef IF_LOGW#define IF_LOGW() IF_LOG(LOG_WARN, LOG_TAG)#endif/* * Conditional based on whether the current LOG_TAG is enabled at * error priority. */#ifndef IF_LOGE#define IF_LOGE() IF_LOG(LOG_ERROR, LOG_TAG)#endif// ---------------------------------------------------------------------/* * Log a fatal error.  If the given condition fails, this stops program * execution like a normal assertion, but also generating the given message. * It is NOT stripped from release builds.  Note that the condition test * is -inverted- from the normal assert() semantics. */#define LOG_ALWAYS_FATAL_IF(cond, ...) \    ( (CONDITION(cond)) \    ? ((void)android_printAssert(#cond, LOG_TAG, __VA_ARGS__)) \    : (void)0 )#define LOG_ALWAYS_FATAL(...) \    ( ((void)android_printAssert(NULL, LOG_TAG, __VA_ARGS__)) )/* * Versions of LOG_ALWAYS_FATAL_IF and LOG_ALWAYS_FATAL that * are stripped out of release builds. */#if LOG_NDEBUG#define LOG_FATAL_IF(cond, ...) ((void)0)#define LOG_FATAL(...) ((void)0)#else#define LOG_FATAL_IF(cond, ...) LOG_ALWAYS_FATAL_IF(cond, __VA_ARGS__)#define LOG_FATAL(...) LOG_ALWAYS_FATAL(__VA_ARGS__)#endif/* * Assertion that generates a log message when the assertion fails. * Stripped out of release builds.  Uses the current LOG_TAG. */#define LOG_ASSERT(cond, ...) LOG_FATAL_IF(!(cond), __VA_ARGS__)//#define LOG_ASSERT(cond) LOG_FATAL_IF(!(cond), "Assertion failed: " #cond)// ---------------------------------------------------------------------/* * Basic log message macro. * * Example: *  LOG(LOG_WARN, NULL, "Failed with error %d", errno); * * The second argument may be NULL or "" to indicate the "global" tag. */#ifndef LOG#define LOG(priority, tag, ...) \    LOG_PRI(ANDROID_##priority, tag, __VA_ARGS__)#endif/* * Log macro that allows you to specify a number for the priority. */#ifndef LOG_PRI#define LOG_PRI(priority, tag, ...) \    android_printLog(priority, tag, __VA_ARGS__)#endif/* * Log macro that allows you to pass in a varargs ("args" is a va_list). */#ifndef LOG_PRI_VA#define LOG_PRI_VA(priority, tag, fmt, args) \    android_vprintLog(priority, NULL, tag, fmt, args)#endif/* * Conditional given a desired logging priority and tag. */#ifndef IF_LOG#define IF_LOG(priority, tag) \    if (android_testLog(ANDROID_##priority, tag))#endif// ---------------------------------------------------------------------/* * Event logging. *//* * Event log entry types.  These must match up with the declarations in * java/android/android/util/EventLog.java. */typedef enum {    EVENT_TYPE_INT      = 0,    EVENT_TYPE_LONG     = 1,    EVENT_TYPE_STRING   = 2,    EVENT_TYPE_LIST     = 3,} AndroidEventLogType;#define LOG_EVENT_INT(_tag, _value) {                                       \        int intBuf = _value;                                                \        (void) android_btWriteLog(_tag, EVENT_TYPE_INT, &intBuf,            \            sizeof(intBuf));                                                \    }#define LOG_EVENT_LONG(_tag, _value) {                                      \        long long longBuf = _value;                                         \        (void) android_btWriteLog(_tag, EVENT_TYPE_LONG, &longBuf,          \            sizeof(longBuf));                                               \    }#define LOG_EVENT_STRING(_tag, _value)                                      \    ((void) 0)  /* not implemented -- must combine len with string *//* TODO: something for LIST *//* * =========================================================================== * * The stuff in the rest of this file should not be used directly. */#define android_printLog(prio, tag, fmt...) \    __android_log_print(prio, tag, fmt)#define android_vprintLog(prio, cond, tag, fmt...) \    __android_log_vprint(prio, tag, fmt)#define android_printAssert(cond, tag, fmt...) \    __android_log_assert(cond, tag, fmt)#define android_writeLog(prio, tag, text) \    __android_log_write(prio, tag, text)#define android_bWriteLog(tag, payload, len) \    __android_log_bwrite(tag, payload, len)#define android_btWriteLog(tag, type, payload, len) \    __android_log_btwrite(tag, type, payload, len)	// TODO: remove these prototypes and their users#define android_testLog(prio, tag) (1)#define android_writevLog(vec,num) do{}while(0)#define android_write1Log(str,len) do{}while (0)#define android_setMinPriority(tag, prio) do{}while(0)//#define android_logToCallback(func) do{}while(0)#define android_logToFile(tag, file) (0)#define android_logToFd(tag, fd) (0)#ifdef __cplusplus}#endif#endif // _LIBS_CUTILS_LOG_H

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?