diff options
| author | Douglas Gregor <dgregor@apple.com> | 2010-07-03 00:47:00 +0000 | 
|---|---|---|
| committer | Douglas Gregor <dgregor@apple.com> | 2010-07-03 00:47:00 +0000 | 
| commit | 9672f92f7f2c5a58037ee6ee38004330d80f3372 (patch) | |
| tree | 958a5b6191a0723112eab72105117d24b2975587 /clang/lib/AST/DeclCXX.cpp | |
| parent | 0664a67fe1cf6bbf93b51153c8cd452409995efb (diff) | |
| download | bcm5719-llvm-9672f92f7f2c5a58037ee6ee38004330d80f3372.tar.gz bcm5719-llvm-9672f92f7f2c5a58037ee6ee38004330d80f3372.zip | |
Lazily declare default constructors. We now delay the construction of
declarations for implicit default constructors, copy constructors,
copy assignment operators, and destructors. On a "simple" translation
unit that includes a bunch of C++ standard library headers, we
generate relatively few of these implicit declarations now:
  4/159 implicit default constructors created
  18/236 implicit copy constructors created
  70/241 implicit copy assignment operators created
  0/173 implicit destructors created
And, on this translation unit, this optimization doesn't really
provide any benefit. I'll do some more performance measurements soon,
but this completes the implementation work for <rdar://problem/8151045>.
llvm-svn: 107551
Diffstat (limited to 'clang/lib/AST/DeclCXX.cpp')
| -rw-r--r-- | clang/lib/AST/DeclCXX.cpp | 5 | 
1 files changed, 4 insertions, 1 deletions
| diff --git a/clang/lib/AST/DeclCXX.cpp b/clang/lib/AST/DeclCXX.cpp index 4b1909e57c6..7ce9c64de03 100644 --- a/clang/lib/AST/DeclCXX.cpp +++ b/clang/lib/AST/DeclCXX.cpp @@ -32,7 +32,7 @@ CXXRecordDecl::DefinitionData::DefinitionData(CXXRecordDecl *D)      Abstract(false), HasTrivialConstructor(true),      HasTrivialCopyConstructor(true), HasTrivialCopyAssignment(true),      HasTrivialDestructor(true), ComputedVisibleConversions(false), -    DeclaredCopyConstructor(false),  +    DeclaredDefaultConstructor(false), DeclaredCopyConstructor(false),       DeclaredCopyAssignment(false), DeclaredDestructor(false),      Bases(0), NumBases(0), VBases(0), NumVBases(0),      Definition(D), FirstFriend(0) { @@ -277,6 +277,9 @@ CXXRecordDecl::addedConstructor(ASTContext &Context,    // Note that we have a user-declared constructor.    data().UserDeclaredConstructor = true; +  // Note that we have no need of an implicitly-declared default constructor. +  data().DeclaredDefaultConstructor = true; +      // C++ [dcl.init.aggr]p1:    //   An aggregate is an array or a class (clause 9) with no    //   user-declared constructors (12.1) [...]. | 

