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.