diff options
author | okan | 2019-02-25 18:07:48 +0000 |
---|---|---|
committer | okan | 2019-02-25 18:07:48 +0000 |
commit | 35d7a7dabf8e1cb8891b2661e5798de4f9f06f87 (patch) | |
tree | daa2286edc7231eac90016a8ace01db134833026 /calmwm.c | |
parent | 8f7c934cef0f223e5fc0d06b2f0cba386b5b8fd8 (diff) | |
download | cwm-35d7a7dabf8e1cb8891b2661e5798de4f9f06f87.tar.gz |
Add a configtest flag (-n).
based on a diff from Sascha Paunovic.
Diffstat (limited to 'calmwm.c')
-rw-r--r-- | calmwm.c | 18 |
1 files changed, 13 insertions, 5 deletions
@@ -15,7 +15,7 @@ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. * - * $OpenBSD: calmwm.c,v 1.109 2018/02/09 19:54:54 okan Exp $ + * $OpenBSD: calmwm.c,v 1.110 2019/02/25 18:07:48 okan Exp $ */ #include <sys/types.h> @@ -55,7 +55,7 @@ main(int argc, char **argv) { char *display_name = NULL; char *fallback; - int ch, xfd; + int ch, xfd, nflag = 0; struct pollfd pfd[1]; if (!setlocale(LC_CTYPE, "") || !XSupportsLocale()) @@ -66,7 +66,7 @@ main(int argc, char **argv) fallback = u_argv(argv); Conf.wm_argv = u_argv(argv); - while ((ch = getopt(argc, argv, "c:d:v")) != -1) { + while ((ch = getopt(argc, argv, "c:d:nv")) != -1) { switch (ch) { case 'c': free(Conf.conf_file); @@ -75,6 +75,9 @@ main(int argc, char **argv) case 'd': display_name = optarg; break; + case 'n': + nflag = 1; + break; case 'v': Conf.debug++; break; @@ -90,8 +93,13 @@ main(int argc, char **argv) if (signal(SIGHUP, sighdlr) == SIG_ERR) err(1, "signal"); - if (parse_config(Conf.conf_file, &Conf) == -1) + if (parse_config(Conf.conf_file, &Conf) == -1) { warnx("error parsing config file"); + if (nflag) + return 1; + } + if (nflag) + return 0; xfd = x_init(display_name); cwm_status = CWM_RUNNING; @@ -219,7 +227,7 @@ usage(void) { extern char *__progname; - (void)fprintf(stderr, "usage: %s [-v] [-c file] [-d display]\n", + (void)fprintf(stderr, "usage: %s [-nv] [-c file] [-d display]\n", __progname); exit(1); } |