diff options
author | Noel Grandin <noel.grandin@collabora.co.uk> | 2016-12-08 11:22:37 +0200 |
---|---|---|
committer | Noel Grandin <noel.grandin@collabora.co.uk> | 2017-01-10 06:31:33 +0000 |
commit | 56d071c10ca8016848f1f059aa3eb197fe928844 (patch) | |
tree | 956ba2f8f51a7845c603aa0875e83d40d8938e68 /sal/osl | |
parent | 014b9ac2e4ec22a1eed2fde806edd7a840035a45 (diff) |
rename SAL_DEBUG_TRACE to SAL_DEBUG_BACKTRACE
since "trace" is such a generic term, this makes it easier to actually find the feature when you need it.
And add feature to limit stack depth of the reported backtrace.
Change-Id: Iab3e4ceb2e8480e7b5e2b920eb6c5d7631e21c43
Reviewed-on: https://gerrit.libreoffice.org/31752
Reviewed-by: Noel Grandin <noel.grandin@collabora.co.uk>
Tested-by: Noel Grandin <noel.grandin@collabora.co.uk>
Diffstat (limited to 'sal/osl')
-rw-r--r-- | sal/osl/all/log.cxx | 29 | ||||
-rw-r--r-- | sal/osl/unx/backtraceapi.cxx | 2 | ||||
-rw-r--r-- | sal/osl/w32/backtrace.cxx | 6 |
3 files changed, 24 insertions, 13 deletions
diff --git a/sal/osl/all/log.cxx b/sal/osl/all/log.cxx index 23f45cdb4875..7245a51000b4 100644 --- a/sal/osl/all/log.cxx +++ b/sal/osl/all/log.cxx @@ -68,7 +68,6 @@ char const * toString(sal_detail_LogLevel level) { case SAL_DETAIL_LOG_LEVEL_WARN: return "warn"; case SAL_DETAIL_LOG_LEVEL_DEBUG: - case SAL_DETAIL_LOG_LEVEL_DEBUG_TRACE: return "debug"; default: assert(false); // this cannot happen @@ -188,8 +187,7 @@ void maybeOutputTimestamp(std::ostringstream &s) { #endif bool isDebug(sal_detail_LogLevel level) { - return level == SAL_DETAIL_LOG_LEVEL_DEBUG || - level == SAL_DETAIL_LOG_LEVEL_DEBUG_TRACE; + return level == SAL_DETAIL_LOG_LEVEL_DEBUG; } bool report(sal_detail_LogLevel level, char const * area) { @@ -298,10 +296,6 @@ void log( } s << message; - if (level == SAL_DETAIL_LOG_LEVEL_DEBUG_TRACE) { - s << " at:\n"; - s << OUString(osl_backtraceAsString(), SAL_NO_ACQUIRE); - } s << '\n'; #if defined ANDROID @@ -314,7 +308,6 @@ void log( android_log_level = ANDROID_LOG_WARN; break; case SAL_DETAIL_LOG_LEVEL_DEBUG: - case SAL_DETAIL_LOG_LEVEL_DEBUG_TRACE: android_log_level = ANDROID_LOG_DEBUG; break; default: @@ -336,7 +329,6 @@ void log( prio = LOG_WARNING; break; case SAL_DETAIL_LOG_LEVEL_DEBUG: - case SAL_DETAIL_LOG_LEVEL_DEBUG_TRACE: prio = LOG_DEBUG; break; default: @@ -359,6 +351,16 @@ void log( #endif } +void log_backtrace( + sal_detail_LogLevel level, char const * area, char const * where, + char const * message, int maxNoStackFramesToDisplay) +{ + OUString buff = OUString::createFromAscii(message) + + " at:\n" + + OUString(osl_backtraceAsString(maxNoStackFramesToDisplay), SAL_NO_ACQUIRE); + log(level, area, where, buff.toUtf8().getStr()); +} + } void sal_detail_log( @@ -370,6 +372,15 @@ void sal_detail_log( } } +void sal_detail_log_backtrace( + sal_detail_LogLevel level, char const * area, char const * where, + char const * message, int maxNoStackFramesToDisplay) +{ + if (report(level, area)) { + log_backtrace(level, area, where, message, maxNoStackFramesToDisplay); + } +} + void sal_detail_logFormat( sal_detail_LogLevel level, char const * area, char const * where, char const * format, ...) diff --git a/sal/osl/unx/backtraceapi.cxx b/sal/osl/unx/backtraceapi.cxx index 1895c4360837..d42fe674adb9 100644 --- a/sal/osl/unx/backtraceapi.cxx +++ b/sal/osl/unx/backtraceapi.cxx @@ -13,7 +13,7 @@ #include "misc.hxx" // FIXME: no-op for now; it needs implementing, cf. above. -rtl_uString *osl_backtraceAsString() +rtl_uString *osl_backtraceAsString(int /*maxNoStackFramesToDisplay*/) { OUStringBuffer aBuf; OUString aStr = aBuf.makeStringAndClear(); diff --git a/sal/osl/w32/backtrace.cxx b/sal/osl/w32/backtrace.cxx index b618c6822c51..e4e71c26ba3c 100644 --- a/sal/osl/w32/backtrace.cxx +++ b/sal/osl/w32/backtrace.cxx @@ -17,15 +17,15 @@ #include <rtl/ustrbuf.hxx> -rtl_uString *osl_backtraceAsString() +rtl_uString *osl_backtraceAsString(int maxNoStackFramesToDisplay) { OUStringBuffer aBuf; HANDLE hProcess = GetCurrentProcess(); SymInitialize( hProcess, nullptr, true ); - void * aStack[ 512 ]; - sal_uInt32 nFrames = CaptureStackBackTrace( 0, 512, aStack, nullptr ); + void * aStack[ maxNoStackFramesToDisplay ]; + sal_uInt32 nFrames = CaptureStackBackTrace( 0, maxNoStackFramesToDisplay, aStack, nullptr ); SYMBOL_INFO * pSymbol; pSymbol = static_cast<SYMBOL_INFO *>(calloc( sizeof( SYMBOL_INFO ) + 1024 * sizeof( char ), 1 )); |