diff options
| author | werdl <werdl_@outlook.com> | 2025-06-01 17:31:29 +0100 |
|---|---|---|
| committer | werdl <werdl_@outlook.com> | 2025-06-01 17:31:29 +0100 |
| commit | e80d59d3ae22bef8aea5282fca64204c6cad1492 (patch) | |
| tree | 1e9fef6c96c7233dc4a8561aac64d6f3d5ccee05 /src/parser.c | |
| parent | f869ac4b6038c151f5c89726e17e16db3b90e9b0 (diff) | |
adjust syntax of exec config keyword
Diffstat (limited to 'src/parser.c')
| -rw-r--r-- | src/parser.c | 66 |
1 files changed, 24 insertions, 42 deletions
diff --git a/src/parser.c b/src/parser.c index baa15a0..cfd7c00 100644 --- a/src/parser.c +++ b/src/parser.c @@ -171,6 +171,7 @@ found: char line[512]; int lineno = 0; int should_floatn = 0; + int torun = 0; // Initialize should_float matrix for (int j = 0; j < 256; j++) { @@ -365,55 +366,36 @@ found: char *final = strip(win); char *comma_ptr; - printf("DEBUG: exec command: '%s'\n", final); - char *comma = strtok_r(final, ",", &comma_ptr); - while (comma) { - comma = strip(comma); - if (*comma == '"') { - comma++; - } - char *end = comma + strlen(comma) - 1; - if (*end == '"') { - *end = '\0'; - } + char *cmd = strip(final); + if (*cmd == '"') { + cmd++; + } else { + fprintf(stderr, "sxwmrc:%d: exec not enclosed in quotes", lineno); + } - char *cmd = strdup(comma); - - // we have to fork and exec, because system() is blocking - pid_t pid = fork(); - if (pid == 0) { - char *argv[64]; - char *argv_ptr; - int i = 0; - char *arg = strtok_r(cmd, " ", &argv_ptr); - while (arg && i < 63) { - argv[i++] = arg; - arg = strtok_r(NULL, " ", &argv_ptr); - } - argv[i] = NULL; - execvp(argv[0], argv); - perror("execvp"); - _exit(127); - } - else if (pid > 0) { - // parent: don’t wait, just continue (background) - } - else { - perror("fork"); - } - - printf("DEBUG: exec command: '%s'\n", comma); - - comma = strtok_r(NULL, ",", &comma_ptr); - } - } + char *end = cmd + strlen(cmd) - 1; + if (*end == '"') { + *end = '\0'; + } else { + fprintf(stderr, "sxwmrc:%d: exec not enclosed in quotes", lineno); + } + + printf("DEBUG: exec command '%s'\n", cmd); + cfg->torun[torun] = strdup(cmd); + + if (torun > 254) { + fprintf(stderr, "sxwmrc:%d: too many execs", lineno); + } else { + torun++; + } + } else { fprintf(stderr, "sxwmrc:%d: unknown option '%s'\n", lineno, key); } } - + fclose(f); remap_and_dedupe_binds(cfg); return 0; |
