------- Additional Comments From dberlin at gcc dot gnu dot org 2005-09-28 02:31 ------- Subject: Re: [4.1 Regression] C++ generates incorrect overlapping fields
On Wed, 2005-09-28 at 02:06 +0000, mark at codesourcery dot com wrote: > ------- Additional Comments From mark at codesourcery dot com 2005-09-28 > 02:06 ------- > Subject: Re: [4.1 Regression] C++ generates incorrect overlapping > fields > > dberlin at gcc dot gnu dot org wrote: > > > However, the questions still remains, what is the offset supposed to be > > relative to? > > The beginning of the type in which the field is contained, which I think > means, in your parlance: The parlance is that of GCC. I didn't invent DECL_CONTEXT :) > > > The direct context, or the outermost containing type? > > the "direct context". Okay, then this is my bug, not yours :) I'll change the summary in a moment. > > In other words, if C has a field of type B at offset 32, and B has an > field "f" with offset 16, then the offset of B::f relative to C is 48. > (That's the only thing that makes any sense; otherwise, we'd have to > make a copy of B every time it appeared as field in some other type.) Well, yes, if you link everything together using a list like that, and only store the offset in a shared field decl. But if you had a nice vector of std::pair<offset, field>, you wouldn't have to copy everything. :) > > > -- http://gcc.gnu.org/bugzilla/show_bug.cgi?id=22488