diff options
author | Waqas Hussain <waqas20@gmail.com> | 2010-12-12 17:10:24 +0500 |
---|---|---|
committer | Waqas Hussain <waqas20@gmail.com> | 2010-12-12 17:10:24 +0500 |
commit | c6216253af827113d16c226386602b21f521d391 (patch) | |
tree | 26e47227c662c5daa611bdb0f29ed3b95e491431 | |
parent | 66fd1d3e538e3a1b488368ed5fb90fcf522408d8 (diff) | |
download | prosody-c6216253af827113d16c226386602b21f521d391.tar.gz prosody-c6216253af827113d16c226386602b21f521d391.zip |
prosodyctl: Added support for --config command line argument, and multiple config parsers (to match the main prosody executable).
-rwxr-xr-x | prosodyctl | 27 |
1 files changed, 24 insertions, 3 deletions
@@ -40,9 +40,30 @@ local prosody = prosody; config = require "core.configmanager" do - -- TODO: Check for other formats when we add support for them - -- Use lfs? Make a new conf/ dir? - local ok, level, err = config.load((CFG_CONFIGDIR or ".").."/prosody.cfg.lua"); + local filenames = {}; + + local filename; + if arg[1] == "--config" and arg[2] then + table.insert(filenames, arg[2]); + table.remove(arg, 1); table.remove(arg, 1); + if CFG_CONFIGDIR then + table.insert(filenames, CFG_CONFIGDIR.."/"..arg[2]); + end + else + for _, format in ipairs(config.parsers()) do + table.insert(filenames, (CFG_CONFIGDIR or ".").."/prosody.cfg."..format); + end + end + for _,_filename in ipairs(filenames) do + filename = _filename; + local file = io.open(filename); + if file then + file:close(); + CFG_CONFIGDIR = filename:match("^(.*)[\\/][^\\/]*$"); + break; + end + end + local ok, level, err = config.load(filename); if not ok then print("\n"); print("**************************"); |