mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-14 14:03:58 +00:00
Use some modern initialization syntax in builtin_wait
Avoids potentially dangling pointers.
This commit is contained in:
parent
51d34e1960
commit
bc28bd7d6d
1 changed files with 3 additions and 6 deletions
|
@ -13,9 +13,8 @@
|
||||||
static int retval;
|
static int retval;
|
||||||
|
|
||||||
static bool all_jobs_finished() {
|
static bool all_jobs_finished() {
|
||||||
job_t *j;
|
|
||||||
job_iterator_t jobs;
|
job_iterator_t jobs;
|
||||||
while ((j = jobs.next())) {
|
while (job_t *j = jobs.next()) {
|
||||||
// If any job is not completed, return false.
|
// If any job is not completed, return false.
|
||||||
// If there are stopped jobs, they are ignored.
|
// If there are stopped jobs, they are ignored.
|
||||||
if ((j->flags & JOB_CONSTRUCTED) && !job_is_completed(j) && !job_is_stopped(j)) {
|
if ((j->flags & JOB_CONSTRUCTED) && !job_is_completed(j) && !job_is_stopped(j)) {
|
||||||
|
@ -26,7 +25,6 @@ static bool all_jobs_finished() {
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool any_jobs_finished(size_t jobs_len) {
|
static bool any_jobs_finished(size_t jobs_len) {
|
||||||
job_t *j;
|
|
||||||
job_iterator_t jobs;
|
job_iterator_t jobs;
|
||||||
bool no_jobs_running = true;
|
bool no_jobs_running = true;
|
||||||
|
|
||||||
|
@ -34,7 +32,7 @@ static bool any_jobs_finished(size_t jobs_len) {
|
||||||
if (jobs_len != jobs.count()) {
|
if (jobs_len != jobs.count()) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
while ((j = jobs.next())) {
|
while (job_t *j = jobs.next()) {
|
||||||
// If any job is completed, return true.
|
// If any job is completed, return true.
|
||||||
if ((j->flags & JOB_CONSTRUCTED) && (job_is_completed(j) || job_is_stopped(j))) {
|
if ((j->flags & JOB_CONSTRUCTED) && (job_is_completed(j) || job_is_stopped(j))) {
|
||||||
return true;
|
return true;
|
||||||
|
@ -64,9 +62,8 @@ static void wait_for_backgrounds(bool any_flag) {
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool all_specified_jobs_finished(const std::vector<int> &wjobs_pid) {
|
static bool all_specified_jobs_finished(const std::vector<int> &wjobs_pid) {
|
||||||
job_t *j;
|
|
||||||
for (auto pid : wjobs_pid) {
|
for (auto pid : wjobs_pid) {
|
||||||
if ((j = job_get_from_pid(pid))) {
|
if (job_t *j = job_get_from_pid(pid)) {
|
||||||
// If any specified job is not completed, return false.
|
// If any specified job is not completed, return false.
|
||||||
// If there are stopped jobs, they are ignored.
|
// If there are stopped jobs, they are ignored.
|
||||||
if ((j->flags & JOB_CONSTRUCTED) && !job_is_completed(j) && !job_is_stopped(j)) {
|
if ((j->flags & JOB_CONSTRUCTED) && !job_is_completed(j) && !job_is_stopped(j)) {
|
||||||
|
|
Loading…
Reference in a new issue