compositor: add --no-config command line option
authorPekka Paalanen <pekka.paalanen@collabora.co.uk>
Wed, 7 May 2014 13:26:25 +0000 (16:26 +0300)
committerKristian Høgsberg <krh@bitplanet.net>
Fri, 9 May 2014 22:00:01 +0000 (15:00 -0700)
Useful for unit tests. If Weston finds a weston.ini during unit tests,
it will load it and all the modules it asks for. We need a way to
prevent loading arbitrary modules from the command line.

Signed-off-by: Pekka Paalanen <pekka.paalanen@collabora.co.uk>
man/weston.man
src/compositor.c

index fd1c7a5..735235f 100644 (file)
@@ -130,6 +130,12 @@ suite. The file is searched for in
 .IR "__weston_modules_dir__" ,
 or you can pass an absolute path.
 .TP
+.BR \-\-no-config
+Do not read
+.I weston.ini
+for the compositor. Avoids e.g. loading compositor modules via the
+configuration file, which is useful for unit tests.
+.TP
 \fB\-\^S\fR\fIname\fR, \fB\-\-socket\fR=\fIname\fR
 Weston will listen in the Wayland socket called
 .IR name .
index cd1ca9a..574db2d 100644 (file)
@@ -4042,6 +4042,7 @@ usage(int error_code)
                "  -i, --idle-time=SECS\tIdle time in seconds\n"
                "  --modules\t\tLoad the comma-separated list of modules\n"
                "  --log==FILE\t\tLog to the given file\n"
+               "  --no-config\t\tDo not read weston.ini\n"
                "  -h, --help\t\tThis help message\n\n");
 
        fprintf(stderr,
@@ -4152,7 +4153,8 @@ int main(int argc, char *argv[])
        int32_t help = 0;
        char *socket_name = "wayland-0";
        int32_t version = 0;
-       struct weston_config *config;
+       int32_t noconfig = 0;
+       struct weston_config *config = NULL;
        struct weston_config_section *section;
        struct wl_client *primary_client;
        struct wl_listener primary_client_destroyed;
@@ -4166,6 +4168,7 @@ int main(int argc, char *argv[])
                { WESTON_OPTION_STRING, "log", 0, &log },
                { WESTON_OPTION_BOOLEAN, "help", 'h', &help },
                { WESTON_OPTION_BOOLEAN, "version", 0, &version },
+               { WESTON_OPTION_BOOLEAN, "no-config", 0, &noconfig },
        };
 
        parse_options(core_options, ARRAY_LENGTH(core_options), &argc, argv);
@@ -4204,7 +4207,8 @@ int main(int argc, char *argv[])
        signals[3] = wl_event_loop_add_signal(loop, SIGCHLD, sigchld_handler,
                                              NULL);
 
-       config = weston_config_parse("weston.ini");
+       if (noconfig == 0)
+               config = weston_config_parse("weston.ini");
        if (config != NULL) {
                weston_log("Using config file '%s'\n",
                           weston_config_get_full_path(config));