From 7176181aef165a6c38edb0d861ae53e7c7bc5f55 Mon Sep 17 00:00:00 2001 From: "Christoph J. Scherr" Date: Thu, 15 Feb 2024 14:26:01 +0100 Subject: [PATCH] bugfix --- tokenize_args.lua | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/tokenize_args.lua b/tokenize_args.lua index 16b3b76..bb434e4 100644 --- a/tokenize_args.lua +++ b/tokenize_args.lua @@ -8,7 +8,7 @@ function tokenize_args(raw) -- '*?' does not work -- '|' is not or -- - -- This means we're better of implementing a programatic lexer. + -- This means we're better of implementing the lexer with an algorithm. local t = {} local current = "" local in_str = false @@ -33,7 +33,9 @@ function tokenize_args(raw) current = current .. c end end - table.insert(t, current) + if string.len(current) > 0 then + table.insert(t, current) + end return t end @@ -58,7 +60,8 @@ function dump(t) end function main() - local mockargs = [[-iab --foo '{"QUX": "BAR"}' --ala=boa]] + local mockargs = + [[--name "tls_service_rs" --base-dir ${PWD%/*/*} --log-level "TRACE" -j '{ "MODE": "server", "CERT": "data/server.crt", "KEY": "data/server.key", "CHAIN": "data/root.crt", "ADDR": "127.0.0.1:9999", "HOSTNAME": "localhost" }']] print(mockargs) local split = tokenize_args(mockargs) print(dump(split))