[Issue 968] New: ICE on compile-time execution

d-bugmail at puremagic.com d-bugmail at puremagic.com
Thu Feb 15 11:41:06 PST 2007


http://d.puremagic.com/issues/show_bug.cgi?id=968

           Summary: ICE on compile-time execution
           Product: D
           Version: 1.006
          Platform: PC
        OS/Version: Linux
            Status: NEW
          Keywords: ice-on-invalid-code, ice-on-valid-code
          Severity: normal
          Priority: P2
         Component: DMD
        AssignedTo: bugzilla at digitalmars.com
        ReportedBy: fvbommel at wxs.nl


-----
// Slightly modified from example provided by 
// Walter upon introduction of v1.006
import std.stdio;

real test(real x)
{
    real root = x / 2;
    for (int ntries = 0; ntries < 5 || true; ntries++) {
        root = (root + x / root) / 2;
    }
    return root;
}

void main()
{
   static x = test();
}
-----
Error checking could be improved here, this gives:
---
test.d(15): function test.test (real) does not match parameter types ()
test.d(15): Error: expected 1 arguments, not 0
dmd: interpret.c:96: Expression* FuncDeclaration::interpret(Expressions*):
Assertion `parameters && parameters->dim == dim' failed.
Aborted (core dumped)
---
It tells you what's wrong, but still trips an assert that seems to be about the
same error. However:
-----
real test()
{
    return 0.0;
}

void main()
{
   static x = test();
}
-----
it still gives:
---
dmd: interpret.c:96: Expression* FuncDeclaration::interpret(Expressions*):
Assertion `parameters && parameters->dim == dim' failed.
Aborted (core dumped)
---
The same assert is tripped, but I don't see why this would even be invalid
code.

So I don't know, maybe it's a different bug entirely. Or it tripped the other
clause of the assert. I don't feel like inspecting interpret.c to find out what
exactly the assert is checking and why it's false...


-- 



More information about the Digitalmars-d-bugs mailing list