[Issue 23598] New: Another nasty forward reference bug

d-bugmail at puremagic.com d-bugmail at puremagic.com
Wed Jan 4 08:02:59 UTC 2023


https://issues.dlang.org/show_bug.cgi?id=23598

          Issue ID: 23598
           Summary: Another nasty forward reference bug
           Product: D
           Version: D2
          Hardware: All
                OS: All
            Status: NEW
          Keywords: rejects-valid
          Severity: blocker
          Priority: P1
         Component: dmd
          Assignee: nobody at puremagic.com
          Reporter: maxsamukha at gmail.com

This one took me a long time to reduce. Marking it as a blocker, as I haven't
found an acceptable workaround yet.

----
alias aliases(a...) = a;

template sort(alias f, a...)
{
    static if (a.length > 0) // (1)
    {
        alias x = f!(a[1]);
        alias sort = a;
    }
    else
        alias sort = a;
}

alias SortedItems = sort!(isDependencyOf, Top, String); // (2)
pragma (msg, "1: ", SortedItems);

enum isDependencyOf(Item) = Item.DirectDependencies.length == 0;

struct Top
{
    alias DirectDependencies = aliases!();
}

struct String
{
    alias DirectDependencies = aliases!();

    pragma(msg, "2: ", SortedItems);
    enum l = SortedItems.length; // (3)
    static assert(is(typeof(SortedItems.length) == size_t)); // (4)
}
----
Error: no property `length` for `sort!(isDependencyOf, Top, String)` of type
`void`

The SortedItems tuple at (2) is (Top, String), which is correct, but at (3) it
is broken. However, at (4) it is correct again - the assert passes if (3) is
commented out. This may have something to do with the 'static if' at (1), as
the error goes away if the 'static if' and the 'else' branch are commented out.

--


More information about the Digitalmars-d-bugs mailing list