Flush gcov files for DBUG_ASSERT and DBUG_SUICIDE

This commit is contained in:
Monty 2021-05-20 15:46:06 +03:00
parent e0a6cfb38b
commit 3b8d4180d5
3 changed files with 14 additions and 2 deletions

View file

@ -269,7 +269,7 @@ SET(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} -DENABLED_DEBUG_SYNC")
OPTION(ENABLE_GCOV "Enable gcov (debug, Linux builds only)" OFF)
IF (ENABLE_GCOV)
MY_CHECK_AND_SET_COMPILER_FLAG("-fprofile-arcs -ftest-coverage -lgcov" DEBUG)
MY_CHECK_AND_SET_COMPILER_FLAG("-DHAVE_gcov -fprofile-arcs -ftest-coverage -lgcov" DEBUG)
ENDIF()
OPTION(WITHOUT_PACKED_SORT_KEYS "disable packed sort keys" OFF)

View file

@ -85,6 +85,9 @@
#undef SAFE_MUTEX
#include <m_string.h>
#include <errno.h>
#ifdef HAVE_gcov
extern void __gcov_flush();
#endif
#ifndef DBUG_OFF
@ -2209,6 +2212,9 @@ void _db_suicide_()
fprintf(stderr, "SIGKILL myself\n");
fflush(stderr);
#ifdef HAVE_gcov
__gcov_flush();
#endif
retval= kill(getpid(), SIGKILL);
assert(retval == 0);
@ -2253,7 +2259,13 @@ my_bool _db_my_assert(const char *file, int line, const char *msg)
my_bool a = my_assert;
_db_flush_();
if (!a)
{
fprintf(stderr, "%s:%d: assert: %s\n", file, line, msg);
fflush(stderr);
#ifdef HAVE_gcov
__gcov_flush();
#endif
}
return a;
}
#else

View file

@ -63,7 +63,7 @@ my $cmd;
if ($opt_purge)
{
$cmd= "find . -name '*.da' -o -name '*.gcda' -o -name '*.gcov' -o ".
"-name '*.dgcov' | grep -v 'README\.gcov' | xargs rm -f ''";
"-name '*.dgcov' | xargs rm -f ''";
logv "Running: $cmd";
system($cmd)==0 or die "system($cmd): $? $!";
exit 0;