summaryrefslogtreecommitdiff
path: root/src/util/loop_args.h
diff options
context:
space:
mode:
authorLieuwe Rooijakkers <lieuwerooijakkers@gmail.com>2024-08-05 21:11:05 +0200
committerLieuwe Rooijakkers <lieuwerooijakkers@gmail.com>2024-08-05 23:25:10 +0200
commitf95fb4af49b36c68ea8bda88db66fca94cdb5ed2 (patch)
treefaf844001b09771937810586c6afd868af9c59e4 /src/util/loop_args.h
parent0e1d811b25f3719582f9e8619c15c03fc921d565 (diff)
loop_{args,files}: add comment
Diffstat (limited to 'src/util/loop_args.h')
-rw-r--r--src/util/loop_args.h11
1 files changed, 11 insertions, 0 deletions
diff --git a/src/util/loop_args.h b/src/util/loop_args.h
index 359ed75..839d104 100644
--- a/src/util/loop_args.h
+++ b/src/util/loop_args.h
@@ -2,4 +2,15 @@
#include <stdbool.h>
+/// Call `callback` for every argument provided by `args`.
+/// The arguments are interpreted as filenames, "-" is interpreted as stdin.
+/// If the list of arguments is empty, `callback` is called once with
+/// (NULL, true).
+///
+/// `callback` is expected to return the exit code for the program.
+/// If the exit code is positive, the program will exit immediately with the
+/// provided exit code.
+/// If the exit code is negative enumeration is continued, but after enumeration
+/// the function will return the exit code negated (i.e. the function will
+/// never return a negative integer).
int loop_args(char **args, int (*callback)(char *arg, bool isstdin));