Is there a way to disable copying of an alias this'd member? - trying to make a NotNull type

Simen Kjærås simen.kjaras at gmail.com
Fri May 24 10:40:01 UTC 2019


On Friday, 24 May 2019 at 10:16:50 UTC, aliak wrote:
> Basically, I want this to fail:
>
> auto notNull(T, Args...)(Args args) {
>     return NotNull!T(new T(args));
> }
>
> struct NotNull(T) {
>   private T _value;
>   @property ref inout(T) value() inout { return this._value; }
>   alias value this;
>   //disable opAssign to null as well
> }
>
> class C {}
> void func(ref C t) {
>   t = null;
> }
>
> auto a = notNull!C;
> func(a); // i want a compile error here
>
> Any ideas that don't involve disabling copying or making the 
> property non-ref?

Pretty sure that can't be done. On the other hand, why is the 
property ref if you're explicitly not going to use its ref-ness? 
Alternatively, can you show me how you use its ref-ness?

And just for completeness, you are aware that alias this takes an 
overload set, so that this works?

    struct NotNull(T) {
        private T _value;
        @property inout(T) value() inout { return _value; }
        @property void value(T val) { _value = val; } // new
        alias value this;
        // disable opAssign to null as well
    }

    class C {}
    void func(ref C t) { t = null; }

    unittest {
        NotNull n;
        n = new C(); // Look ma, I'm assigning without ref!
        func(n); // Does not compile - value() doesn't return by 
ref
    }

--
   Simen


More information about the Digitalmars-d-learn mailing list