[Issue 6511] [CTFE] Array op gives wrong result

d-bugmail at puremagic.com d-bugmail at puremagic.com
Tue Aug 23 01:29:18 PDT 2011


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


Don <clugdbug at yahoo.com.au> changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
                 CC|                            |clugdbug at yahoo.com.au


--- Comment #3 from Don <clugdbug at yahoo.com.au> 2011-08-23 01:29:13 PDT ---
(In reply to comment #2)
> The given code example now works. But this:
> 
> 
> T foo(T)() {
>     T[1] a = [1];
>     a[] += a[];
>     return a[0];
> }
> static assert(foo!long() == 2); // OK
> static assert(foo!int() == 2); // error
> void main() {}
> 
> 
> Gives:
> 
> test.d(3): Error: _arraySliceSliceAddass_i cannot be interpreted at compile
> time, because it has no available source code
> test.d(7): Error: cannot evaluate foo() at compile time
> test.d(7): Error: static assert  (foo() == 2) is not evaluatable at compile
> time
> 
> This behaviour difference between long and int is not good. Do you prefer me to
> reopen this bug or to open a new one?

A new one. Surprisingly, it actually has *nothing* in common with this bug.
This bug was actually a problem with array slicing, and didn't require array
operations.
The new case is that the array operations which are special-cased in the
runtime don't have special case treatment in the CTFE engine, since CTFE
doesn't have access to the source code of druntime. The array ops which aren't
special-cased don't use druntime code, so they should all work.

-- 
Configure issuemail: http://d.puremagic.com/issues/userprefs.cgi?tab=email
------- You are receiving this mail because: -------


More information about the Digitalmars-d-bugs mailing list