Anyone know why this CTFE isn't working?

Lars T. Kyllingstad public at kyllingen.NOSPAMnet
Fri Jul 16 03:57:06 PDT 2010


On Fri, 16 Jul 2010 12:12:38 +0200, Rory McGuire wrote:

> On Fri, 16 Jul 2010 11:58:57 +0200, Lars T. Kyllingstad
> <public at kyllingen.nospamnet> wrote:
> 
>> On Fri, 16 Jul 2010 11:46:48 +0200, Rory McGuire wrote:
>>
>>> import std.stdio;
>>>
>>> struct State {
>>>   string s; string getString() { return s; } static State
>>>   opCall(string s) {
>>>   State ret;
>>>   ret.s = s;
>>>   return ret;
>>>   }
>>> }
>>>
>>> void main() {
>>>   auto s = State("adf");
>>>   pragma(msg, s.getString());
>>> }
>>>
>>> dmd Output: (line 14 is the pragma statement)
>>>
>>> struct.d(14): Error: variable s cannot be read at compile time
>>> struct.d(14): Error: cannot evaluate s.getString() at compile time
>>> s.getString()
>>
>> It's not working because s isn't a compile-time quantity.  Try:
>>
>>   enum s = State("adf");
>>
>> -Lars
> 
> Awesome thanks, worked.
> 
> So is the difference that "auto s" is a Struct which can change whereas
> "enum s" is a constant?
> If it is a constant its just "s" that is constant right?
> 
> Thanks Lars

Yes.  Writing "auto s = State("adf");" is equivalent to writing

  State s = State("adf");

and since s can change at runtime, it would be meaningless to say that it 
has a value at compile time.  However, its *initial value*, the struct 
literal State("adf"), is known at compile time -- otherwise it would be 
impossible to assign it to an enum.

And actually, an enum is not only a constant, it is a manifest constant.  
When you declare "enum x = someFixedValue", the compiler will just 
replace all later uses of x with someFixedValue.  It's basically the same 
as using the literal value in those places.

This has the consequence that you can't take the address of an enum, nor 
pass an enum by reference.  Doing

  enum i = 3;
  int* p = &i;

is equivalent to

  int* p = &3;

which doesn't make sense.

-Lars


More information about the Digitalmars-d-learn mailing list