diff options
| author | werdl <werdl_is_cool@outlook.com> | 2025-05-18 11:05:51 +0100 |
|---|---|---|
| committer | werdl <werdl_is_cool@outlook.com> | 2025-05-18 11:05:51 +0100 |
| commit | 6c467fc57888c34b7d2ce150d6522a931002047a (patch) | |
| tree | 6b37344debfb1dfa6a8a7ec56f0405ba2b727d29 /src/parser.c | |
| parent | d114f2c131f87b9ad2bd23179677832168cc3fe3 (diff) | |
it works now
Diffstat (limited to 'src/parser.c')
| -rw-r--r-- | src/parser.c | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/src/parser.c b/src/parser.c index de63e8d..1ceb7e0 100644 --- a/src/parser.c +++ b/src/parser.c @@ -169,6 +169,12 @@ found: char line[512]; int lineno = 0; + int should_floatn = 0; + + for (int i = 0; i < 256; i++) { + cfg->should_float[i] = NULL; + } + while (fgets(line, sizeof line, f)) { lineno++; char *s = strip(line); @@ -221,6 +227,25 @@ found: else if (!strcmp(key, "snap_distance")) { cfg->snap_distance = atoi(rest); } + else if (!strcmp(key, "should_float")) { + // should_float: <window> + + if (should_floatn >= 256) { + fprintf(stderr, "sxwmrc:%d: too many should_float entries\n", lineno); + continue; + } + + char *win = strip(rest); + + cfg->should_float[should_floatn] = malloc(strlen(win) + 1); + if (!cfg->should_float[should_floatn]) { + fprintf(stderr, "sxwmrc:%d: out of memory\n", lineno); + break; + } + + strcpy(cfg->should_float[should_floatn], win); + should_floatn++; + } else if (!strcmp(key, "call") || !strcmp(key, "bind")) { char *mid = strchr(rest, ':'); if (!mid) { |
