Guy Benyei | 11169dd | 2012-12-18 14:30:41 +0000 | [diff] [blame] | 1 | //===--- ASTCommon.cpp - Common stuff for ASTReader/ASTWriter----*- C++ -*-===// |
| 2 | // |
| 3 | // The LLVM Compiler Infrastructure |
| 4 | // |
| 5 | // This file is distributed under the University of Illinois Open Source |
| 6 | // License. See LICENSE.TXT for details. |
| 7 | // |
| 8 | //===----------------------------------------------------------------------===// |
| 9 | // |
| 10 | // This file defines common functions that both ASTReader and ASTWriter use. |
| 11 | // |
| 12 | //===----------------------------------------------------------------------===// |
| 13 | |
| 14 | #include "ASTCommon.h" |
Richard Smith | d08aeb6 | 2014-08-28 01:33:39 +0000 | [diff] [blame] | 15 | #include "clang/AST/DeclCXX.h" |
Douglas Gregor | 9f78289 | 2013-01-21 15:25:38 +0000 | [diff] [blame] | 16 | #include "clang/AST/DeclObjC.h" |
Guy Benyei | 11169dd | 2012-12-18 14:30:41 +0000 | [diff] [blame] | 17 | #include "clang/Basic/IdentifierTable.h" |
| 18 | #include "clang/Serialization/ASTDeserializationListener.h" |
| 19 | #include "llvm/ADT/StringExtras.h" |
| 20 | |
| 21 | using namespace clang; |
| 22 | |
| 23 | // Give ASTDeserializationListener's VTable a home. |
Angel Garcia Gomez | 637d1e6 | 2015-10-20 13:23:58 +0000 | [diff] [blame^] | 24 | ASTDeserializationListener::~ASTDeserializationListener() { } |
Guy Benyei | 11169dd | 2012-12-18 14:30:41 +0000 | [diff] [blame] | 25 | |
| 26 | serialization::TypeIdx |
| 27 | serialization::TypeIdxFromBuiltin(const BuiltinType *BT) { |
| 28 | unsigned ID = 0; |
| 29 | switch (BT->getKind()) { |
Alexey Bader | bdf7c84 | 2015-09-15 12:18:29 +0000 | [diff] [blame] | 30 | case BuiltinType::Void: |
| 31 | ID = PREDEF_TYPE_VOID_ID; |
| 32 | break; |
| 33 | case BuiltinType::Bool: |
| 34 | ID = PREDEF_TYPE_BOOL_ID; |
| 35 | break; |
| 36 | case BuiltinType::Char_U: |
| 37 | ID = PREDEF_TYPE_CHAR_U_ID; |
| 38 | break; |
| 39 | case BuiltinType::UChar: |
| 40 | ID = PREDEF_TYPE_UCHAR_ID; |
| 41 | break; |
| 42 | case BuiltinType::UShort: |
| 43 | ID = PREDEF_TYPE_USHORT_ID; |
| 44 | break; |
| 45 | case BuiltinType::UInt: |
| 46 | ID = PREDEF_TYPE_UINT_ID; |
| 47 | break; |
| 48 | case BuiltinType::ULong: |
| 49 | ID = PREDEF_TYPE_ULONG_ID; |
| 50 | break; |
| 51 | case BuiltinType::ULongLong: |
| 52 | ID = PREDEF_TYPE_ULONGLONG_ID; |
| 53 | break; |
| 54 | case BuiltinType::UInt128: |
| 55 | ID = PREDEF_TYPE_UINT128_ID; |
| 56 | break; |
| 57 | case BuiltinType::Char_S: |
| 58 | ID = PREDEF_TYPE_CHAR_S_ID; |
| 59 | break; |
| 60 | case BuiltinType::SChar: |
| 61 | ID = PREDEF_TYPE_SCHAR_ID; |
| 62 | break; |
Guy Benyei | 11169dd | 2012-12-18 14:30:41 +0000 | [diff] [blame] | 63 | case BuiltinType::WChar_S: |
Alexey Bader | bdf7c84 | 2015-09-15 12:18:29 +0000 | [diff] [blame] | 64 | case BuiltinType::WChar_U: |
| 65 | ID = PREDEF_TYPE_WCHAR_ID; |
| 66 | break; |
| 67 | case BuiltinType::Short: |
| 68 | ID = PREDEF_TYPE_SHORT_ID; |
| 69 | break; |
| 70 | case BuiltinType::Int: |
| 71 | ID = PREDEF_TYPE_INT_ID; |
| 72 | break; |
| 73 | case BuiltinType::Long: |
| 74 | ID = PREDEF_TYPE_LONG_ID; |
| 75 | break; |
| 76 | case BuiltinType::LongLong: |
| 77 | ID = PREDEF_TYPE_LONGLONG_ID; |
| 78 | break; |
| 79 | case BuiltinType::Int128: |
| 80 | ID = PREDEF_TYPE_INT128_ID; |
| 81 | break; |
| 82 | case BuiltinType::Half: |
| 83 | ID = PREDEF_TYPE_HALF_ID; |
| 84 | break; |
| 85 | case BuiltinType::Float: |
| 86 | ID = PREDEF_TYPE_FLOAT_ID; |
| 87 | break; |
| 88 | case BuiltinType::Double: |
| 89 | ID = PREDEF_TYPE_DOUBLE_ID; |
| 90 | break; |
| 91 | case BuiltinType::LongDouble: |
| 92 | ID = PREDEF_TYPE_LONGDOUBLE_ID; |
| 93 | break; |
| 94 | case BuiltinType::NullPtr: |
| 95 | ID = PREDEF_TYPE_NULLPTR_ID; |
| 96 | break; |
| 97 | case BuiltinType::Char16: |
| 98 | ID = PREDEF_TYPE_CHAR16_ID; |
| 99 | break; |
| 100 | case BuiltinType::Char32: |
| 101 | ID = PREDEF_TYPE_CHAR32_ID; |
| 102 | break; |
| 103 | case BuiltinType::Overload: |
| 104 | ID = PREDEF_TYPE_OVERLOAD_ID; |
| 105 | break; |
| 106 | case BuiltinType::BoundMember: |
| 107 | ID = PREDEF_TYPE_BOUND_MEMBER; |
| 108 | break; |
| 109 | case BuiltinType::PseudoObject: |
| 110 | ID = PREDEF_TYPE_PSEUDO_OBJECT; |
| 111 | break; |
| 112 | case BuiltinType::Dependent: |
| 113 | ID = PREDEF_TYPE_DEPENDENT_ID; |
| 114 | break; |
| 115 | case BuiltinType::UnknownAny: |
| 116 | ID = PREDEF_TYPE_UNKNOWN_ANY; |
| 117 | break; |
Guy Benyei | 11169dd | 2012-12-18 14:30:41 +0000 | [diff] [blame] | 118 | case BuiltinType::ARCUnbridgedCast: |
Alexey Bader | bdf7c84 | 2015-09-15 12:18:29 +0000 | [diff] [blame] | 119 | ID = PREDEF_TYPE_ARC_UNBRIDGED_CAST; |
| 120 | break; |
| 121 | case BuiltinType::ObjCId: |
| 122 | ID = PREDEF_TYPE_OBJC_ID; |
| 123 | break; |
| 124 | case BuiltinType::ObjCClass: |
| 125 | ID = PREDEF_TYPE_OBJC_CLASS; |
| 126 | break; |
| 127 | case BuiltinType::ObjCSel: |
| 128 | ID = PREDEF_TYPE_OBJC_SEL; |
| 129 | break; |
| 130 | case BuiltinType::OCLImage1d: |
| 131 | ID = PREDEF_TYPE_IMAGE1D_ID; |
| 132 | break; |
| 133 | case BuiltinType::OCLImage1dArray: |
| 134 | ID = PREDEF_TYPE_IMAGE1D_ARR_ID; |
| 135 | break; |
| 136 | case BuiltinType::OCLImage1dBuffer: |
| 137 | ID = PREDEF_TYPE_IMAGE1D_BUFF_ID; |
| 138 | break; |
| 139 | case BuiltinType::OCLImage2d: |
| 140 | ID = PREDEF_TYPE_IMAGE2D_ID; |
| 141 | break; |
| 142 | case BuiltinType::OCLImage2dArray: |
| 143 | ID = PREDEF_TYPE_IMAGE2D_ARR_ID; |
| 144 | break; |
Alexey Bader | 9c8453f | 2015-09-15 11:18:52 +0000 | [diff] [blame] | 145 | case BuiltinType::OCLImage2dDepth: |
| 146 | ID = PREDEF_TYPE_IMAGE2D_DEP_ID; |
| 147 | break; |
| 148 | case BuiltinType::OCLImage2dArrayDepth: |
| 149 | ID = PREDEF_TYPE_IMAGE2D_ARR_DEP_ID; |
| 150 | break; |
| 151 | case BuiltinType::OCLImage2dMSAA: |
| 152 | ID = PREDEF_TYPE_IMAGE2D_MSAA_ID; |
| 153 | break; |
| 154 | case BuiltinType::OCLImage2dArrayMSAA: |
| 155 | ID = PREDEF_TYPE_IMAGE2D_ARR_MSAA_ID; |
| 156 | break; |
| 157 | case BuiltinType::OCLImage2dMSAADepth: |
| 158 | ID = PREDEF_TYPE_IMAGE2D_MSAA_DEP_ID; |
| 159 | break; |
| 160 | case BuiltinType::OCLImage2dArrayMSAADepth: |
| 161 | ID = PREDEF_TYPE_IMAGE2D_ARR_MSAA_DEPTH_ID; |
| 162 | break; |
Alexey Bader | bdf7c84 | 2015-09-15 12:18:29 +0000 | [diff] [blame] | 163 | case BuiltinType::OCLImage3d: |
| 164 | ID = PREDEF_TYPE_IMAGE3D_ID; |
| 165 | break; |
| 166 | case BuiltinType::OCLSampler: |
| 167 | ID = PREDEF_TYPE_SAMPLER_ID; |
| 168 | break; |
| 169 | case BuiltinType::OCLEvent: |
| 170 | ID = PREDEF_TYPE_EVENT_ID; |
| 171 | break; |
Alexey Bader | 9c8453f | 2015-09-15 11:18:52 +0000 | [diff] [blame] | 172 | case BuiltinType::OCLClkEvent: |
| 173 | ID = PREDEF_TYPE_CLK_EVENT_ID; |
| 174 | break; |
| 175 | case BuiltinType::OCLQueue: |
| 176 | ID = PREDEF_TYPE_QUEUE_ID; |
| 177 | break; |
| 178 | case BuiltinType::OCLNDRange: |
| 179 | ID = PREDEF_TYPE_NDRANGE_ID; |
| 180 | break; |
| 181 | case BuiltinType::OCLReserveID: |
| 182 | ID = PREDEF_TYPE_RESERVE_ID_ID; |
| 183 | break; |
Guy Benyei | 11169dd | 2012-12-18 14:30:41 +0000 | [diff] [blame] | 184 | case BuiltinType::BuiltinFn: |
Alexey Bader | bdf7c84 | 2015-09-15 12:18:29 +0000 | [diff] [blame] | 185 | ID = PREDEF_TYPE_BUILTIN_FN; |
| 186 | break; |
| 187 | case BuiltinType::OMPArraySection: |
| 188 | ID = PREDEF_TYPE_OMP_ARRAY_SECTION; |
| 189 | break; |
Guy Benyei | 11169dd | 2012-12-18 14:30:41 +0000 | [diff] [blame] | 190 | } |
| 191 | |
| 192 | return TypeIdx(ID); |
| 193 | } |
| 194 | |
| 195 | unsigned serialization::ComputeHash(Selector Sel) { |
| 196 | unsigned N = Sel.getNumArgs(); |
| 197 | if (N == 0) |
| 198 | ++N; |
| 199 | unsigned R = 5381; |
| 200 | for (unsigned I = 0; I != N; ++I) |
| 201 | if (IdentifierInfo *II = Sel.getIdentifierInfoForSlot(I)) |
| 202 | R = llvm::HashString(II->getName(), R); |
| 203 | return R; |
| 204 | } |
Douglas Gregor | 9f78289 | 2013-01-21 15:25:38 +0000 | [diff] [blame] | 205 | |
Douglas Gregor | 7a6e200 | 2013-01-22 17:08:30 +0000 | [diff] [blame] | 206 | const DeclContext * |
| 207 | serialization::getDefinitiveDeclContext(const DeclContext *DC) { |
Douglas Gregor | 9f78289 | 2013-01-21 15:25:38 +0000 | [diff] [blame] | 208 | switch (DC->getDeclKind()) { |
| 209 | // These entities may have multiple definitions. |
| 210 | case Decl::TranslationUnit: |
Richard Smith | f19e127 | 2015-03-07 00:04:49 +0000 | [diff] [blame] | 211 | case Decl::ExternCContext: |
Douglas Gregor | 9f78289 | 2013-01-21 15:25:38 +0000 | [diff] [blame] | 212 | case Decl::Namespace: |
| 213 | case Decl::LinkageSpec: |
Craig Topper | a13603a | 2014-05-22 05:54:18 +0000 | [diff] [blame] | 214 | return nullptr; |
Douglas Gregor | 9f78289 | 2013-01-21 15:25:38 +0000 | [diff] [blame] | 215 | |
| 216 | // C/C++ tag types can only be defined in one place. |
| 217 | case Decl::Enum: |
| 218 | case Decl::Record: |
| 219 | if (const TagDecl *Def = cast<TagDecl>(DC)->getDefinition()) |
| 220 | return Def; |
Craig Topper | a13603a | 2014-05-22 05:54:18 +0000 | [diff] [blame] | 221 | return nullptr; |
Douglas Gregor | 9f78289 | 2013-01-21 15:25:38 +0000 | [diff] [blame] | 222 | |
| 223 | // FIXME: These can be defined in one place... except special member |
| 224 | // functions and out-of-line definitions. |
| 225 | case Decl::CXXRecord: |
| 226 | case Decl::ClassTemplateSpecialization: |
| 227 | case Decl::ClassTemplatePartialSpecialization: |
Craig Topper | a13603a | 2014-05-22 05:54:18 +0000 | [diff] [blame] | 228 | return nullptr; |
Douglas Gregor | 9f78289 | 2013-01-21 15:25:38 +0000 | [diff] [blame] | 229 | |
| 230 | // Each function, method, and block declaration is its own DeclContext. |
| 231 | case Decl::Function: |
| 232 | case Decl::CXXMethod: |
| 233 | case Decl::CXXConstructor: |
| 234 | case Decl::CXXDestructor: |
| 235 | case Decl::CXXConversion: |
| 236 | case Decl::ObjCMethod: |
| 237 | case Decl::Block: |
Tareq A. Siraj | 6dfa25a | 2013-04-16 19:37:38 +0000 | [diff] [blame] | 238 | case Decl::Captured: |
Douglas Gregor | 9f78289 | 2013-01-21 15:25:38 +0000 | [diff] [blame] | 239 | // Objective C categories, category implementations, and class |
| 240 | // implementations can only be defined in one place. |
| 241 | case Decl::ObjCCategory: |
| 242 | case Decl::ObjCCategoryImpl: |
| 243 | case Decl::ObjCImplementation: |
Douglas Gregor | 7a6e200 | 2013-01-22 17:08:30 +0000 | [diff] [blame] | 244 | return DC; |
Douglas Gregor | 9f78289 | 2013-01-21 15:25:38 +0000 | [diff] [blame] | 245 | |
| 246 | case Decl::ObjCProtocol: |
| 247 | if (const ObjCProtocolDecl *Def |
| 248 | = cast<ObjCProtocolDecl>(DC)->getDefinition()) |
| 249 | return Def; |
Craig Topper | a13603a | 2014-05-22 05:54:18 +0000 | [diff] [blame] | 250 | return nullptr; |
Douglas Gregor | 9f78289 | 2013-01-21 15:25:38 +0000 | [diff] [blame] | 251 | |
| 252 | // FIXME: These are defined in one place, but properties in class extensions |
| 253 | // end up being back-patched into the main interface. See |
| 254 | // Sema::HandlePropertyInClassExtension for the offending code. |
| 255 | case Decl::ObjCInterface: |
Craig Topper | a13603a | 2014-05-22 05:54:18 +0000 | [diff] [blame] | 256 | return nullptr; |
| 257 | |
Douglas Gregor | 9f78289 | 2013-01-21 15:25:38 +0000 | [diff] [blame] | 258 | default: |
| 259 | llvm_unreachable("Unhandled DeclContext in AST reader"); |
| 260 | } |
| 261 | |
Douglas Gregor | 7a6e200 | 2013-01-22 17:08:30 +0000 | [diff] [blame] | 262 | llvm_unreachable("Unhandled decl kind"); |
Douglas Gregor | fe732d5 | 2013-01-21 16:16:40 +0000 | [diff] [blame] | 263 | } |
Douglas Gregor | 9f78289 | 2013-01-21 15:25:38 +0000 | [diff] [blame] | 264 | |
Douglas Gregor | fe732d5 | 2013-01-21 16:16:40 +0000 | [diff] [blame] | 265 | bool serialization::isRedeclarableDeclKind(unsigned Kind) { |
| 266 | switch (static_cast<Decl::Kind>(Kind)) { |
Richard Smith | f19e127 | 2015-03-07 00:04:49 +0000 | [diff] [blame] | 267 | case Decl::TranslationUnit: |
| 268 | case Decl::ExternCContext: |
| 269 | // Special case of a "merged" declaration. |
| 270 | return true; |
| 271 | |
Douglas Gregor | fe732d5 | 2013-01-21 16:16:40 +0000 | [diff] [blame] | 272 | case Decl::Namespace: |
Richard Smith | f463436 | 2014-09-03 23:11:22 +0000 | [diff] [blame] | 273 | case Decl::NamespaceAlias: |
Douglas Gregor | fe732d5 | 2013-01-21 16:16:40 +0000 | [diff] [blame] | 274 | case Decl::Typedef: |
| 275 | case Decl::TypeAlias: |
| 276 | case Decl::Enum: |
| 277 | case Decl::Record: |
| 278 | case Decl::CXXRecord: |
| 279 | case Decl::ClassTemplateSpecialization: |
| 280 | case Decl::ClassTemplatePartialSpecialization: |
Larisse Voufo | 39a1e50 | 2013-08-06 01:03:05 +0000 | [diff] [blame] | 281 | case Decl::VarTemplateSpecialization: |
| 282 | case Decl::VarTemplatePartialSpecialization: |
Douglas Gregor | fe732d5 | 2013-01-21 16:16:40 +0000 | [diff] [blame] | 283 | case Decl::Function: |
| 284 | case Decl::CXXMethod: |
| 285 | case Decl::CXXConstructor: |
| 286 | case Decl::CXXDestructor: |
| 287 | case Decl::CXXConversion: |
Richard Smith | fd8634a | 2013-10-23 02:17:46 +0000 | [diff] [blame] | 288 | case Decl::UsingShadow: |
Douglas Gregor | fe732d5 | 2013-01-21 16:16:40 +0000 | [diff] [blame] | 289 | case Decl::Var: |
| 290 | case Decl::FunctionTemplate: |
| 291 | case Decl::ClassTemplate: |
Larisse Voufo | 39a1e50 | 2013-08-06 01:03:05 +0000 | [diff] [blame] | 292 | case Decl::VarTemplate: |
Douglas Gregor | fe732d5 | 2013-01-21 16:16:40 +0000 | [diff] [blame] | 293 | case Decl::TypeAliasTemplate: |
| 294 | case Decl::ObjCProtocol: |
| 295 | case Decl::ObjCInterface: |
Michael Han | 8432435 | 2013-02-22 17:15:32 +0000 | [diff] [blame] | 296 | case Decl::Empty: |
Douglas Gregor | fe732d5 | 2013-01-21 16:16:40 +0000 | [diff] [blame] | 297 | return true; |
| 298 | |
| 299 | // Never redeclarable. |
| 300 | case Decl::UsingDirective: |
| 301 | case Decl::Label: |
| 302 | case Decl::UnresolvedUsingTypename: |
| 303 | case Decl::TemplateTypeParm: |
| 304 | case Decl::EnumConstant: |
| 305 | case Decl::UnresolvedUsingValue: |
| 306 | case Decl::IndirectField: |
| 307 | case Decl::Field: |
John McCall | 5e77d76 | 2013-04-16 07:28:30 +0000 | [diff] [blame] | 308 | case Decl::MSProperty: |
Douglas Gregor | fe732d5 | 2013-01-21 16:16:40 +0000 | [diff] [blame] | 309 | case Decl::ObjCIvar: |
| 310 | case Decl::ObjCAtDefsField: |
Douglas Gregor | fe732d5 | 2013-01-21 16:16:40 +0000 | [diff] [blame] | 311 | case Decl::NonTypeTemplateParm: |
| 312 | case Decl::TemplateTemplateParm: |
| 313 | case Decl::Using: |
Douglas Gregor | fe732d5 | 2013-01-21 16:16:40 +0000 | [diff] [blame] | 314 | case Decl::ObjCMethod: |
| 315 | case Decl::ObjCCategory: |
| 316 | case Decl::ObjCCategoryImpl: |
| 317 | case Decl::ObjCImplementation: |
| 318 | case Decl::ObjCProperty: |
| 319 | case Decl::ObjCCompatibleAlias: |
| 320 | case Decl::LinkageSpec: |
| 321 | case Decl::ObjCPropertyImpl: |
| 322 | case Decl::FileScopeAsm: |
| 323 | case Decl::AccessSpec: |
| 324 | case Decl::Friend: |
| 325 | case Decl::FriendTemplate: |
| 326 | case Decl::StaticAssert: |
| 327 | case Decl::Block: |
Tareq A. Siraj | 6dfa25a | 2013-04-16 19:37:38 +0000 | [diff] [blame] | 328 | case Decl::Captured: |
Douglas Gregor | fe732d5 | 2013-01-21 16:16:40 +0000 | [diff] [blame] | 329 | case Decl::ClassScopeFunctionSpecialization: |
| 330 | case Decl::Import: |
Alexey Bataev | a769e07 | 2013-03-22 06:34:35 +0000 | [diff] [blame] | 331 | case Decl::OMPThreadPrivate: |
Douglas Gregor | fe732d5 | 2013-01-21 16:16:40 +0000 | [diff] [blame] | 332 | return false; |
Richard Smith | f463436 | 2014-09-03 23:11:22 +0000 | [diff] [blame] | 333 | |
| 334 | // These indirectly derive from Redeclarable<T> but are not actually |
| 335 | // redeclarable. |
| 336 | case Decl::ImplicitParam: |
| 337 | case Decl::ParmVar: |
Douglas Gregor | 85f3f95 | 2015-07-07 03:57:15 +0000 | [diff] [blame] | 338 | case Decl::ObjCTypeParam: |
Richard Smith | f463436 | 2014-09-03 23:11:22 +0000 | [diff] [blame] | 339 | return false; |
Douglas Gregor | fe732d5 | 2013-01-21 16:16:40 +0000 | [diff] [blame] | 340 | } |
| 341 | |
| 342 | llvm_unreachable("Unhandled declaration kind"); |
Douglas Gregor | 9f78289 | 2013-01-21 15:25:38 +0000 | [diff] [blame] | 343 | } |
Richard Smith | d08aeb6 | 2014-08-28 01:33:39 +0000 | [diff] [blame] | 344 | |
| 345 | bool serialization::needsAnonymousDeclarationNumber(const NamedDecl *D) { |
Richard Smith | 2b56057 | 2015-02-07 03:11:11 +0000 | [diff] [blame] | 346 | // Friend declarations in dependent contexts aren't anonymous in the usual |
| 347 | // sense, but they cannot be found by name lookup in their semantic context |
| 348 | // (or indeed in any context), so we treat them as anonymous. |
| 349 | // |
| 350 | // This doesn't apply to friend tag decls; Sema makes those available to name |
| 351 | // lookup in the surrounding context. |
| 352 | if (D->getFriendObjectKind() && |
| 353 | D->getLexicalDeclContext()->isDependentContext() && !isa<TagDecl>(D)) { |
| 354 | // For function templates and class templates, the template is numbered and |
| 355 | // not its pattern. |
| 356 | if (auto *FD = dyn_cast<FunctionDecl>(D)) |
| 357 | return !FD->getDescribedFunctionTemplate(); |
| 358 | if (auto *RD = dyn_cast<CXXRecordDecl>(D)) |
| 359 | return !RD->getDescribedClassTemplate(); |
| 360 | return true; |
| 361 | } |
| 362 | |
| 363 | // Otherwise, we only care about anonymous class members. |
Richard Smith | d08aeb6 | 2014-08-28 01:33:39 +0000 | [diff] [blame] | 364 | if (D->getDeclName() || !isa<CXXRecordDecl>(D->getLexicalDeclContext())) |
| 365 | return false; |
| 366 | return isa<TagDecl>(D) || isa<FieldDecl>(D); |
| 367 | } |
| 368 | |