summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--src/nxt_application.c5
-rw-r--r--src/nxt_runtime.c24
-rw-r--r--src/nxt_runtime.h1
3 files changed, 28 insertions, 2 deletions
diff --git a/src/nxt_application.c b/src/nxt_application.c
index 4689f622..23182401 100644
--- a/src/nxt_application.c
+++ b/src/nxt_application.c
@@ -46,9 +46,10 @@ nxt_discovery_start(nxt_task_t *task, void *data)
nxt_debug(task, "DISCOVERY");
- b = nxt_discovery_modules(task, "build/nginext.*");
-
rt = task->thread->runtime;
+
+ b = nxt_discovery_modules(task, rt->modules);
+
main_port = rt->port_by_type[NXT_PROCESS_MASTER];
nxt_port_socket_write(task, main_port, NXT_PORT_MSG_MODULES, -1,
diff --git a/src/nxt_runtime.c b/src/nxt_runtime.c
index d6518fbe..f070bd94 100644
--- a/src/nxt_runtime.c
+++ b/src/nxt_runtime.c
@@ -703,6 +703,7 @@ nxt_runtime_conf_init(nxt_task_t *task, nxt_runtime_t *rt)
rt->group = NXT_GROUP;
rt->pid = NXT_PID;
rt->log = NXT_LOG;
+ rt->modules = NXT_MODULES;
if (nxt_runtime_conf_read_cmd(task, rt) != NXT_OK) {
return NXT_ERROR;
@@ -740,6 +741,14 @@ nxt_runtime_conf_init(nxt_task_t *task, nxt_runtime_t *rt)
file = nxt_list_first(rt->log_files);
file->name = file_name.start;
+ ret = nxt_file_name_create(rt->mem_pool, &file_name, "%snginext.*%Z",
+ rt->modules);
+ if (nxt_slow_path(ret != NXT_OK)) {
+ return NXT_ERROR;
+ }
+
+ rt->modules = (char *) file_name.start;
+
return NXT_OK;
}
@@ -761,6 +770,8 @@ nxt_runtime_conf_read_cmd(nxt_task_t *task, nxt_runtime_t *rt)
static const char no_group[] = "option \"--group\" requires group name\n";
static const char no_pid[] = "option \"--pid\" requires filename\n";
static const char no_log[] = "option \"--log\" requires filename\n";
+ static const char no_modules[] =
+ "option \"--modules\" requires directory\n";
argv = &nxt_process_argv[1];
@@ -857,6 +868,19 @@ nxt_runtime_conf_read_cmd(nxt_task_t *task, nxt_runtime_t *rt)
continue;
}
+ if (nxt_strcmp(p, "--modules") == 0) {
+ if (*argv == NULL) {
+ write(STDERR_FILENO, no_modules, sizeof(no_modules) - 1);
+ return NXT_ERROR;
+ }
+
+ p = *argv++;
+
+ rt->modules = p;
+
+ continue;
+ }
+
if (nxt_strcmp(p, "--no-daemon") == 0) {
rt->daemon = 0;
continue;
diff --git a/src/nxt_runtime.h b/src/nxt_runtime.h
index 8741f08c..d774aad3 100644
--- a/src/nxt_runtime.h
+++ b/src/nxt_runtime.h
@@ -57,6 +57,7 @@ struct nxt_runtime_s {
const char *group;
const char *pid;
const char *log;
+ const char *modules;
nxt_queue_t engines; /* of nxt_event_engine_t */