aboutsummaryrefslogtreecommitdiffstats
path: root/options.c
diff options
context:
space:
mode:
authorNRK <nrk@disroot.org>2023-10-01 13:06:04 +0200
committerNRK <nrk@disroot.org>2023-10-01 13:23:29 +0200
commit1fc28278b55a5835bfd57821619141bd92eed91d (patch)
tree1d7e9776b6cc542bd9acfe6460c5aa5efd372af4 /options.c
parent2093f36661194f6f820c1233ff8857656a4d1dfe (diff)
downloadnsxiv-1fc28278b55a5835bfd57821619141bd92eed91d.tar.zst
add option to update cache in a background process
the cli flag is undocumented for now, since it's experimental. Closes: https://codeberg.org/nsxiv/nsxiv/issues/416 Closes: https://codeberg.org/nsxiv/nsxiv/pulls/425 Co-authored-by: explosion-mental <explosion0mental@gmail.com>
Diffstat (limited to 'options.c')
-rw-r--r--options.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/options.c b/options.c
index 89dfe20..2835967 100644
--- a/options.c
+++ b/options.c
@@ -81,7 +81,8 @@ void parse_options(int argc, char **argv)
*/
OPT_START = UCHAR_MAX,
OPT_AA,
- OPT_AL
+ OPT_AL,
+ OPT_BG
};
static const struct optparse_long longopts[] = {
{ "framerate", 'A', OPTPARSE_REQUIRED },
@@ -109,6 +110,8 @@ void parse_options(int argc, char **argv)
{ "null", '0', OPTPARSE_NONE },
{ "anti-alias", OPT_AA, OPTPARSE_OPTIONAL },
{ "alpha-layer", OPT_AL, OPTPARSE_OPTIONAL },
+ /* TODO: document this when it's stable */
+ { "bg-cache", OPT_BG, OPTPARSE_OPTIONAL },
{ 0 }, /* end */
};
@@ -145,6 +148,7 @@ void parse_options(int argc, char **argv)
_options.thumb_mode = false;
_options.clean_cache = false;
_options.private_mode = false;
+ _options.background_cache = false;
if (argc > 0) {
s = strrchr(argv[0], '/');
@@ -264,6 +268,11 @@ void parse_options(int argc, char **argv)
error(EXIT_FAILURE, 0, "Invalid argument for option --alpha-layer: %s", op.optarg);
_options.alpha_layer = op.optarg == NULL;
break;
+ case OPT_BG:
+ if (op.optarg != NULL && !STREQ(op.optarg, "no"))
+ error(EXIT_FAILURE, 0, "Invalid argument for option --bg-cache: %s", op.optarg);
+ _options.background_cache = op.optarg == NULL;
+ break;
}
}