# HG changeset patch # User Kim Alvefur # Date 1522333631 -7200 # Node ID 0499f3da0ec449d00310639a8b22253ece57365a # Parent c60fdf14811856ee4a2fb33bbd201d04afdc7d74 util.startup: Factor out processing of plugin and data paths into a separate functions diff -r c60fdf148118 -r 0499f3da0ec4 util/startup.lua --- a/util/startup.lua Tue Mar 27 13:44:40 2018 +0100 +++ b/util/startup.lua Thu Mar 29 16:27:11 2018 +0200 @@ -192,7 +192,21 @@ full_sessions = prosody.full_sessions; hosts = prosody.hosts; - local data_path = config.get("*", "data_path") or CFG_DATADIR or "data"; + prosody.paths = { source = CFG_SOURCEDIR, config = CFG_CONFIGDIR or ".", + plugins = CFG_PLUGINDIR or "plugins", data = "data" }; + + prosody.arg = _G.arg; + + startup.detect_platform(); + startup.detect_installed(); + _G.prosody = prosody; +end + +function startup.setup_datadir() + prosody.paths.data = config.get("*", "data_path") or CFG_DATADIR or "data"; +end + +function startup.setup_plugindir() local custom_plugin_paths = config.get("*", "plugin_paths"); if custom_plugin_paths then local path_sep = package.config:sub(3,3); @@ -200,14 +214,7 @@ -- luacheck: ignore 111 CFG_PLUGINDIR = table.concat(custom_plugin_paths, path_sep)..path_sep..(CFG_PLUGINDIR or "plugins"); end - prosody.paths = { source = CFG_SOURCEDIR, config = CFG_CONFIGDIR or ".", - plugins = CFG_PLUGINDIR or "plugins", data = data_path }; - - prosody.arg = _G.arg; - - startup.detect_platform(); - startup.detect_installed(); - _G.prosody = prosody; + prosody.paths.plugins = CFG_PLUGINDIR; end function startup.chdir() @@ -491,6 +498,8 @@ function startup.prosodyctl() startup.read_config(); startup.init_global_state(); + startup.setup_plugindir(); + startup.setup_datadir(); startup.chdir(); startup.read_version(); startup.switch_user(); @@ -515,6 +524,8 @@ startup.check_dependencies(); startup.load_libraries(); startup.init_global_state(); + startup.setup_plugindir(); + startup.setup_datadir(); startup.init_logging(); startup.chdir(); startup.add_global_prosody_functions();