aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Uffe Jakobsen <uffe@uffe.org>2020-02-14 16:05:18 +0100
committerGravatar GitHub <noreply@github.com>2020-02-14 20:35:17 +0530
commit1ed015e988073a04376f3dbf054a0cf50462f3f5 (patch)
tree4cd145e59065d621ce8165d674f22d6da27337c9
parent9b199b32535b6b28ea3845a975deac23465e5c16 (diff)
downloadnnn-1ed015e988073a04376f3dbf054a0cf50462f3f5.tar.gz
Add NNN_OPTS environment variable feature (#476)
-rw-r--r--src/nnn.c43
1 files changed, 34 insertions, 9 deletions
diff --git a/src/nnn.c b/src/nnn.c
index 2285178..077aaa2 100644
--- a/src/nnn.c
+++ b/src/nnn.c
@@ -553,16 +553,18 @@ static const char * const messages[] = {
};
/* Supported configuration environment variables */
-#define NNN_BMS 0
-#define NNN_PLUG 1
-#define NNN_OPENER 2
-#define NNN_COLORS 3
-#define NNNLVL 4
-#define NNN_PIPE 5
-#define NNN_ARCHIVE 6 /* strings end here */
-#define NNN_TRASH 7 /* flags begin here */
+#define NNN_OPTS 0
+#define NNN_BMS 1
+#define NNN_PLUG 2
+#define NNN_OPENER 3
+#define NNN_COLORS 4
+#define NNNLVL 5
+#define NNN_PIPE 6
+#define NNN_ARCHIVE 7 /* strings end here */
+#define NNN_TRASH 8 /* flags begin here */
static const char * const env_cfg[] = {
+ "NNN_OPTS",
"NNN_BMS",
"NNN_PLUG",
"NNN_OPENER",
@@ -6450,7 +6452,12 @@ int main(int argc, char *argv[])
mmask_t mask;
#endif
- while ((opt = getopt(argc, argv, "aAb:cdeEgHKnop:QrRs:St:vVxh")) != -1) {
+ const char* const env_opts = xgetenv(env_cfg[NNN_OPTS], NULL);
+ int env_opts_idx = (env_opts ? (int)strlen(env_opts) : -1);
+ while ((opt = (--env_opts_idx >= 0 ? env_opts[env_opts_idx] : getopt(argc, argv, "aAb:cdeEgHKnop:QrRs:St:vVxh"))) != -1) {
+ if (env_opts_idx >= 0) {
+ optarg = NULL;
+ }
switch (opt) {
case 'a':
cfg.mtime = 0;
@@ -6495,6 +6502,9 @@ int main(int argc, char *argv[])
cfg.nonavopen = 1;
break;
case 'p':
+ if (!optarg) {
+ break;
+ }
cfg.picker = 1;
if (optarg[0] == '-' && optarg[1] == '\0')
cfg.pickraw = 1;
@@ -6524,24 +6534,39 @@ int main(int argc, char *argv[])
cfg.rollover = 0;
break;
case 's':
+ if (!optarg) {
+ break;
+ }
session = optarg;
break;
case 't':
+ if (!optarg) {
+ break;
+ }
idletimeout = atoi(optarg);
break;
case 'v':
namecmpfn = &xstrverscasecmp;
break;
case 'V':
+ if (env_opts_idx >= 0) {
+ break;
+ }
fprintf(stdout, "%s\n", VERSION);
return _SUCCESS;
case 'x':
cfg.x11 = 1;
break;
case 'h':
+ if (env_opts_idx >= 0) {
+ break;
+ }
usage();
return _SUCCESS;
default:
+ if (env_opts_idx >= 0) {
+ fprintf(stderr, "Error: Illegal option '%c' in env var '%s'\n\n", opt, env_cfg[NNN_OPTS]);
+ }
usage();
return _FAILURE;
}