diff options
| author | letouzey | 2012-11-12 13:55:35 +0000 |
|---|---|---|
| committer | letouzey | 2012-11-12 13:55:35 +0000 |
| commit | 863b9fa00230b754458578857732b1e3a9e225f6 (patch) | |
| tree | 2cf55bfa6cbab19eea8c45b0f26fa66d37b4d6ac | |
| parent | 327d2aa33230d99f1b3fc36fee9ecbc0f5ac7813 (diff) | |
Coqide : allow properly closing communication pipes with coqtop
NB: it's important to close coqide's descriptors (ide2top_w and top2ide_r)
in coqtop. We do this indirectly via [Unix.set_close_on_exec].
This way, coqide has the only remaining copies of these descriptors,
and closing them later will have visible effects in coqtop. Cf man 7 pipe
for more details.
This should avoid the need for Unix.kill on coqtop clients (at least
when they aren't inside a long computation).
git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/coq/trunk@15961 85f007b7-540e-0410-9357-904b9bb8a0f7
| -rw-r--r-- | ide/coq.ml | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/ide/coq.ml b/ide/coq.ml index 8607241b4e..7f927042e7 100644 --- a/ide/coq.ml +++ b/ide/coq.ml @@ -232,11 +232,29 @@ let coqtop_zombies () = !toplvl_ctr Note: we use Unix.stderr in Unix.create_process to get debug messages from the coqtop's Ide_slave loop. + + NB: it's important to close coqide's descriptors (ide2top_w and top2ide_r) + in coqtop. We do this indirectly via [Unix.set_close_on_exec]. + This way, coqide has the only remaining copies of these descriptors, + and closing them later will have visible effects in coqtop. Cf man 7 pipe : + + - If all file descriptors referring to the write end of a pipe have been + closed, then an attempt to read(2) from the pipe will see end-of-file + (read(2) will return 0). + - If all file descriptors referring to the read end of a pipe have been + closed, then a write(2) will cause a SIGPIPE signal to be generated for + the calling process. If the calling process is ignoring this signal, + then write(2) fails with the error EPIPE. + + Symmetrically, coqtop's descriptors (ide2top_r and top2ide_w) should be + closed in coqide. *) let open_process_pid prog args = let (ide2top_r,ide2top_w) = Unix.pipe () in let (top2ide_r,top2ide_w) = Unix.pipe () in + Unix.set_close_on_exec ide2top_w; + Unix.set_close_on_exec top2ide_r; let pid = Unix.create_process prog args ide2top_r top2ide_w Unix.stderr in assert (pid <> 0); Unix.close ide2top_r; |
