mirror of
https://github.com/xomboverlord/ldc.git
synced 2026-01-20 14:53:14 +01:00
Fixed problem with nested function inside static nested function. see mini/compile_nested2.d. fixes #143 .
This commit is contained in:
@@ -771,24 +771,31 @@ void DtoDefineFunc(FuncDeclaration* fd)
|
||||
if (!fd->nestedVars.empty())
|
||||
{
|
||||
Logger::println("has nested frame");
|
||||
// start with add all enclosing parent frames
|
||||
// start with adding all enclosing parent frames until a static parent is reached
|
||||
int nparelems = 0;
|
||||
Dsymbol* par = fd->toParent2();
|
||||
while (par)
|
||||
if (!fd->isStatic())
|
||||
{
|
||||
if (FuncDeclaration* parfd = par->isFuncDeclaration())
|
||||
Dsymbol* par = fd->toParent2();
|
||||
while (par)
|
||||
{
|
||||
nparelems += parfd->nestedVars.size();
|
||||
if (FuncDeclaration* parfd = par->isFuncDeclaration())
|
||||
{
|
||||
nparelems += parfd->nestedVars.size();
|
||||
// stop at first static
|
||||
if (parfd->isStatic())
|
||||
break;
|
||||
}
|
||||
else if (ClassDeclaration* parcd = par->isClassDeclaration())
|
||||
{
|
||||
// nothing needed
|
||||
}
|
||||
else
|
||||
{
|
||||
break;
|
||||
}
|
||||
|
||||
par = par->toParent2();
|
||||
}
|
||||
else if (ClassDeclaration* parcd = par->isClassDeclaration())
|
||||
{
|
||||
// nothing needed
|
||||
}
|
||||
else
|
||||
{
|
||||
break;
|
||||
}
|
||||
par = par->toParent2();
|
||||
}
|
||||
int nelems = fd->nestedVars.size() + nparelems;
|
||||
|
||||
|
||||
13
tests/mini/compile_nested2.d
Normal file
13
tests/mini/compile_nested2.d
Normal file
@@ -0,0 +1,13 @@
|
||||
void test(void delegate() spam)
|
||||
{
|
||||
static void foo() // static is the problem
|
||||
{
|
||||
uint x;
|
||||
void peek() { x = 0; }
|
||||
}
|
||||
|
||||
void bar()
|
||||
{
|
||||
spam();
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user