aboutsummaryrefslogtreecommitdiff
path: root/lib/xwrap.c
diff options
context:
space:
mode:
authorRob Landley <rob@landley.net>2018-07-08 01:16:16 -0500
committerRob Landley <rob@landley.net>2018-07-08 01:16:16 -0500
commit66d1776fb85530b446dcc1f68929231849a5ad44 (patch)
tree7d9653d2af47f4ce7d6a599316172608d9f6cc38 /lib/xwrap.c
parentd2e317a622c672109ed25176044a3920a1167466 (diff)
downloadtoybox-66d1776fb85530b446dcc1f68929231849a5ad44.tar.gz
Fix division by zero errors and double summary in ping.
Diffstat (limited to 'lib/xwrap.c')
-rw-r--r--lib/xwrap.c11
1 files changed, 6 insertions, 5 deletions
diff --git a/lib/xwrap.c b/lib/xwrap.c
index 26383c92..d5ec9f64 100644
--- a/lib/xwrap.c
+++ b/lib/xwrap.c
@@ -46,12 +46,13 @@ void xexit(void)
{
// Call toys.xexit functions in reverse order added.
while (toys.xexit) {
- // This is typecasting xexit->arg to a function pointer,then calling it.
- // Using the invalid signal number 0 lets the signal handlers distinguish
- // an actual signal from a regular exit.
- ((void (*)(int))(toys.xexit->arg))(0);
+ struct arg_list *al = llist_pop(&toys.xexit);
- free(llist_pop(&toys.xexit));
+ // typecast xexit->arg to a function pointer, then call it using invalid
+ // signal 0 to let signal handlers tell actual signal from regular exit.
+ ((void (*)(int))(al->arg))(0);
+
+ free(al);
}
if (fflush(NULL) || ferror(stdout))
if (!toys.exitval) perror_msg("write");