bug: label between local definitions can mix-up their initializations

This commit is contained in:
Roberto Ierusalimschy 2016-03-07 16:25:39 -03:00
parent 03ca6385dc
commit e7b2e01d43
2 changed files with 35 additions and 2 deletions

33
bugs
View File

@ -3542,6 +3542,39 @@ patch = [[
}
Bug{
what = [[label between local definitions can mix-up their initializations]],
report = [[Karel Tuma, 2016/03/01]],
since = [[5.2]],
fix = nil,
example = [[
do
local k = 0
local x
::foo::
local y -- should be reset to nil after goto, but it is not
assert(not y)
y = true
k = k + 1
if k < 2 then goto foo end
end
]],
patch = [[
--- lparser.c 2015/11/02 16:09:30 2.149
+++ lparser.c 2016/03/03 12:03:37
@@ -1226,7 +1226,7 @@
checkrepeated(fs, ll, label); /* check for repeated labels */
checknext(ls, TK_DBCOLON); /* skip double colon */
/* create new entry for this label */
- l = newlabelentry(ls, ll, label, line, fs->pc);
+ l = newlabelentry(ls, ll, label, line, luaK_getlabel(fs));
skipnoopstat(ls); /* skip other no-op statements */
if (block_follow(ls, 0)) { /* label is last no-op statement in the block? */
/* assume that locals are already out of scope */
]]
}
--[=[
Bug{
what = [[ ]],

View File

@ -1,5 +1,5 @@
/*
** $Id: lparser.c,v 2.150 2015/12/09 15:21:28 roberto Exp roberto $
** $Id: lparser.c,v 2.151 2016/01/05 16:22:37 roberto Exp roberto $
** Lua Parser
** See Copyright Notice in lua.h
*/
@ -1230,7 +1230,7 @@ static void labelstat (LexState *ls, TString *label, int line) {
checkrepeated(fs, ll, label); /* check for repeated labels */
checknext(ls, TK_DBCOLON); /* skip double colon */
/* create new entry for this label */
l = newlabelentry(ls, ll, label, line, fs->pc);
l = newlabelentry(ls, ll, label, line, luaK_getlabel(fs));
skipnoopstat(ls); /* skip other no-op statements */
if (block_follow(ls, 0)) { /* label is last no-op statement in the block? */
/* assume that locals are already out of scope */