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

@@ -22,11 +22,6 @@
# include "event/process.c.generated.h"
#endif
/// Externally defined with gcov.
#ifdef USE_GCOV
void __gcov_dump(void);
#endif
// Time for a process to exit cleanly before we send KILL.
// For PTY processes SIGTERM is sent first (in case SIGHUP was not enough).
#define KILL_TIMEOUT_MS 2000
@@ -55,11 +50,6 @@ int process_spawn(Process *proc, bool in, bool out, bool err)
proc->err.closed = true;
}
#ifdef USE_GCOV
// Dump coverage data before forking, to avoid "Merge mismatch" errors.
__gcov_dump();
#endif
int status;
switch (proc->type) {
case kProcessTypeUv:

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);