X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/47fe7ff3821c632b490b16da6b5113f127905a23..06d7ed27a19281549a8293d26cb44dd2d45055ea:/src/common/log.cpp diff --git a/src/common/log.cpp b/src/common/log.cpp index 89ed1264fc..a3214b8630 100644 --- a/src/common/log.cpp +++ b/src/common/log.cpp @@ -458,11 +458,14 @@ void WXDLLEXPORT wxVLogSysError(unsigned long err, const wxString& format, va_li // ---------------------------------------------------------------------------- /* static */ -unsigned wxLog::DoLogNumberOfRepeats() +unsigned wxLog::LogLastRepetitionCountIfNeeded() { - long retval = ms_prevCounter; + wxCRIT_SECT_LOCKER(lock, ms_prevCS); + + const unsigned count = ms_prevCounter; + wxLog *pLogger = GetActiveTarget(); - if ( pLogger && ms_prevCounter > 0 ) + if ( pLogger && ms_prevCounter ) { wxString msg; #if wxUSE_INTL @@ -471,23 +474,20 @@ unsigned wxLog::DoLogNumberOfRepeats() ms_prevCounter), ms_prevCounter); #else - msg.Printf(wxT("The previous message was repeated.")); + msg.Printf(wxT("The previous message was repeated %lu times."), + ms_prevCounter); #endif ms_prevCounter = 0; ms_prevString.clear(); pLogger->DoLog(ms_prevLevel, msg, ms_prevTimeStamp); } - return retval; + + return count; } wxLog::~wxLog() { - if ( ms_prevCounter > 0 ) - { - // looks like the repeat count has not been logged yet, - // so let's do it now - wxLog::DoLogNumberOfRepeats(); - } + LogLastRepetitionCountIfNeeded(); } /* static */ @@ -498,21 +498,28 @@ void wxLog::OnLog(wxLogLevel level, const wxString& szString, time_t t) wxLog *pLogger = GetActiveTarget(); if ( pLogger ) { - if ( GetRepetitionCounting() && ms_prevString == szString ) - { - ms_prevCounter++; - } - else + if ( GetRepetitionCounting() ) { - if ( GetRepetitionCounting() ) + wxCRIT_SECT_LOCKER(lock, ms_prevCS); + + if ( szString == ms_prevString ) { - DoLogNumberOfRepeats(); + ms_prevCounter++; + + // nothing else to do, in particular, don't log the + // repeated message + return; } + + LogLastRepetitionCountIfNeeded(); + + // reset repetition counter for a new message ms_prevString = szString; ms_prevLevel = level; ms_prevTimeStamp = t; - pLogger->DoLog(level, szString, t); } + + pLogger->DoLog(level, szString, t); } } } @@ -901,6 +908,9 @@ wxLogInterposerTemp::wxLogInterposerTemp() // static variables // ---------------------------------------------------------------------------- +#if wxUSE_THREADS +wxCriticalSection wxLog::ms_prevCS; +#endif // wxUSE_THREADS bool wxLog::ms_bRepetCounting = false; wxString wxLog::ms_prevString; unsigned int wxLog::ms_prevCounter = 0;