20 #if !defined(NX_KIT_API) 32 NX_KIT_API
char pathSeparator();
34 NX_KIT_API
size_t commonPrefixSize(
const std::string& s1,
const std::string& s2);
40 NX_KIT_API
const char* relativeSrcFilename(
const char* file);
42 NX_KIT_API std::string fileBaseNameWithoutExt(
const char* file);
48 #if defined(NX_PRINT_TO_QDEBUG) 49 #define NX_DEBUG_STREAM qDebug().nospace().noquote() 51 static inline QDebug operator<<(QDebug d,
const std::string& s)
53 return d << QString::fromStdString(s);
57 #if !defined(NX_DEBUG_INI) 59 #define NX_DEBUG_INI ini(). 62 #if !defined(NX_DEBUG_ENABLE_OUTPUT) 64 #define NX_DEBUG_ENABLE_OUTPUT NX_DEBUG_INI enableOutput 67 #if !defined(NX_PRINT_PREFIX) 69 #define NX_PRINT_PREFIX ::nx::kit::debug::detail::printPrefix(__FILE__) 72 #if !defined(NX_DEBUG_STREAM) 74 #define NX_DEBUG_STREAM *::nx::kit::debug::stream() 77 #if !defined(NX_DEBUG_ENDL) 79 #define NX_DEBUG_ENDL << std::endl 86 NX_KIT_API std::ostream*& stream();
88 #if !defined(NX_PRINT) 95 ( []() { struct Endl { ~Endl() { NX_DEBUG_STREAM NX_DEBUG_ENDL; } }; \ 96 return std::make_shared<Endl>(); }() ) , \ 97 NX_DEBUG_STREAM << NX_PRINT_PREFIX 105 int NX_KIT_DEBUG_DETAIL_CONCAT(nxOutput_, __line__) = 0; \ 106 NX_KIT_DEBUG_DETAIL_CONCAT(nxOutput_, __line__) != 1 && (NX_DEBUG_ENABLE_OUTPUT); \ 107 ++NX_KIT_DEBUG_DETAIL_CONCAT(nxOutput_, __line__) \ 128 #define NX_KIT_ASSERT( ...) \ 129 NX_KIT_DEBUG_DETAIL_MSVC_EXPAND(NX_KIT_DEBUG_DETAIL_GET_3RD_ARG( \ 130 __VA_ARGS__, NX_KIT_DEBUG_DETAIL_ASSERT2, NX_KIT_DEBUG_DETAIL_ASSERT1, \ 131 args_required)(__VA_ARGS__)) 137 NX_KIT_API
void intentionallyCrash(
const char* message);
146 NX_PRINT << "####### LL line " + ::nx::kit::utils::toString(__LINE__) \ 147 + NX_KIT_DEBUG_DETAIL_THREAD_ID() \ 148 + ", file " + ::nx::kit::debug::relativeSrcFilename(__FILE__); 153 #define NX_PRINT_VALUE(VALUE) \ 154 NX_PRINT << "####### " #VALUE ": " + ::nx::kit::utils::toString(VALUE) 159 #define NX_PRINT_HEX_DUMP(CAPTION, BYTES, SIZE) \ 160 ::nx::kit::debug::detail::printHexDump( \ 161 NX_KIT_DEBUG_DETAIL_PRINT_FUNC, (CAPTION), (const char*) (BYTES), (int) (SIZE)) 166 NX_KIT_API std::string hexDumpLine(
const char* bytes,
int size,
int bytesPerLine = 0);
171 #if !defined(NX_DEBUG_ENABLE_TIME) 173 #define NX_DEBUG_ENABLE_TIME NX_DEBUG_INI enableTime 179 #define NX_TIME_BEGIN(TAG) \ 180 ::nx::kit::debug::detail::Timer nxTimer_##TAG( \ 181 (NX_DEBUG_ENABLE_TIME), NX_KIT_DEBUG_DETAIL_PRINT_FUNC, #TAG) 187 #define NX_TIME_MARK(TAG, MARK) do \ 189 if (NX_DEBUG_ENABLE_TIME) \ 190 nxTimer_##TAG.mark((MARK)); \ 196 #define NX_TIME_END(TAG) do \ 198 if (NX_DEBUG_ENABLE_TIME) \ 199 nxTimer_##TAG.finish(); \ 205 #if !defined(NX_DEBUG_ENABLE_FPS) 207 #define NX_DEBUG_ENABLE_FPS NX_DEBUG_INI enableFps 214 #define NX_FPS(TAG, ...) do \ 216 if (NX_KIT_DEBUG_DETAIL_CONCAT(NX_DEBUG_ENABLE_FPS, TAG)) \ 218 static ::nx::kit::debug::detail::Fps fps( \ 219 NX_KIT_DEBUG_DETAIL_PRINT_FUNC, #TAG); \ 220 fps.mark(__VA_ARGS__); \ 229 typedef std::function<void(const char*)> PrintFunc;
231 #define NX_KIT_DEBUG_DETAIL_PRINT_FUNC ([&](const char* message) { NX_PRINT << message; }) 237 #define NX_KIT_DEBUG_DETAIL_MSVC_EXPAND(ARG) ARG 240 #define NX_KIT_DEBUG_DETAIL_GET_3RD_ARG(ARG1, ARG2, ARG3, ...) ARG3 242 #define NX_KIT_DEBUG_DETAIL_ASSERT1(CONDITION) \ 243 ::nx::kit::debug::detail::doAssert( \ 244 !!(CONDITION), NX_KIT_DEBUG_DETAIL_PRINT_FUNC, #CONDITION, "", __FILE__, __LINE__) 246 #define NX_KIT_DEBUG_DETAIL_ASSERT2(CONDITION, MESSAGE) \ 247 ::nx::kit::debug::detail::doAssert( \ 248 !!(CONDITION), NX_KIT_DEBUG_DETAIL_PRINT_FUNC, #CONDITION, MESSAGE, __FILE__, __LINE__) 250 NX_KIT_API
void assertionFailed(
251 PrintFunc printFunc,
const char* conditionStr,
const std::string& message,
252 const char* file,
int line);
254 inline bool doAssert(
255 bool condition, PrintFunc printFunc,
const char* conditionStr,
const std::string& message,
256 const char* file,
int line)
259 assertionFailed(printFunc, conditionStr, message, file, line);
263 #define NX_KIT_DEBUG_DETAIL_CONCAT(X, Y) NX_KIT_DEBUG_DETAIL_CONCAT2(X, Y) 264 #define NX_KIT_DEBUG_DETAIL_CONCAT2(X, Y) X##Y 267 NX_KIT_API std::string printPrefix(
const char* file);
272 Timer(
bool enabled, PrintFunc printFunc,
const char* tag);
274 void mark(
const char* markStr);
285 Fps(PrintFunc printFunc,
const char* tag);
287 void mark(
const char* markStr =
nullptr);
294 NX_KIT_API
void printHexDump(
295 PrintFunc printFunc,
const char* caption,
const char* bytes,
int size);
303 #if defined(__linux__) 305 #define NX_KIT_DEBUG_DETAIL_THREAD_ID() \ 306 ::nx::kit::utils::format(", thread %llx", (long long) pthread_self()) 307 #elif defined(QT_CORE_LIB) 308 #include <QtCore/QThread> 309 #define NX_KIT_DEBUG_DETAIL_THREAD_ID() \ 310 ::nx::kit::utils::format(", thread %llx", (long long) QThread::currentThreadId()) 313 #define NX_KIT_DEBUG_DETAIL_THREAD_ID() ""
Definition: debug.cpp:291
Definition: debug.cpp:216
Definition: apple_utils.h:6