From 492ed7f90f8fe575c64d4689b2963bd0674da0f9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=9C=80=E8=90=8C=E5=B0=8F=E6=B1=90?= Date: Mon, 11 Jul 2022 15:57:46 +0800 Subject: fix #1317 --- script/parser/compile.lua | 30 ++++++++++++++++-------------- 1 file changed, 16 insertions(+), 14 deletions(-) (limited to 'script') diff --git a/script/parser/compile.lua b/script/parser/compile.lua index 1e4165ff..bae1e21a 100644 --- a/script/parser/compile.lua +++ b/script/parser/compile.lua @@ -12,11 +12,9 @@ local uchar = utf8.char local tconcat = table.concat local tinsert = table.insert local tointeger = math.tointeger -local mtype = math.type local tonumber = tonumber local maxinteger = math.maxinteger local assert = assert -local next = next _ENV = nil @@ -2669,7 +2667,6 @@ local function parseVarTails(parser, isLocal) end if isLocal then createLocal(second, parseLocalAttrs()) - second.effect = maxinteger end skipSpace() if Tokens[Index + 1] ~= ',' then @@ -2684,7 +2681,6 @@ local function parseVarTails(parser, isLocal) end if isLocal then createLocal(third, parseLocalAttrs()) - third.effect = maxinteger end local rest = { third } while true do @@ -2701,7 +2697,6 @@ local function parseVarTails(parser, isLocal) end if isLocal then createLocal(name, parseLocalAttrs()) - name.effect = maxinteger end rest[#rest+1] = name end @@ -2709,7 +2704,6 @@ end local function bindValue(n, v, index, lastValue, isLocal, isSet) if isLocal then - n.effect = lastRightPosition() if v and v.special then addSpecial(v.special, n) end @@ -2755,9 +2749,6 @@ local function bindValue(n, v, index, lastValue, isLocal, isSet) n.value = v n.range = v.finish v.parent = n - if isLocal then - n.effect = lastRightPosition() - end end end @@ -2777,6 +2768,7 @@ local function parseMultiVars(n1, parser, isLocal) local index = 1 bindValue(n1, v1, index, nil, isLocal, isSet) local lastValue = v1 + local lastVar = n1 if n2 then max = 2 if not v2 then @@ -2784,6 +2776,7 @@ local function parseMultiVars(n1, parser, isLocal) end bindValue(n2, v2, index, lastValue, isLocal, isSet) lastValue = v2 or lastValue + lastVar = n2 pushActionIntoCurrentChunk(n2) end if nrest then @@ -2796,10 +2789,24 @@ local function parseMultiVars(n1, parser, isLocal) end bindValue(n, v, index, lastValue, isLocal, isSet) lastValue = v or lastValue + lastVar = n pushActionIntoCurrentChunk(n) end end + if isLocal then + local effect = lastValue and lastValue.finish or lastVar.finish + n1.effect = effect + if n2 then + n2.effect = effect + end + if nrest then + for i = 1, #nrest do + nrest[i].effect = effect + end + end + end + if v2 and not n2 then v2.redundant = { max = max, @@ -2921,11 +2928,6 @@ local function parseLocal() pushActionIntoCurrentChunk(loc) skipSpace() parseMultiVars(loc, parseName, true) - if loc.value then - loc.effect = loc.value.finish - else - loc.effect = loc.finish - end return loc end -- cgit v1.2.3