Chris Lattner | ddc135e | 2006-11-10 06:34:16 +0000 | [diff] [blame] | 1 | //===--- ASTContext.cpp - Context to hold long-lived AST nodes ------------===// |
| 2 | // |
| 3 | // The LLVM Compiler Infrastructure |
| 4 | // |
| 5 | // This file was developed by Chris Lattner and is distributed under |
| 6 | // the University of Illinois Open Source License. See LICENSE.TXT for details. |
| 7 | // |
| 8 | //===----------------------------------------------------------------------===// |
| 9 | // |
| 10 | // This file implements the ASTContext interface. |
| 11 | // |
| 12 | //===----------------------------------------------------------------------===// |
| 13 | |
| 14 | #include "clang/AST/ASTContext.h" |
Chris Lattner | 970e54e | 2006-11-12 00:37:36 +0000 | [diff] [blame] | 15 | #include "clang/AST/Type.h" |
Chris Lattner | ddc135e | 2006-11-10 06:34:16 +0000 | [diff] [blame] | 16 | #include "clang/Lex/Preprocessor.h" |
| 17 | using namespace llvm; |
| 18 | using namespace clang; |
| 19 | |
| 20 | ASTContext::ASTContext(Preprocessor &pp) |
| 21 | : PP(pp), Target(pp.getTargetInfo()) { |
Chris Lattner | 970e54e | 2006-11-12 00:37:36 +0000 | [diff] [blame] | 22 | InitBuiltinTypes(); |
| 23 | } |
| 24 | |
Chris Lattner | d5973eb | 2006-11-12 00:53:46 +0000 | [diff] [blame] | 25 | ASTContext::~ASTContext() { |
| 26 | // Deallocate all the types. |
| 27 | while (!Types.empty()) { |
| 28 | delete Types.back(); |
| 29 | Types.pop_back(); |
| 30 | } |
| 31 | } |
| 32 | |
| 33 | void ASTContext::InitBuiltinType(TypeRef &R, const char *Name) { |
| 34 | Types.push_back((R = new BuiltinType(Name)).getTypePtr()); |
| 35 | } |
| 36 | |
| 37 | |
Chris Lattner | 970e54e | 2006-11-12 00:37:36 +0000 | [diff] [blame] | 38 | void ASTContext::InitBuiltinTypes() { |
| 39 | assert(VoidTy.isNull() && "Context reinitialized?"); |
| 40 | |
| 41 | // C99 6.2.5p19. |
Chris Lattner | d5973eb | 2006-11-12 00:53:46 +0000 | [diff] [blame] | 42 | InitBuiltinType(VoidTy, "void"); |
Chris Lattner | 970e54e | 2006-11-12 00:37:36 +0000 | [diff] [blame] | 43 | |
| 44 | // C99 6.2.5p2. |
Chris Lattner | d5973eb | 2006-11-12 00:53:46 +0000 | [diff] [blame] | 45 | InitBuiltinType(BoolTy, "_Bool"); |
Chris Lattner | 970e54e | 2006-11-12 00:37:36 +0000 | [diff] [blame] | 46 | // C99 6.2.5p3. |
Chris Lattner | d5973eb | 2006-11-12 00:53:46 +0000 | [diff] [blame] | 47 | InitBuiltinType(CharTy, "char"); |
Chris Lattner | 970e54e | 2006-11-12 00:37:36 +0000 | [diff] [blame] | 48 | // C99 6.2.5p4. |
Chris Lattner | d5973eb | 2006-11-12 00:53:46 +0000 | [diff] [blame] | 49 | InitBuiltinType(SignedCharTy, "signed char"); |
| 50 | InitBuiltinType(ShortTy, "short"); |
| 51 | InitBuiltinType(IntTy, "int"); |
| 52 | InitBuiltinType(LongTy, "long"); |
| 53 | InitBuiltinType(LongLongTy, "long long"); |
Chris Lattner | 970e54e | 2006-11-12 00:37:36 +0000 | [diff] [blame] | 54 | |
| 55 | // C99 6.2.5p6. |
Chris Lattner | d5973eb | 2006-11-12 00:53:46 +0000 | [diff] [blame] | 56 | InitBuiltinType(UnsignedCharTy, "unsigned char"); |
| 57 | InitBuiltinType(UnsignedShortTy, "unsigned short"); |
| 58 | InitBuiltinType(UnsignedIntTy, "unsigned int"); |
| 59 | InitBuiltinType(UnsignedLongTy, "unsigned long"); |
| 60 | InitBuiltinType(UnsignedLongLongTy, "unsigned long long"); |
Chris Lattner | 970e54e | 2006-11-12 00:37:36 +0000 | [diff] [blame] | 61 | |
| 62 | // C99 6.2.5p10. |
Chris Lattner | d5973eb | 2006-11-12 00:53:46 +0000 | [diff] [blame] | 63 | InitBuiltinType(FloatTy, "float"); |
| 64 | InitBuiltinType(DoubleTy, "double"); |
| 65 | InitBuiltinType(LongDoubleTy, "long double"); |
Chris Lattner | 970e54e | 2006-11-12 00:37:36 +0000 | [diff] [blame] | 66 | |
| 67 | // C99 6.2.5p11. |
Chris Lattner | d5973eb | 2006-11-12 00:53:46 +0000 | [diff] [blame] | 68 | InitBuiltinType(FloatComplexTy, "float _Complex"); |
| 69 | InitBuiltinType(DoubleComplexTy, "double _Complex"); |
| 70 | InitBuiltinType(LongDoubleComplexTy, "long double _Complex"); |
Chris Lattner | 970e54e | 2006-11-12 00:37:36 +0000 | [diff] [blame] | 71 | } |
| 72 | |
| 73 | /// getPointerType - Return the uniqued reference to the type for a pointer to |
| 74 | /// the specified type. |
Chris Lattner | 7ccecb9 | 2006-11-12 08:50:50 +0000 | [diff] [blame^] | 75 | TypeRef ASTContext::getPointerType(TypeRef T) { |
Chris Lattner | d5973eb | 2006-11-12 00:53:46 +0000 | [diff] [blame] | 76 | // FIXME: This is obviously braindead! |
| 77 | // Unique pointers, to guarantee there is only one pointer of a particular |
| 78 | // structure. |
| 79 | for (unsigned i = 0, e = Types.size(); i != e; ++i) |
Chris Lattner | 4781466 | 2006-11-12 00:56:20 +0000 | [diff] [blame] | 80 | if (PointerType *PTy = dyn_cast<PointerType>(Types[i])) |
Chris Lattner | 7ccecb9 | 2006-11-12 08:50:50 +0000 | [diff] [blame^] | 81 | if (PTy->getPointeeType() == T) |
Chris Lattner | d5973eb | 2006-11-12 00:53:46 +0000 | [diff] [blame] | 82 | return Types[i]; |
Chris Lattner | 970e54e | 2006-11-12 00:37:36 +0000 | [diff] [blame] | 83 | |
Chris Lattner | 7ccecb9 | 2006-11-12 08:50:50 +0000 | [diff] [blame^] | 84 | // If the pointee type isn't canonical, this won't be a canonical type either, |
| 85 | // so fill in the canonical type field. |
Chris Lattner | 970e54e | 2006-11-12 00:37:36 +0000 | [diff] [blame] | 86 | Type *Canonical = 0; |
| 87 | if (!T->isCanonical()) |
| 88 | Canonical = getPointerType(T.getCanonicalType()).getTypePtr(); |
Chris Lattner | d5973eb | 2006-11-12 00:53:46 +0000 | [diff] [blame] | 89 | |
| 90 | Types.push_back(new PointerType(T, Canonical)); |
| 91 | return Types.back(); |
Chris Lattner | ddc135e | 2006-11-10 06:34:16 +0000 | [diff] [blame] | 92 | } |
| 93 | |
Chris Lattner | 7ccecb9 | 2006-11-12 08:50:50 +0000 | [diff] [blame^] | 94 | /// getArrayType - Return the unique reference to the type for an array of the |
| 95 | /// specified element type. |
| 96 | TypeRef ASTContext::getArrayType(TypeRef EltTy,ArrayType::ArraySizeModifier ASM, |
| 97 | unsigned EltTypeQuals, void *NumElts) { |
| 98 | #warning "IGNORING SIZE" |
| 99 | |
| 100 | // FIXME: This is obviously braindead! |
| 101 | // Unique array, to guarantee there is only one array of a particular |
| 102 | // structure. |
| 103 | for (unsigned i = 0, e = Types.size(); i != e; ++i) |
| 104 | if (ArrayType *ATy = dyn_cast<ArrayType>(Types[i])) |
| 105 | if (ATy->getElementType() == EltTy && |
| 106 | ATy->getSizeModifier() == ASM && |
| 107 | ATy->getIndexTypeQualifier() == EltTypeQuals) |
| 108 | return Types[i]; |
| 109 | |
| 110 | // If the element type isn't canonical, this won't be a canonical type either, |
| 111 | // so fill in the canonical type field. |
| 112 | Type *Canonical = 0; |
| 113 | if (!EltTy->isCanonical()) |
| 114 | Canonical = getArrayType(EltTy.getCanonicalType(), ASM, EltTypeQuals, |
| 115 | NumElts).getTypePtr(); |
| 116 | |
| 117 | Types.push_back(new ArrayType(EltTy, ASM, EltTypeQuals, Canonical)); |
| 118 | return Types.back(); |
| 119 | } |
| 120 | |
Chris Lattner | ef51c20 | 2006-11-10 07:17:23 +0000 | [diff] [blame] | 121 | |