[Issue 17934] New: [scope] scopeness entrypoint for unique/ref-counted missing
    d-bugmail at puremagic.com 
    d-bugmail at puremagic.com
       
    Tue Oct 24 22:42:26 UTC 2017
    
    
  
https://issues.dlang.org/show_bug.cgi?id=17934
          Issue ID: 17934
           Summary: [scope] scopeness entrypoint for unique/ref-counted
                    missing
           Product: D
           Version: D2
          Hardware: All
                OS: All
            Status: NEW
          Keywords: safe
          Severity: normal
          Priority: P3
         Component: dmd
          Assignee: bugzilla at digitalmars.com
          Reporter: code at dawg.eu
cat > bug.d << CODE
import core.stdc.stdlib;
struct List
{
    Elem front() @safe return scope
    {
        return Elem(data);
    }
    ~this() @trusted scope
    {
        free(data);
        data = null;
    }
    @disable this(this);
private:
    void* data;
}
struct Elem
{
private:
    void* data;
}
/**
  There seems to be now way to write this functions so
  that the compiler infers the return value as scope.
 */
List list() @trusted
{
    return List(malloc(1));
}
void test() @safe
{
    Elem elem;
    {
        //scope l = list(); // works with explicit scope
        auto l = list(); // not inferred as scope
        elem = l.front; // escapes, b/c l isn't scoped
    }
}
CODE
dmd -c -dip1000 bug.d
----
Repeatedly ending up with this problem. It doesn't seem possible to contain
allocated data, as there is now way to enforce that the call-site uses a scope
variable.
--
    
    
More information about the Digitalmars-d-bugs
mailing list