gcov: use __gcov_flush instead of __gcov_dump (#10260)

This restores missing coverage again.

Move it to process_spawn in os/pty_process_unix.c, since it seems to
break printargs-test on Windows/AppVeyor otherwise (#10248).
This commit is contained in:
Daniel Hahler
2019-06-18 06:31:57 +02:00
committed by GitHub
parent 4946751906
commit 25e04c1d98
2 changed files with 10 additions and 10 deletions

View File

@@ -36,6 +36,11 @@
# include "os/pty_process_unix.c.generated.h"
#endif
/// Externally defined with gcov.
#ifdef USE_GCOV
void __gcov_flush(void);
#endif
/// termios saved at startup (for TUI) or initialized by pty_process_spawn().
static struct termios termios_default;
@@ -59,6 +64,11 @@ int pty_process_spawn(PtyProcess *ptyproc)
init_termios(&termios_default);
}
#ifdef USE_GCOV
// Flush coverage data before forking, to avoid "Merge mismatch" errors.
__gcov_flush();
#endif
int status = 0; // zero or negative error code (libuv convention)
Process *proc = (Process *)ptyproc;
assert(proc->err.closed);