#pragma once // Simple wrapper around Android's logging interface that also allows other // implementations, and also some misc utilities. // Disable annoying warnings in VS #ifdef _MSC_VER #pragma warning (disable:4996) //strcpy may be dangerous #endif #undef Crash #include // Logging #ifdef _WIN32 #ifdef _M_X64 inline void Crash() { /*DebugBreak();*/ } #else inline void Crash() { __asm { int 3 }; } #endif #else #if defined(ARM) || defined(MIPS) inline void Crash() { char *p = (char *)1337; *p = 1; } #else // TODO: 64-bit version inline void Crash() { asm("int $0x3"); } #endif #endif #if defined(ANDROID) #include // Must only be used for logging #ifndef APP_NAME #define APP_NAME "NativeApp" #endif #define ILOG(...) __android_log_print(ANDROID_LOG_INFO, APP_NAME, __VA_ARGS__); #define WLOG(...) __android_log_print(ANDROID_LOG_WARN, APP_NAME, __VA_ARGS__); #define ELOG(...) __android_log_print(ANDROID_LOG_ERROR, APP_NAME, __VA_ARGS__); #define FLOG(...) { __android_log_print(ANDROID_LOG_ERROR, APP_NAME, __VA_ARGS__); Crash(); } #define MessageBox(a, b, c, d) __android_log_print(ANDROID_LOG_INFO, APP_NAME, "%s %s", (b), (c)); #elif defined(__SYMBIAN32__) #include #define ILOG(...) { qDebug(__VA_ARGS__);} #define WLOG(...) { qDebug(__VA_ARGS__);} #define ELOG(...) { qDebug(__VA_ARGS__);} #define FLOG(...) { qDebug(__VA_ARGS__); Crash();} #else #ifdef _WIN32 void __ods__(const char *p); #define ILOG(...) {char temp[512]; char *p = temp; p += sprintf(p, "I: %s:%i: ", __FILE__, __LINE__); p += sprintf(p, "I: " __VA_ARGS__); p += sprintf(p, "\n"); __ods__(temp);} #define WLOG(...) {char temp[512]; char *p = temp; p += sprintf(p, "W: %s:%i: ", __FILE__, __LINE__); p += sprintf(p, "W: " __VA_ARGS__); p += sprintf(p, "\n"); __ods__(temp);} #define ELOG(...) {char temp[512]; char *p = temp; p += sprintf(p, "E: %s:%i: ", __FILE__, __LINE__); p += sprintf(p, "E: " __VA_ARGS__); p += sprintf(p, "\n"); __ods__(temp);} #define FLOG(...) {char temp[512]; char *p = temp; p += sprintf(p, "F: %s:%i: ", __FILE__, __LINE__); p += sprintf(p, "F: " __VA_ARGS__); p += sprintf(p, "\n"); __ods__(temp); Crash();} // TODO: Win32 version using OutputDebugString #else #include #define ILOG(...) {printf("I: %s:%i: ", __FILE__, __LINE__); printf("I: " __VA_ARGS__); printf("\n");} #define WLOG(...) {printf("W: %s:%i: ", __FILE__, __LINE__); printf("W: " __VA_ARGS__); printf("\n");} #define ELOG(...) {printf("E: %s:%i: ", __FILE__, __LINE__); printf("E: " __VA_ARGS__); printf("\n");} #define FLOG(...) {printf("F: %s:%i: ", __FILE__, __LINE__); printf("F: " __VA_ARGS__); printf("\n"); Crash();} #endif #endif #undef CHECK #define CHECK(a) {if (!(a)) {FLOG("CHECK failed");}} #define CHECK_P(a, ...) {if (!(a)) {FLOG("CHECK failed: " __VA_ARGS__);}} #define CHECK_EQ(a, b) CHECK((a) == (b)); #define CHECK_NE(a, b) CHECK((a) != (b)); #define CHECK_GT(a, b) CHECK((a) > (b)); #define CHECK_GE(a, b) CHECK((a) >= (b)); #define CHECK_LT(a, b) CHECK((a) < (b)); #define CHECK_LE(a, b) CHECK((a) <= (b));