On Wed, 25 Sep 2024, Jason Merrill wrote:

> On 7/30/24 6:49 PM, Giuseppe D'Angelo wrote:
> > On 29/07/2024 22:53, Giuseppe D'Angelo wrote:
> > > Hi,
> > > 
> > > The attached patch is a stab at adding the necessary compiler builtin to
> > > support std::is_virtual_base_of (P2985R0, approved for C++26). The name
> > > of the builtin matches the one just merged into clang:
> > > 
> > > https://github.com/llvm/llvm-project/issues/98310
> > > 
> > > The next patch will add the libstdc++ bits.
> > 
> > Hello,
> > 
> > This is a new revision of the same patch, this time with a DCO.
> 
> > +  ba_require_virtual = 1 << 3 /* Require a virtual base */
> 
> Why change lookup rather than just call lookup_base and then binfo_from_vbase
> in trait_expr_value?

IIUC it's because of the ambiguous case: std::is_virtual_base_of needs
to be true if there's an ambiguous virtual base, one of which is virtual,
but lookup_base by default prefers returning a non-virtual base in case
of ambiguity.

> 
> Jason
> 
> 

Reply via email to