CT BitArray
Stefan Koch
uplink.coder at googlemail.com
Thu Nov 1 00:01:04 UTC 2018
On Wednesday, 31 October 2018 at 23:14:08 UTC, Bastiaan Veelo
wrote:
> Currently, BitArray is not usable at compile time, so you
> cannot do
> ```
> enum e = BitArray([1, 1, 1, 0]);
> ```
> This gives
>> /dlang/dmd/linux/bin64/../../src/phobos/std/bitmanip.d(1190):
>> Error: `bts` cannot be interpreted at compile time, because it
>> has no available source code
>
> IIUC, that is because `bts` comes from core.bitop but no source
> code is there. I am guessing these are filled in by compiler
> intrinsics or the like, and they are unavailable at CT, correct?
>
> I suppose that alternative implementations of `btc`, `bts`,
> `btr`, `bsf` and `bt` could exist that do not use the runtime
> that could be used if(__ctfe) in the implementation of
> BitArray, that would make the above code work. Is this
> feasible? Is there precedent in phobos? Are there complications?
>
> Thanks!
Oh that ... actually I can fix that with a small patch to dmd.
Tell me which version are you using and I'll make it for you.
Cheers,
Stefan
More information about the Digitalmars-d-learn
mailing list