Software /
code /
clix
Diff
clix.lua @ 33:f1901c9de891
clix.lua: Improvements to argument handling and command detection. In particular options may now precede commands.
author | Matthew Wild <mwild1@gmail.com> |
---|---|
date | Sat, 29 May 2010 21:13:27 +0100 |
parent | 32:cda6a004ff79 |
child | 34:d4f8fc71d936 |
line wrap: on
line diff
--- a/clix.lua Sat May 29 20:58:27 2010 +0100 +++ b/clix.lua Sat May 29 21:13:27 2010 +0100 @@ -12,9 +12,7 @@ short_opts = { v = "verbose", q = "quiet", t = "to", f = "from", e = "type", a = "account", p = "password", r = "resource", o = "presence", c = "chatroom" } -local command = arg[1]; - -if not command then +if #arg < 1 then print("Command Line XMPP, available commands:"); for module in pairs(package.preload) do if module:match("^clix%.") then @@ -26,30 +24,10 @@ return 0; end -local ok, m = pcall(require, "clix."..command); -if not ok then - local is_debug; - for i=1,#arg do - if arg[i] == "--debug" then - is_debug = true; break; - end - end - print("Error running command '"..command..(is_debug and "" or "' (run with --debug to see full error)")); - if is_debug then - print(m); - end - return 1; -end - -if type(m) ~= "function" then - print(command.." is not a valid command"); - return 1; -end - local accounts = { default = {} }; local current_account; -local config_path = (os.getenv("XDG_CONFIG_HOME") or (os.getenv("HOME").."/.config"); +local config_path = (os.getenv("XDG_CONFIG_HOME") or (os.getenv("HOME").."/.config")); local config_file, err = io.open(config_path.."/.clixrc") or io.open(config_path.."/.clix"); if not config_file then @@ -152,5 +130,27 @@ table.remove(arg, n); end +local command = arg[1]; + +local ok, m = pcall(require, "clix."..command); +if not ok then + local is_debug; + for i=1,#arg do + if arg[i] == "--debug" then + is_debug = true; break; + end + end + print("Error running command '"..command..(is_debug and "" or "' (run with --debug to see full error)")); + if is_debug then + print(m); + end + return 1; +end + +if type(m) ~= "function" then + print(command.." is not a valid command"); + return 1; +end + return m(opts, arg) or 0;