Centralize the handling of
CXXRecordDecl::DefinitionData::DeclaredCopyAssignment, for
copy-assignment operators. Another step toward <rdar://problem/8459981>.


git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@114899 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/lib/AST/DeclBase.cpp b/lib/AST/DeclBase.cpp
index 207edde..26ab925 100644
--- a/lib/AST/DeclBase.cpp
+++ b/lib/AST/DeclBase.cpp
@@ -778,14 +778,11 @@
   } else {
     FirstDecl = LastDecl = D;
   }
-  
-  if (CXXRecordDecl *Record = dyn_cast<CXXRecordDecl>(this)) {
-    Decl *InnerD = D;
-    if (FunctionTemplateDecl *FunTmpl = dyn_cast<FunctionTemplateDecl>(D))
-      InnerD = FunTmpl->getTemplatedDecl();
-    if (CXXConstructorDecl *Constructor = dyn_cast<CXXConstructorDecl>(InnerD))
-      Record->addedConstructor(Constructor);
-  }
+
+  // Notify a C++ record declaration that we've added a member, so it can
+  // update it's class-specific state.
+  if (CXXRecordDecl *Record = dyn_cast<CXXRecordDecl>(this))
+    Record->addedMember(D);
 }
 
 void DeclContext::addDecl(Decl *D) {