mirror of
https://github.com/fish-shell/fish-shell.git
synced 2025-01-21 01:47:15 +08:00
Create job-exit caller events inside event handlers
f7e2e7d26b
forbid any job exit events
from happening inside jobs that were themselves event handlers, but
that causes e.g.
```fish
function f --on-event fish_prompt
source (echo "echo hello world" | psub)
end
```
to not trigger psub's cleanup, so it leaves files in $TMPDIR behind.
This was hit by pyenv, because that still uses `source (thing |
psub)`.
Fixes #7792.
This commit is contained in:
parent
fe70c29c48
commit
371516382d
12
src/proc.cpp
12
src/proc.cpp
|
@ -649,13 +649,17 @@ static bool process_clean_after_marking(parser_t &parser, bool allow_interactive
|
||||||
printed = true;
|
printed = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Prepare events for completed jobs, except for jobs that themselves came from event
|
// Prepare events for completed jobs
|
||||||
// handlers.
|
if (j->is_completed()) {
|
||||||
if (!j->from_event_handler() && j->is_completed()) {
|
// If this job already came from an event handler,
|
||||||
if (j->should_report_process_exits()) {
|
// don't create an event or it's easy to get an infinite loop.
|
||||||
|
if (!j->from_event_handler() && j->should_report_process_exits()) {
|
||||||
pid_t pgid = *j->get_pgid();
|
pid_t pgid = *j->get_pgid();
|
||||||
exit_events.push_back(proc_create_event(L"JOB_EXIT", event_type_t::exit, -pgid, 0));
|
exit_events.push_back(proc_create_event(L"JOB_EXIT", event_type_t::exit, -pgid, 0));
|
||||||
}
|
}
|
||||||
|
// Caller exit events we still create, which anecdotally fixes `source (thing | psub)` inside event handlers.
|
||||||
|
// This seems benign since this event is barely used (basically only psub), and it seems hard
|
||||||
|
// to construct an infinite loop with it.
|
||||||
exit_events.push_back(
|
exit_events.push_back(
|
||||||
proc_create_event(L"JOB_EXIT", event_type_t::caller_exit, j->job_id(), 0));
|
proc_create_event(L"JOB_EXIT", event_type_t::caller_exit, j->job_id(), 0));
|
||||||
exit_events.back().desc.param1.caller_id = j->internal_job_id;
|
exit_events.back().desc.param1.caller_id = j->internal_job_id;
|
||||||
|
|
Loading…
Reference in New Issue
Block a user