summaryrefslogtreecommitdiff
path: root/util/libreboot-utils/lottery.c
diff options
context:
space:
mode:
authorLeah Rowe <leah@libreboot.org>2026-03-28 06:53:37 +0000
committerLeah Rowe <leah@libreboot.org>2026-03-28 06:53:37 +0000
commit0f1a22174fc7c6a0767617974640d521074174d5 (patch)
tree5d13587d08a95332518b3191b7440424f0f190c6 /util/libreboot-utils/lottery.c
parent55f0e6ac8e540cea24af64070bfc49a032729511 (diff)
libreboot-utils: unified error handling
i now use a singleton hook function per program: nvmutil, mkhtemp and lottery call this at the startup of your program: (void) errhook(exit_cleanup); then provide that function. make it static, so that each program has its own version. if you're writing a program that handles lots of files for example, and you want to do certain cleanup on exit (including error exit), this can be quite useful. Signed-off-by: Leah Rowe <leah@libreboot.org>
Diffstat (limited to 'util/libreboot-utils/lottery.c')
-rw-r--r--util/libreboot-utils/lottery.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/util/libreboot-utils/lottery.c b/util/libreboot-utils/lottery.c
index fd0728fd..cbe8a871 100644
--- a/util/libreboot-utils/lottery.c
+++ b/util/libreboot-utils/lottery.c
@@ -11,6 +11,9 @@
#include "include/common.h"
static void
+exit_cleanup(void);
+
+static void
spew_buf(const void *data, size_t len);
int
@@ -22,6 +25,8 @@ main(int argc, char **argv)
(void) argc, (void) argv;
xpledgex("stdio", NULL);
+ (void) errhook(exit_cleanup);
+
buf = mkrbuf(BUFSIZ + 1);
if (!memcmp(buf, buf + (BUFSIZ >> 1), BUFSIZ >> 1))
same = 1;
@@ -73,3 +78,9 @@ spew_buf(const void *data, size_t len)
printf("%08zx\n", len);
}
+
+static void
+exit_cleanup(void)
+{
+ return;
+}