diff options
-rw-r--r-- | src/nvim/CMakeLists.txt | 1 | ||||
-rw-r--r-- | src/nvim/event/process.c | 10 |
2 files changed, 11 insertions, 0 deletions
diff --git a/src/nvim/CMakeLists.txt b/src/nvim/CMakeLists.txt index 77c5bf59e4..99171dbb02 100644 --- a/src/nvim/CMakeLists.txt +++ b/src/nvim/CMakeLists.txt @@ -7,6 +7,7 @@ if(USE_GCOV) set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} --coverage") set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} --coverage") set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} --coverage") + add_compile_definitions(USE_GCOV) endif() endif() diff --git a/src/nvim/event/process.c b/src/nvim/event/process.c index 7a8a39dbcf..7059a41def 100644 --- a/src/nvim/event/process.c +++ b/src/nvim/event/process.c @@ -22,6 +22,11 @@ # 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 @@ -50,6 +55,11 @@ 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: |