diff options
author | Laurent Bercot <ska-skaware@skarnet.org> | 2022-08-10 14:56:35 +0000 |
---|---|---|
committer | Laurent Bercot <ska@appnovation.com> | 2022-08-10 14:56:35 +0000 |
commit | 775b68f68395936980d503edd22dd6bcd3bb05c2 (patch) | |
tree | 79d2548f67e583f9e55261c4694dcce1ffad0379 /src | |
parent | e35bc72c6f8214dbcb9105bb0268aaa86b602e9e (diff) | |
download | mdevd-775b68f68395936980d503edd22dd6bcd3bb05c2.tar.xz |
Fix the refactor... handle_event() modifies event, duh.
Signed-off-by: Laurent Bercot <ska@appnovation.com>
Diffstat (limited to 'src')
-rw-r--r-- | src/mdevd/mdevd.c | 18 |
1 files changed, 8 insertions, 10 deletions
diff --git a/src/mdevd/mdevd.c b/src/mdevd/mdevd.c index 5559225..0a3afcb 100644 --- a/src/mdevd/mdevd.c +++ b/src/mdevd/mdevd.c @@ -1022,17 +1022,15 @@ int main (int argc, char const *const *argv) while (ud.pid || cont == 2) { - int done = 0 ; if (iopause_stamp(x, 1 + (!ud.pid && cont == 2), 0, 0) < 0) strerr_diefu1sys(111, "iopause") ; - if (x[0].revents & IOPAUSE_READ) - done |= handle_signals(&event, script, scriptlen, storage, envmatch, &ud) ; - if (!ud.pid && cont == 2 && x[1].revents & IOPAUSE_READ) - done |= handle_event(x[1].fd, &event, script, scriptlen, storage, envmatch, &ud) ; - if (done) - { - if (outputfd && !output_event(outputfd, &event)) outputfd = 0 ; - if (rebc) rebc_event(rebc, &event) ; - } + if (x[0].revents & IOPAUSE_READ && handle_signals(&event, script, scriptlen, storage, envmatch, &ud)) + goto dorebc ; + if (!ud.pid && cont == 2 && x[1].revents & IOPAUSE_READ && handle_event(x[1].fd, &event, script, scriptlen, storage, envmatch, &ud)) + goto dorebc ; + continue ; + dorebc: + if (outputfd && !output_event(outputfd, &event)) outputfd = 0 ; + if (rebc) rebc_event(rebc, &event) ; } script_free(script, scriptlen, envmatch, envmatchlen) ; |