diff options
| author | Anders Carlsson <andersca@mac.com> | 2010-02-13 22:23:31 +0000 |
|---|---|---|
| committer | Anders Carlsson <andersca@mac.com> | 2010-02-13 22:23:31 +0000 |
| commit | a678aa1e51c08c0a6d89724c7da92e1e5311e071 (patch) | |
| tree | 652b8355133b0f699edd301a46b8259613651ca1 /clang/lib/CodeGen/CGVtable.cpp | |
| parent | e75aaa97b366456b06193a35b5fee4ae63e3a03b (diff) | |
| download | bcm5719-llvm-a678aa1e51c08c0a6d89724c7da92e1e5311e071.tar.gz bcm5719-llvm-a678aa1e51c08c0a6d89724c7da92e1e5311e071.zip | |
Assert if we encounter this adjustments.
llvm-svn: 96125
Diffstat (limited to 'clang/lib/CodeGen/CGVtable.cpp')
| -rw-r--r-- | clang/lib/CodeGen/CGVtable.cpp | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/clang/lib/CodeGen/CGVtable.cpp b/clang/lib/CodeGen/CGVtable.cpp index 4b2a703493f..eb8b30d4a30 100644 --- a/clang/lib/CodeGen/CGVtable.cpp +++ b/clang/lib/CodeGen/CGVtable.cpp @@ -219,6 +219,7 @@ private: /// and we want to override B::f with C::f, we also need to override A::f with /// C::f. void PropagateOverrider(const CXXMethodDecl *OldMD, + BaseSubobject NewBase, const CXXMethodDecl *NewMD, SubobjectOffsetsMapTy &Offsets); @@ -290,7 +291,7 @@ void FinalOverriders::AddOverriders(BaseSubobject Base, continue; // First, propagate the overrider. - PropagateOverrider(MD, MD, Offsets); + PropagateOverrider(MD, Base, MD, Offsets); // Add the overrider as the final overrider of itself. OverriderInfo& Overrider = OverridersMap[std::make_pair(Base, MD)]; @@ -409,6 +410,7 @@ ComputeReturnTypeBaseOffset(ASTContext &Context, } void FinalOverriders::PropagateOverrider(const CXXMethodDecl *OldMD, + BaseSubobject NewBase, const CXXMethodDecl *NewMD, SubobjectOffsetsMapTy &Offsets) { for (CXXMethodDecl::method_iterator I = OldMD->begin_overridden_methods(), @@ -446,13 +448,18 @@ void FinalOverriders::PropagateOverrider(const CXXMethodDecl *OldMD, // Store the return adjustment base offset. ReturnAdjustments[SubobjectAndMethod] = ReturnBaseOffset; } + + // Check if we need a 'this' adjustment base offset as well. + if (Offset != NewBase.getBaseOffset()) { + assert(false && "FIXME: Handle 'this' adjustments!"); + } } // Set the new overrider. Overrider.Method = NewMD; // And propagate it further. - PropagateOverrider(OverriddenMD, NewMD, Offsets); + PropagateOverrider(OverriddenMD, NewBase, NewMD, Offsets); } } } |

