digitalmars.D.bugs - [Issue 24335] New: Class Downcast
- d-bugmail puremagic.com (47/47) Jan 11 2024 https://issues.dlang.org/show_bug.cgi?id=24335
https://issues.dlang.org/show_bug.cgi?id=24335 Issue ID: 24335 Summary: Class Downcast Product: D Version: D2 Hardware: All OS: All Status: NEW Severity: enhancement Priority: P1 Component: dmd Assignee: nobody puremagic.com Reporter: bugzilla digitalmars.com deadalnix writes: Currently, we use a linear algorithm to downcast and we reach this algorithm via a call int he runtime. This prevent the optimizer from doing anything about it, in addition to be slow. The problem is similar to 1/. The whole check can be made trivial if we let the compiler prebake some data for us, namely an array of primary parents. Let's see what it looks like in the first example, when b is not final. class A {} class B : A {} auto foo(A a) { return cast(B) a; } Which we can do as follow: auto foo(A a) { // The primaries generated by the compiler for us. auto tidA = typeid(A); assert(tidA.primaries = [tidA]); auto tidB = typeid(B); assert(tidB.primaries = [tidA, tidB]); auto t = typeid(a); auto depth = tidB.primaries.length - 1; if (t.primary.length <= depth) { return null; } if (t.primary[depth] == tidB) { return a; } return null; } This is starting to look good, now we have general downcast in a form that is not only really fast to perform, but also completely transparent to the optimizer. https://forum.dlang.org/post/hteuczyclxajakrisxjd forum.dlang.org --
Jan 11 2024