diff options
| -rw-r--r-- | clang/lib/CodeGen/CGVtable.cpp | 12 | ||||
| -rw-r--r-- | clang/test/CodeGenCXX/vtable-layout-abi-examples.cpp | 1 | 
2 files changed, 9 insertions, 4 deletions
diff --git a/clang/lib/CodeGen/CGVtable.cpp b/clang/lib/CodeGen/CGVtable.cpp index 8e9e0655e8d..399b921b52e 100644 --- a/clang/lib/CodeGen/CGVtable.cpp +++ b/clang/lib/CodeGen/CGVtable.cpp @@ -1296,6 +1296,8 @@ OverridesMethodInBases(const CXXMethodDecl *MD,  }  void VtableBuilder::ComputeThisAdjustments() { +  std::map<uint64_t, ThisAdjustment> SortedThisAdjustments; +      // Now go through the method info map and see if any of the methods need    // 'this' pointer adjustments.    for (MethodInfoMapTy::const_iterator I = MethodInfoMap.begin(), @@ -1338,17 +1340,21 @@ void VtableBuilder::ComputeThisAdjustments() {                                                            ThisAdjustmentOffset);      // Add it. -    ThisAdjustments.push_back(std::make_pair(VtableIndex, ThisAdjustment)); +    SortedThisAdjustments.insert(std::make_pair(VtableIndex, ThisAdjustment));      if (isa<CXXDestructorDecl>(MD)) {        // Add an adjustment for the deleting destructor as well. -      ThisAdjustments.push_back(std::make_pair(VtableIndex + 1, -                                               ThisAdjustment)); +      SortedThisAdjustments.insert(std::make_pair(VtableIndex + 1, +                                                  ThisAdjustment));      }    }    /// Clear the method info map.    MethodInfoMap.clear(); +   +  // Add the sorted elements. +  ThisAdjustments.append(SortedThisAdjustments.begin(), +                         SortedThisAdjustments.end());  }  VtableBuilder::ReturnAdjustment  diff --git a/clang/test/CodeGenCXX/vtable-layout-abi-examples.cpp b/clang/test/CodeGenCXX/vtable-layout-abi-examples.cpp index cec7a5cf71b..2c6b7a48ccf 100644 --- a/clang/test/CodeGenCXX/vtable-layout-abi-examples.cpp +++ b/clang/test/CodeGenCXX/vtable-layout-abi-examples.cpp @@ -1,5 +1,4 @@  // RUN: %clang_cc1 %s -triple=x86_64-apple-darwin10 -emit-llvm-only -fdump-vtable-layouts 2>&1 | FileCheck %s -// XFAIL: *  /// Examples from the Itanium C++ ABI specification.  /// http://www.codesourcery.com/public/cxx-abi/  | 

