digitalmars.D - alias this and immutable shenanigans
- Yao G. (42/42) Aug 12 2010 Consider this code:
- Justin Johansson (21/26) Aug 13 2010 See the prior thread about the status and pandemonium of
- Stanislav Blinov (14/56) Aug 13 2010 If you rename Bar._foo to Bar._fooo, you'll see what it complains about
Consider this code:
---
module test;
struct Foo
{
     this( int f ) {
         _foo = f;
     }
      property int baz() {
         return _foo;
     }
     // alias _foo this;
     // alias baz this;	
     immutable int _foo;
}
struct Bar
{
     this( int f ) {
         _foo  = Foo(f);
     }
     private:
     immutable Foo _foo;
}
---
If I uncomment the alias _foo this line, I get the following error message:
% Test.d(22): Error: can only initialize const member _foo inside  
constructor
WTF! I'm initializing it in a constructor! Is this a bug? Or by design you  
cannot alias this to a immutable member of a struct. It seems that there's  
a hidden temp created that wants to initialize the field. Also, I wanted  
to alias the property Foo.baz, but it also caused the following errors:
% Test.d(22): Error: function test.Foo.baz () is not callable using  
argument types (Foo) immutable
% Test.d(22): Error: expected 0 arguments, not 1 for non-variadic function  
type  property int()
It seems that somehow the property is used as a "setter", not as a  
"getter".
So, my questions are:
1. Why is disallowed to alias this an immutable data inside a struct?
2. Why is disallowed to alias this a struct "getter" property?
-- 
Yao G.
 Aug 12 2010
Yao G. wrote:WTF! I'm initializing it in a constructor! Is this a bug? Or by design you cannot alias this to a immutable member of a struct. It seems that there's a hidden temp created that wants to initialize the field. Also, I wanted to alias the property Foo.baz, but it also caused the following errors:See the prior thread about the status and pandemonium of const/immutable/shared as your post is manifestly related to the same. Whether your particular observation is a bug or not depends on what the language specification calls out for. Of course (being cynical), if the language specification says to raise these kinds of errors that you observe under your input conditions then it is not a bug and that's simply how this PL compiler happens to work (and is expected to work according to its specification). Now, since no warranties are given that said PL is useful for any particular purpose, the sole responsibility is on you, the user, to determine whether or not said PL is useful for your purposes. ATOH, whether or not the language specification (formal/informal/absent/otherwise) is in concert with any formal/established theory of programming is yet another question. While feeling somewhat awkward about making this response, me thinks that the "roadmap for the holy grail of D" needs to be redrafted from scratch in many areas. -- Justin Johansson
 Aug 13 2010
  13.08.2010 9:37, Yao G. wrote:
 Consider this code:
 ---
 module test;
 struct Foo
 {
     this( int f ) {
         _foo = f;
     }
      property int baz() {
         return _foo;
     }
     // alias _foo this;
     // alias baz this;
     immutable int _foo;
 }
 struct Bar
 {
     this( int f ) {
         _foo  = Foo(f);
     }
     private:
     immutable Foo _foo;
 }
 ---
 If I uncomment the alias _foo this line, I get the following error 
 message:
 % Test.d(22): Error: can only initialize const member _foo inside 
 constructor
 WTF! I'm initializing it in a constructor! Is this a bug? Or by design 
 you cannot alias this to a immutable member of a struct. It seems that 
 there's a hidden temp created that wants to initialize the field. 
 Also, I wanted to alias the property Foo.baz, but it also caused the 
 following errors:
 % Test.d(22): Error: function test.Foo.baz () is not callable using 
 argument types (Foo) immutable
 % Test.d(22): Error: expected 0 arguments, not 1 for non-variadic 
 function type  property int()
 It seems that somehow the property is used as a "setter", not as a 
 "getter".
 So, my questions are:
 1. Why is disallowed to alias this an immutable data inside a struct?
 2. Why is disallowed to alias this a struct "getter" property?
If you rename Bar._foo to Bar._fooo, you'll see what it complains about 
(yep, about A._foo).
When you use 'alias x this', methods not defined for 'typeof(this)' will 
be searched in typeof(x). In this case, _foo = Foo( f ) is a constructor 
call, but...
If alias is present, _foo = Foo(f) translates to 
_foo._foo.opAssign(Foo(f)), or, when you alias to baz, to property 
assignment (and you indeed don't have a setter).
Thus being said, I'm not sure if it's a bug or not - seems like an 
ambiguity at least.
-- 
*
* 	
 Aug 13 2010








 
  
  
 
 Justin Johansson <no spam.com>
 Justin Johansson <no spam.com> 