From 6a77b3cd215bb32ae1ef3a1fc5b1b40c440d51ec Mon Sep 17 00:00:00 2001 From: Starbeamrainbowlabs Date: Wed, 28 Jul 2021 17:54:44 +0100 Subject: [PATCH] split_shell: fix escape handling by unwinding escaping by 1 level --- .../utils/strings/split_shell.lua | 17 +++++++++++++++-- 1 file changed, 15 insertions(+), 2 deletions(-) diff --git a/worldeditadditions/utils/strings/split_shell.lua b/worldeditadditions/utils/strings/split_shell.lua index 46f1e0b..d33fc41 100644 --- a/worldeditadditions/utils/strings/split_shell.lua +++ b/worldeditadditions/utils/strings/split_shell.lua @@ -2,6 +2,15 @@ function is_whitespace(char) return char == " " or char == "\t" or char == "\r" or char == "\n" end +local function table_map(tbl, func) + local result = {} + for i,value in ipairs(tbl) do + local newval = func(value, i) + if newval ~= nil then table.insert(result, newval) end + end + return result +end + function split_shell(text) local text_length = #text local scan_pos = 1 @@ -60,7 +69,11 @@ function split_shell(text) if #acc > 0 then table.insert(result, table.concat(acc, "")) end - return result + + -- Unwind all escapes by 1 level + return table_map(result, function(str) + return str:gsub("\\([\"'\\])", "%1") + end) end function test(text) @@ -74,7 +87,7 @@ end test("yay yay yay") test("yay \"yay yay\" yay") test("yay \"yay\\\" yay\" yay") -test("yay \"yay 'inside quotes' yay\" yay") +test("yay \"yay 'inside quotes' yay\\\"\" yay") test("yay 'inside quotes' another") test("y\"ay \"yay 'in\\\"side quotes' yay\" y\\\"ay")