Bug 5497 – [CTFE] Cannot (reinterpret) cast string/array to different array
Status
RESOLVED
Resolution
FIXED
Severity
normal
Priority
P2
Component
dmd
Product
D
Version
D2
Platform
Other
OS
Linux
Creation time
2011-01-27T13:35:00Z
Last change time
2015-06-09T05:11:42Z
Keywords
rejects-valid
Assigned to
nobody
Creator
aziz.koeksal
Comments
Comment #0 by aziz.koeksal — 2011-01-27T13:35:17Z
Example code:
uint[] toArray(string s)
{
return cast(uint[])s;
}
version(BigEndian)
static assert(toArray("\xdd\xcc\xbb\xaa")[0] == 0xddccbbaa);
else
static assert(toArray("\xdd\xcc\xbb\xaa")[0] == 0xaabbccdd);
// The following code works, of course:
static this()
{
version(BigEndian)
assert(toArray("\xdd\xcc\xbb\xaa")[0] == 0xddccbbaa);
else
assert(toArray("\xdd\xcc\xbb\xaa")[0] == 0xaabbccdd);
}
Comment #1 by clugdbug — 2011-11-08T02:43:00Z
This test case generated wrong code in 2.053 and earlier, but it actually should have been accepts-invalid.
Since 2.054 it generates
test.d(3): Error: array cast from string to uint[] is not supported at compile t
ime
test.d(8): Error: cannot evaluate toArray("\xdd\xcc\xbb\xaa") at compile time
test.d(8): Error: static assert (toArray("\xdd\xcc\xbb\xaa")[0u] == -1430532899
u) is not evaluatable at compile time
https://github.com/D-Programming-Language/dmd/commit/5d6df984d50862f25b481790ad4ef86b0afd6c9a
Also the spec now states that such casts are not legal in CTFE.