When implicit members are added to a C++ record, notify the serializer so that a chained PCH writes the definition again.
Thanks to Doug for the hint!

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@116975 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/lib/AST/DeclCXX.cpp b/lib/AST/DeclCXX.cpp
index 19caae5..78b15ff 100644
--- a/lib/AST/DeclCXX.cpp
+++ b/lib/AST/DeclCXX.cpp
@@ -363,6 +363,13 @@
   }
   
   if (D->isImplicit()) {
+    // Notify the serializer that an implicit member changed the definition.
+    // A chained PCH will write the whole definition again.
+    // FIXME: Make a notification about the specific change (through a listener
+    // interface) so the changes that the serializer records are more
+    // fine grained.
+    data().Definition->setChangedSinceDeserialization(true);
+
     if (CXXConstructorDecl *Constructor = dyn_cast<CXXConstructorDecl>(D)) {
       // If this is the implicit default constructor, note that we have now
       // declared it.