[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