| /* |
| ** Copyright 2008, 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. |
| */ |
| |
| #ifndef DEBUG_H |
| #define DEBUG_H |
| |
| #include <stdio.h> |
| |
| #define LOG_TAG "RPC" |
| #include <utils/Log.h> |
| |
| #ifdef RPC_LOG_TO_STDOUT_ONLY |
| #define PRINT(x...) do { \ |
| fprintf(stdout, "%s(%d) ", __FUNCTION__, __LINE__); \ |
| fprintf(stdout, ##x); \ |
| } while(0) |
| #elif defined(RPC_LOG_TO_STDOUT_AND_LOG) |
| #define PRINT(x...) do { \ |
| fprintf(stdout, "%s(%d) ", __FUNCTION__, __LINE__); \ |
| fprintf(stdout, ##x); \ |
| ALOGI(x); \ |
| } while(0) |
| #else |
| #define PRINT(x...) ALOGI(x) |
| #endif |
| |
| #ifdef DEBUG |
| #define D PRINT |
| #else |
| #define D(x...) do { } while(0) |
| #endif |
| |
| #ifdef VERBOSE |
| #define V PRINT |
| #else |
| #define V(x...) do { } while(0) |
| #endif |
| |
| #define E(x...) do { \ |
| fprintf(stderr, "%s(%d) ", __FUNCTION__, __LINE__); \ |
| fprintf(stderr, ##x); \ |
| ALOGE(x); \ |
| } while(0) |
| |
| #define FAILIF(cond, msg...) do { \ |
| if (__builtin_expect (cond, 0)) { \ |
| fprintf(stderr, "%s:%s:(%d): ", __FILE__, __FUNCTION__, __LINE__); \ |
| fprintf(stderr, ##msg); \ |
| ALOGE(msg); \ |
| } \ |
| } while(0) |
| |
| #endif/*DEBUG_H*/ |