Diff

util/startup.lua @ 10600:08f2fe5ac30f 0.11

util.startup: Fix logic to make --config work again
author Matthew Wild <mwild1@gmail.com>
date Sun, 19 Jan 2020 15:39:13 +0000
parent 10597:25a3c8134b0a
child 10601:d8b51833926b
child 10602:f23add0df461
line wrap: on
line diff
--- a/util/startup.lua	Sun Jan 19 15:28:09 2020 +0000
+++ b/util/startup.lua	Sun Jan 19 15:39:13 2020 +0000
@@ -18,50 +18,52 @@
 function startup.parse_args()
 	local parsed_opts = {};
 
-	if #arg > 0 and arg[1] ~= "--config" then
-		while true do
-			local raw_param = arg[1];
-			if not raw_param then
-				break;
-			end
+	if #arg == 0 then
+		return;
+	end
+	while true do
+		local raw_param = arg[1];
+		if not raw_param then
+			break;
+		end
 
-			local prefix = raw_param:match("^%-%-?");
-			if not prefix then
-				break;
-			elseif prefix == "--" and raw_param == "--" then
-				table.remove(arg, 1);
-				break;
-			end
-			local param = table.remove(arg, 1):sub(#prefix+1);
-			if #param == 1 then
-				param = short_params[param];
-			end
+		local prefix = raw_param:match("^%-%-?");
+		if not prefix then
+			break;
+		elseif prefix == "--" and raw_param == "--" then
+			table.remove(arg, 1);
+			break;
+		end
+		local param = table.remove(arg, 1):sub(#prefix+1);
+		if #param == 1 then
+			param = short_params[param];
+		end
 
-			if not param then
-				print("Unknown command-line option: "..tostring(param));
-				print("Perhaps you meant to use prosodyctl instead?");
+		if not param then
+			print("Unknown command-line option: "..tostring(param));
+			print("Perhaps you meant to use prosodyctl instead?");
+			os.exit(1);
+		end
+
+		local param_k, param_v;
+		if value_params[param] then
+			param_k, param_v = param, table.remove(arg, 1);
+			if not param_v then
+				print("Expected a value to follow command-line option: "..raw_param);
 				os.exit(1);
 			end
-
-			local param_k, param_v;
-			if value_params[param] then
-				param_k, param_v = param, table.remove(arg, 1);
-				if not param_v then
-					print("Expected a value to follow command-line option: "..raw_param);
-					os.exit(1);
-				end
-			else
-				param_k, param_v = param:match("^([^=]+)=(.+)$");
-				if not param_k then
-					if param:match("^no%-") then
-						param_k, param_v = param:sub(4), false;
-					else
-						param_k, param_v = param, true;
-					end
+		else
+			param_k, param_v = param:match("^([^=]+)=(.+)$");
+			if not param_k then
+				if param:match("^no%-") then
+					param_k, param_v = param:sub(4), false;
+				else
+					param_k, param_v = param, true;
 				end
 			end
-			parsed_opts[param_k] = param_v;
 		end
+		parsed_opts[param_k] = param_v;
+		print("ARG", param_k, param_v);
 	end
 	prosody.opts = parsed_opts;
 end