Type.h revision 3cbc064cf343c2151488b7822430ed327ade176e
14b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner//===--- Type.h - C Language Family Type Representation ---------*- C++ -*-===//
24b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner//
34b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner//                     The LLVM Compiler Infrastructure
44b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner//
5959e5be188a505881058777f35abaaa3fe2de40bChris Lattner// This file is distributed under the University of Illinois Open Source
6959e5be188a505881058777f35abaaa3fe2de40bChris Lattner// License. See LICENSE.TXT for details.
74b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner//
84b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner//===----------------------------------------------------------------------===//
94b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner//
104b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner//  This file defines the Type interface and subclasses.
114b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner//
124b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner//===----------------------------------------------------------------------===//
134b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
144b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner#ifndef LLVM_CLANG_AST_TYPE_H
154b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner#define LLVM_CLANG_AST_TYPE_H
164b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
174b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner#include "llvm/Support/Casting.h"
184b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner#include "llvm/ADT/FoldingSet.h"
1983c13010359c33354c581acee65d0c986a75247eSteve Naroff#include "llvm/ADT/APSInt.h"
2078f138f44886abc5ab7fc1551d501308f1846d80Ted Kremenek#include "llvm/Bitcode/SerializationFwd.h"
214b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
224b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerusing llvm::isa;
234b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerusing llvm::cast;
244b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerusing llvm::cast_or_null;
254b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerusing llvm::dyn_cast;
264b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerusing llvm::dyn_cast_or_null;
274b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
284b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnernamespace clang {
294b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  class ASTContext;
304b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  class Type;
314b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  class TypedefDecl;
324b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  class TagDecl;
334b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  class RecordDecl;
34ea29d1ec6b76c3722d7c0fb6a3d35c2d8cc74a79Argiris Kirtzidis  class CXXRecordDecl;
354b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  class EnumDecl;
3664be4ada44c719304c1dee75fb1e551f84b7779aTed Kremenek  class FieldDecl;
3742730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek  class ObjCInterfaceDecl;
3842730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek  class ObjCProtocolDecl;
3942730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek  class ObjCMethodDecl;
404b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  class Expr;
41718b6638e0d259d1b8371ef30e475e9c2e981ffcTed Kremenek  class Stmt;
424b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  class SourceLocation;
43cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner  class PointerLikeType;
444b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  class PointerType;
457aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff  class BlockPointerType;
464b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  class ReferenceType;
474b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  class VectorType;
484b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  class ArrayType;
495eb879b0ab7cc0b98c5700b0c19cae3797530d9cSteve Naroff  class ConstantArrayType;
505eb879b0ab7cc0b98c5700b0c19cae3797530d9cSteve Naroff  class VariableArrayType;
518ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman  class IncompleteArrayType;
522cb6638a26cfa999e5fb999e6af9211127e681c1Steve Naroff  class RecordType;
530832dbca0e11ee020bbed181c515b3835158436eEli Friedman  class EnumType;
547a85fa1ba94c9f4cf960463dd3eb444ef6f89446Chris Lattner  class ComplexType;
55806b319509d01bffe47317f11140c930da800dbbSteve Naroff  class TagType;
565c45be48e6125c5981ad48708dc7e8267bace63aTed Kremenek  class TypedefType;
57806b319509d01bffe47317f11140c930da800dbbSteve Naroff  class FunctionType;
58d5a56aae166344e13f1f8c845530beee0868db49Chris Lattner  class FunctionTypeProto;
59af6ed504d90dc3b813c573bfbee8bc0e92e7fdc0Nate Begeman  class ExtVectorType;
60c33c060e2f4e7c7e89e3b809f52cfc6d55ea9838Steve Naroff  class BuiltinType;
61b06cf30badcddfea862bc9a538447453bdd94598Chris Lattner  class ObjCInterfaceType;
62b06cf30badcddfea862bc9a538447453bdd94598Chris Lattner  class ObjCQualifiedIdType;
6342730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek  class ObjCQualifiedInterfaceType;
64fce813e3159a67a57a03cdca45ac4e10d4cffac3Ted Kremenek  class StmtIteratorBase;
654b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
664b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// QualType - For efficiency, we don't store CVR-qualified types as nodes on
674b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// their own: instead each reference to a type stores the qualifiers.  This
684b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// greatly reduces the number of nodes we need to allocate for types (for
694b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// example we only need one for 'int', 'const int', 'volatile int',
704b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// 'const volatile int', etc).
714b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner///
724b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// As an added efficiency bonus, instead of making this a pair, we just store
734b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// the three bits we care about in the low bits of the pointer.  To handle the
744b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// packing/unpacking, we make QualType be a simple wrapper class that acts like
754b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// a smart pointer.
764b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerclass QualType {
774b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  uintptr_t ThePtr;
784b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerpublic:
794b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  enum TQ {   // NOTE: These flags must be kept in sync with DeclSpec::TQ.
804b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    Const    = 0x1,
814b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    Restrict = 0x2,
824b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    Volatile = 0x4,
834b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    CVRFlags = Const|Restrict|Volatile
844b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  };
854b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
864b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  QualType() : ThePtr(0) {}
874b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
884b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  QualType(Type *Ptr, unsigned Quals) {
894b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    assert((Quals & ~CVRFlags) == 0 && "Invalid type qualifiers!");
90aeaf7eff830282cdf1e57b4eeb28833d57c9d4edSteve Naroff    ThePtr = reinterpret_cast<uintptr_t>(Ptr);
91aeaf7eff830282cdf1e57b4eeb28833d57c9d4edSteve Naroff    assert((ThePtr & CVRFlags) == 0 && "Type pointer not 8-byte aligned?");
92aeaf7eff830282cdf1e57b4eeb28833d57c9d4edSteve Naroff    ThePtr |= Quals;
93aeaf7eff830282cdf1e57b4eeb28833d57c9d4edSteve Naroff  }
94aeaf7eff830282cdf1e57b4eeb28833d57c9d4edSteve Naroff
95aeaf7eff830282cdf1e57b4eeb28833d57c9d4edSteve Naroff  QualType(const Type *Ptr, unsigned Quals) {
96aeaf7eff830282cdf1e57b4eeb28833d57c9d4edSteve Naroff    assert((Quals & ~CVRFlags) == 0 && "Invalid type qualifiers!");
974b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    ThePtr = reinterpret_cast<uintptr_t>(Ptr);
984b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    assert((ThePtr & CVRFlags) == 0 && "Type pointer not 8-byte aligned?");
994b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    ThePtr |= Quals;
1004b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
1014b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
1024b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static QualType getFromOpaquePtr(void *Ptr) {
1034b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    QualType T;
1044b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    T.ThePtr = reinterpret_cast<uintptr_t>(Ptr);
1054b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    return T;
1064b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
1074b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
10835fef52886c88e3855745917fcb0bf6a19fa0ba1Chris Lattner  unsigned getCVRQualifiers() const {
1094b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    return ThePtr & CVRFlags;
1104b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
1114b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  Type *getTypePtr() const {
1124b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    return reinterpret_cast<Type*>(ThePtr & ~CVRFlags);
1134b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
1144b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
1154b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  void *getAsOpaquePtr() const {
1164b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    return reinterpret_cast<void*>(ThePtr);
1174b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
1184b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
1194b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  Type &operator*() const {
1204b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    return *getTypePtr();
1214b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
1224b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
1234b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  Type *operator->() const {
1244b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    return getTypePtr();
1254b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
1264b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
1274b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// isNull - Return true if this QualType doesn't point to a type yet.
1284b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  bool isNull() const {
1294b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    return ThePtr == 0;
1304b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
1314b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
1324b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  bool isConstQualified() const {
133c75ccff9e318638cac63fe392f68893ab4177f45Chris Lattner    return (ThePtr & Const) ? true : false;
1344b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
1354b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  bool isVolatileQualified() const {
136c75ccff9e318638cac63fe392f68893ab4177f45Chris Lattner    return (ThePtr & Volatile) ? true : false;
1374b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
1384b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  bool isRestrictQualified() const {
139c75ccff9e318638cac63fe392f68893ab4177f45Chris Lattner    return (ThePtr & Restrict) ? true : false;
1404b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
141a7bbf567dac9dfd58f12c9ff14584d64104694f3Nuno Lopes
142a7bbf567dac9dfd58f12c9ff14584d64104694f3Nuno Lopes  bool isConstant(ASTContext& Ctx) const;
1432e3b1d2ed22e5638fa9c55cc1ea5dac4db6aecdcChris Lattner
1442e3b1d2ed22e5638fa9c55cc1ea5dac4db6aecdcChris Lattner  /// addConst/addVolatile/addRestrict - add the specified type qual to this
1452e3b1d2ed22e5638fa9c55cc1ea5dac4db6aecdcChris Lattner  /// QualType.
1462e3b1d2ed22e5638fa9c55cc1ea5dac4db6aecdcChris Lattner  void addConst()    { ThePtr |= Const; }
1472e3b1d2ed22e5638fa9c55cc1ea5dac4db6aecdcChris Lattner  void addVolatile() { ThePtr |= Volatile; }
1482e3b1d2ed22e5638fa9c55cc1ea5dac4db6aecdcChris Lattner  void addRestrict() { ThePtr |= Restrict; }
1494b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
15093eb82549eec82d75ce5dd3afbeeaf6fdb0e2a27Sanjiv Gupta  void removeConst()    { ThePtr &= ~Const; }
15193eb82549eec82d75ce5dd3afbeeaf6fdb0e2a27Sanjiv Gupta  void removeVolatile() { ThePtr &= ~Volatile; }
15293eb82549eec82d75ce5dd3afbeeaf6fdb0e2a27Sanjiv Gupta  void removeRestrict() { ThePtr &= ~Restrict; }
15393eb82549eec82d75ce5dd3afbeeaf6fdb0e2a27Sanjiv Gupta
1544b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  QualType getQualifiedType(unsigned TQs) const {
1554b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    return QualType(getTypePtr(), TQs);
1564b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
157a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner  QualType getWithAdditionalQualifiers(unsigned TQs) const {
158a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner    return QualType(getTypePtr(), TQs|getCVRQualifiers());
159a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner  }
1604b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
1612a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  inline QualType getUnqualifiedType() const;
1624b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
1634b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// operator==/!= - Indicate whether the specified types and qualifiers are
1644b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// identical.
1654b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  bool operator==(const QualType &RHS) const {
1664b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    return ThePtr == RHS.ThePtr;
1674b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
1684b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  bool operator!=(const QualType &RHS) const {
1694b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    return ThePtr != RHS.ThePtr;
1704b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
1714b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  std::string getAsString() const {
1724b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    std::string S;
1734b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    getAsStringInternal(S);
1744b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    return S;
1754b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
1764b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  void getAsStringInternal(std::string &Str) const;
1774b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
178a55e321bd645398b514e246981c04a4889ee2472Chris Lattner  void dump(const char *s) const;
179a55e321bd645398b514e246981c04a4889ee2472Chris Lattner  void dump() const;
1809d464449c2a782e0a91ea85d79ad9e35418ec441Ted Kremenek
1819d464449c2a782e0a91ea85d79ad9e35418ec441Ted Kremenek  void Profile(llvm::FoldingSetNodeID &ID) const {
1829d464449c2a782e0a91ea85d79ad9e35418ec441Ted Kremenek    ID.AddPointer(getAsOpaquePtr());
1839d464449c2a782e0a91ea85d79ad9e35418ec441Ted Kremenek  }
1844b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
185b06cf30badcddfea862bc9a538447453bdd94598Chris Lattnerpublic:
1864b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
1872a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  /// getAddressSpace - Return the address space of this type.
1882a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  inline unsigned getAddressSpace() const;
1892a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb
190034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek  /// Emit - Serialize a QualType to Bitcode.
19178f138f44886abc5ab7fc1551d501308f1846d80Ted Kremenek  void Emit(llvm::Serializer& S) const;
19278f138f44886abc5ab7fc1551d501308f1846d80Ted Kremenek
193034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek  /// Read - Deserialize a QualType from Bitcode.
194034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek  static QualType ReadVal(llvm::Deserializer& D);
19564be4ada44c719304c1dee75fb1e551f84b7779aTed Kremenek
19664be4ada44c719304c1dee75fb1e551f84b7779aTed Kremenek  void ReadBackpatch(llvm::Deserializer& D);
1974b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner};
1984b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
1994b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner} // end clang.
2004b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
2014b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnernamespace llvm {
2024b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// Implement simplify_type for QualType, so that we can dyn_cast from QualType
2034b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// to a specific Type class.
2044b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnertemplate<> struct simplify_type<const ::clang::QualType> {
2054b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  typedef ::clang::Type* SimpleType;
2064b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static SimpleType getSimplifiedValue(const ::clang::QualType &Val) {
2074b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    return Val.getTypePtr();
2084b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
2094b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner};
2104b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnertemplate<> struct simplify_type< ::clang::QualType>
2114b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  : public simplify_type<const ::clang::QualType> {};
21278f138f44886abc5ab7fc1551d501308f1846d80Ted Kremenek
21378f138f44886abc5ab7fc1551d501308f1846d80Ted Kremenek} // end namespace llvm
2144b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
2154b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnernamespace clang {
2164b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
2174b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// Type - This is the base class of the type hierarchy.  A central concept
2184b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// with types is that each type always has a canonical type.  A canonical type
2194b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// is the type with any typedef names stripped out of it or the types it
2204b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// references.  For example, consider:
2214b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner///
2224b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner///  typedef int  foo;
2234b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner///  typedef foo* bar;
2244b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner///    'int *'    'foo *'    'bar'
2254b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner///
2264b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// There will be a Type object created for 'int'.  Since int is canonical, its
2274b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// canonicaltype pointer points to itself.  There is also a Type for 'foo' (a
2284b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// TypeNameType).  Its CanonicalType pointer points to the 'int' Type.  Next
2294b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// there is a PointerType that represents 'int*', which, like 'int', is
2304b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// canonical.  Finally, there is a PointerType type for 'foo*' whose canonical
2314b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// type is 'int*', and there is a TypeNameType for 'bar', whose canonical type
2324b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// is also 'int*'.
2334b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner///
2344b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// Non-canonical types are useful for emitting diagnostics, without losing
2354b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// information about typedefs being used.  Canonical types are useful for type
2364b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// comparisons (they allow by-pointer equality tests) and useful for reasoning
2374b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// about whether something has a particular form (e.g. is a function type),
2384b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// because they implicitly, recursively, strip all typedefs out of a type.
2394b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner///
2404b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// Types, once created, are immutable.
2414b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner///
2424b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerclass Type {
2434b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerpublic:
2444b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  enum TypeClass {
24583c13010359c33354c581acee65d0c986a75247eSteve Naroff    Builtin, Complex, Pointer, Reference,
2468ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman    ConstantArray, VariableArray, IncompleteArray,
247af6ed504d90dc3b813c573bfbee8bc0e92e7fdc0Nate Begeman    Vector, ExtVector,
2484b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    FunctionNoProto, FunctionProto,
2492a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb    TypeName, Tagged, ASQual,
25042730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek    ObjCInterface, ObjCQualifiedInterface,
25142730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek    ObjCQualifiedId,
2527aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff    TypeOfExp, TypeOfTyp, // GNU typeof extension.
2537aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff    BlockPointer          // C extension
2544b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  };
2554b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerprivate:
2564b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  QualType CanonicalType;
2574b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
2584b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// TypeClass bitfield - Enum that specifies what subclass this belongs to.
2594b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// Note that this should stay at the end of the ivars for Type so that
2604b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// subclasses can pack their bitfields into the same word.
2612a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  unsigned TC : 5;
2624b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerprotected:
2637c6f0c755e48a2782bc0a0a4cfc63dc84e0f11d5Hartmut Kaiser  // silence VC++ warning C4355: 'this' : used in base member initializer list
2647c6f0c755e48a2782bc0a0a4cfc63dc84e0f11d5Hartmut Kaiser  Type *this_() { return this; }
2654b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  Type(TypeClass tc, QualType Canonical)
26635fef52886c88e3855745917fcb0bf6a19fa0ba1Chris Lattner    : CanonicalType(Canonical.isNull() ? QualType(this_(), 0) : Canonical),
26735fef52886c88e3855745917fcb0bf6a19fa0ba1Chris Lattner      TC(tc) {}
268db4d5970d9243fb699f250f74eab6b7cce901a40Ted Kremenek  virtual ~Type() {};
269db4d5970d9243fb699f250f74eab6b7cce901a40Ted Kremenek  virtual void Destroy(ASTContext& C);
2704b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  friend class ASTContext;
27178f138f44886abc5ab7fc1551d501308f1846d80Ted Kremenek
27278f138f44886abc5ab7fc1551d501308f1846d80Ted Kremenek  void EmitTypeInternal(llvm::Serializer& S) const;
27378f138f44886abc5ab7fc1551d501308f1846d80Ted Kremenek  void ReadTypeInternal(llvm::Deserializer& D);
27478f138f44886abc5ab7fc1551d501308f1846d80Ted Kremenek
2754b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerpublic:
27692803daaa6a40a3899c2e599bddc42732c2ce593Hartmut Kaiser  TypeClass getTypeClass() const { return static_cast<TypeClass>(TC); }
2774b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
2784b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  bool isCanonical() const { return CanonicalType.getTypePtr() == this; }
2794b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
2804b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// Types are partitioned into 3 broad categories (C99 6.2.5p1):
2814b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// object types, function types, and incomplete types.
2824b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
2834b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// isObjectType - types that fully describe objects. An object is a region
2844b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// of memory that can be examined and stored into (H&S).
2854b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  bool isObjectType() const;
2864b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
2874b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// isIncompleteType - Return true if this is an incomplete type.
2884b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// A type that can describe objects, but which lacks information needed to
2894b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// determine its size (e.g. void, or a fwd declared struct). Clients of this
2904b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// routine will need to determine if the size is actually required.
2914b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  bool isIncompleteType() const;
2929db553e9ffdcd7c9fbd2fa6cf70646370e589159Chris Lattner
2939db553e9ffdcd7c9fbd2fa6cf70646370e589159Chris Lattner  /// isIncompleteOrObjectType - Return true if this is an incomplete or object
2949db553e9ffdcd7c9fbd2fa6cf70646370e589159Chris Lattner  /// type, in other words, not a function type.
2959db553e9ffdcd7c9fbd2fa6cf70646370e589159Chris Lattner  bool isIncompleteOrObjectType() const {
2969db553e9ffdcd7c9fbd2fa6cf70646370e589159Chris Lattner    return !isFunctionType();
2979db553e9ffdcd7c9fbd2fa6cf70646370e589159Chris Lattner  }
2984b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
2995eb879b0ab7cc0b98c5700b0c19cae3797530d9cSteve Naroff  /// isVariablyModifiedType (C99 6.7.5.2p2) - Return true for variable array
3005eb879b0ab7cc0b98c5700b0c19cae3797530d9cSteve Naroff  /// types that have a non-constant expression. This does not include "[]".
3015eb879b0ab7cc0b98c5700b0c19cae3797530d9cSteve Naroff  bool isVariablyModifiedType() const;
3025eb879b0ab7cc0b98c5700b0c19cae3797530d9cSteve Naroff
3034b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// Helper methods to distinguish type categories. All type predicates
3042a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  /// operate on the canonical type, ignoring typedefs and qualifiers.
3058888c7acd5cd43c7f910bfe03f5979ed4011de2aSteve Naroff
3068888c7acd5cd43c7f910bfe03f5979ed4011de2aSteve Naroff  /// isIntegerType() does *not* include complex integers (a GCC extension).
3078888c7acd5cd43c7f910bfe03f5979ed4011de2aSteve Naroff  /// isComplexIntegerType() can be used to test for complex integers.
3084b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  bool isIntegerType() const;     // C99 6.2.5p17 (int, char, bool, enum)
3098d3b170e5cb1700b5cbd227182bc29ca0d16819dSteve Naroff  bool isEnumeralType() const;
3108d3b170e5cb1700b5cbd227182bc29ca0d16819dSteve Naroff  bool isBooleanType() const;
3118d3b170e5cb1700b5cbd227182bc29ca0d16819dSteve Naroff  bool isCharType() const;
3121815b3bfc1382c88bee771bd158755b2426f0780Douglas Gregor  bool isWideCharType() const;
313c81f316d260b8b8b9da21a0f9a22baa334e063fbFariborz Jahanian  bool isIntegralType() const;
3144b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
3154b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// Floating point categories.
3164b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  bool isRealFloatingType() const; // C99 6.2.5p10 (float, double, long double)
3174300121ffff80d4b23d17689930e2aa2a83086b9Steve Naroff  /// isComplexType() does *not* include complex integers (a GCC extension).
3184300121ffff80d4b23d17689930e2aa2a83086b9Steve Naroff  /// isComplexIntegerType() can be used to test for complex integers.
3194b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  bool isComplexType() const;      // C99 6.2.5p11 (complex)
3203277df47de6b65b55721726dc3f7b294e70ef6feChris Lattner  bool isAnyComplexType() const;   // C99 6.2.5p11 (complex) + Complex Int.
3214b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  bool isFloatingType() const;     // C99 6.2.5p11 (real floating + complex)
3224b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  bool isRealType() const;         // C99 6.2.5p17 (real floating + integer)
3234b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  bool isArithmeticType() const;   // C99 6.2.5p18 (integer + floating)
324e35a104a7d5caf8fa71117fbaa6f18cacc53c7a7Chris Lattner  bool isVoidType() const;         // C99 6.2.5p19
325e35a104a7d5caf8fa71117fbaa6f18cacc53c7a7Chris Lattner  bool isDerivedType() const;      // C99 6.2.5p20
326e35a104a7d5caf8fa71117fbaa6f18cacc53c7a7Chris Lattner  bool isScalarType() const;       // C99 6.2.5p21 (arithmetic + pointers)
327e35a104a7d5caf8fa71117fbaa6f18cacc53c7a7Chris Lattner  bool isAggregateType() const;    // C99 6.2.5p21 (arrays, structures)
3284b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
329e35a104a7d5caf8fa71117fbaa6f18cacc53c7a7Chris Lattner  // Type Predicates: Check to see if this type is structurally the specified
3302a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  // type, ignoring typedefs and qualifiers.
331e35a104a7d5caf8fa71117fbaa6f18cacc53c7a7Chris Lattner  bool isFunctionType() const;
332cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner  bool isPointerLikeType() const; // Pointer or Reference.
3337931f4a186bc76b21dd4629ee74d64264a7fb8a2Chris Lattner  bool isPointerType() const;
3347aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff  bool isBlockPointerType() const;
335f0c4a0a830c9154b1ae72e497c2ce586c10e9b71Chris Lattner  bool isReferenceType() const;
336cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner  bool isFunctionPointerType() const;
337e35a104a7d5caf8fa71117fbaa6f18cacc53c7a7Chris Lattner  bool isArrayType() const;
338a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner  bool isConstantArrayType() const;
339a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner  bool isIncompleteArrayType() const;
340a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner  bool isVariableArrayType() const;
341e35a104a7d5caf8fa71117fbaa6f18cacc53c7a7Chris Lattner  bool isRecordType() const;
3422e78db3510b136b3f961af202e6a1a3df4839172Chris Lattner  bool isClassType() const;
343e35a104a7d5caf8fa71117fbaa6f18cacc53c7a7Chris Lattner  bool isStructureType() const;
34436e35e652e28cbdffbeda8cc3362888357ec7173Steve Naroff  bool isUnionType() const;
345b06cf30badcddfea862bc9a538447453bdd94598Chris Lattner  bool isComplexIntegerType() const;            // GCC _Complex integer type.
346b06cf30badcddfea862bc9a538447453bdd94598Chris Lattner  bool isVectorType() const;                    // GCC vector type.
347af6ed504d90dc3b813c573bfbee8bc0e92e7fdc0Nate Begeman  bool isExtVectorType() const;                 // Extended vector type.
348b06cf30badcddfea862bc9a538447453bdd94598Chris Lattner  bool isObjCInterfaceType() const;             // NSString or NSString<foo>
349b06cf30badcddfea862bc9a538447453bdd94598Chris Lattner  bool isObjCQualifiedInterfaceType() const;    // NSString<foo>
350b06cf30badcddfea862bc9a538447453bdd94598Chris Lattner  bool isObjCQualifiedIdType() const;           // id<foo>
351e35a104a7d5caf8fa71117fbaa6f18cacc53c7a7Chris Lattner
352e35a104a7d5caf8fa71117fbaa6f18cacc53c7a7Chris Lattner  // Type Checking Functions: Check to see if this type is structurally the
35335fef52886c88e3855745917fcb0bf6a19fa0ba1Chris Lattner  // specified type, ignoring typedefs and qualifiers, and return a pointer to
35435fef52886c88e3855745917fcb0bf6a19fa0ba1Chris Lattner  // the best type we can.
355c33c060e2f4e7c7e89e3b809f52cfc6d55ea9838Steve Naroff  const BuiltinType *getAsBuiltinType() const;
356e35a104a7d5caf8fa71117fbaa6f18cacc53c7a7Chris Lattner  const FunctionType *getAsFunctionType() const;
357d5a56aae166344e13f1f8c845530beee0868db49Chris Lattner  const FunctionTypeProto *getAsFunctionTypeProto() const;
358cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner  const PointerLikeType *getAsPointerLikeType() const; // Pointer or Reference.
3597931f4a186bc76b21dd4629ee74d64264a7fb8a2Chris Lattner  const PointerType *getAsPointerType() const;
3607aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff  const BlockPointerType *getAsBlockPointerType() const;
361f0c4a0a830c9154b1ae72e497c2ce586c10e9b71Chris Lattner  const ReferenceType *getAsReferenceType() const;
362e35a104a7d5caf8fa71117fbaa6f18cacc53c7a7Chris Lattner  const RecordType *getAsRecordType() const;
3635c45be48e6125c5981ad48708dc7e8267bace63aTed Kremenek  const RecordType *getAsStructureType() const;
364a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner  /// NOTE: getAsArrayType* are methods on ASTContext.
3655c45be48e6125c5981ad48708dc7e8267bace63aTed Kremenek  const TypedefType *getAsTypedefType() const;
366e35a104a7d5caf8fa71117fbaa6f18cacc53c7a7Chris Lattner  const RecordType *getAsUnionType() const;
3670832dbca0e11ee020bbed181c515b3835158436eEli Friedman  const EnumType *getAsEnumType() const;
368e35a104a7d5caf8fa71117fbaa6f18cacc53c7a7Chris Lattner  const VectorType *getAsVectorType() const; // GCC vector type.
3697a85fa1ba94c9f4cf960463dd3eb444ef6f89446Chris Lattner  const ComplexType *getAsComplexType() const;
37036e35e652e28cbdffbeda8cc3362888357ec7173Steve Naroff  const ComplexType *getAsComplexIntegerType() const; // GCC complex int type.
371af6ed504d90dc3b813c573bfbee8bc0e92e7fdc0Nate Begeman  const ExtVectorType *getAsExtVectorType() const; // Extended vector type.
372b06cf30badcddfea862bc9a538447453bdd94598Chris Lattner  const ObjCInterfaceType *getAsObjCInterfaceType() const;
373b06cf30badcddfea862bc9a538447453bdd94598Chris Lattner  const ObjCQualifiedInterfaceType *getAsObjCQualifiedInterfaceType() const;
374b06cf30badcddfea862bc9a538447453bdd94598Chris Lattner  const ObjCQualifiedIdType *getAsObjCQualifiedIdType() const;
375a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner
376f914765ba1d70f599fa69bde38b8646c02d9b1aaChris Lattner  /// getAsPointerToObjCInterfaceType - If this is a pointer to an ObjC
377f914765ba1d70f599fa69bde38b8646c02d9b1aaChris Lattner  /// interface, return the interface type, otherwise return null.
378f914765ba1d70f599fa69bde38b8646c02d9b1aaChris Lattner  const ObjCInterfaceType *getAsPointerToObjCInterfaceType() const;
379f914765ba1d70f599fa69bde38b8646c02d9b1aaChris Lattner
380a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner  /// getArrayElementTypeNoTypeQual - If this is an array type, return the
381a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner  /// element type of the array, potentially with type qualifiers missing.
382a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner  /// This method should never be used when type qualifiers are meaningful.
383a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner  const Type *getArrayElementTypeNoTypeQual() const;
384a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner
385a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner
3864b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
3872afc72b0b6b3d2f44ca2576c98d307310d556983Chris Lattner  /// getDesugaredType - Return the specified type with any "sugar" removed from
3885c45be48e6125c5981ad48708dc7e8267bace63aTed Kremenek  /// the type.  This takes off typedefs, typeof's etc.  If the outer level of
3892afc72b0b6b3d2f44ca2576c98d307310d556983Chris Lattner  /// the type is already concrete, it returns it unmodified.  This is similar
3902afc72b0b6b3d2f44ca2576c98d307310d556983Chris Lattner  /// to getting the canonical type, but it doesn't remove *all* typedefs.  For
3912ea769b494649b5ca4864acf154f2fedc7718029Chris Lattner  /// example, it returns "T*" as "T*", (not as "int*"), because the pointer is
3922afc72b0b6b3d2f44ca2576c98d307310d556983Chris Lattner  /// concrete.
393a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner  QualType getDesugaredType() const;
3942afc72b0b6b3d2f44ca2576c98d307310d556983Chris Lattner
3954b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// More type predicates useful for type checking/promotion
3964b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  bool isPromotableIntegerType() const; // C99 6.3.1.1p2
3974b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
3984b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// isSignedIntegerType - Return true if this is an integer type that is
399bbe686be29157b575e53fbed328613117b525f26Chris Lattner  /// signed, according to C99 6.2.5p4 [char, signed char, short, int, long..],
400bbe686be29157b575e53fbed328613117b525f26Chris Lattner  /// an enum decl which has a signed representation, or a vector of signed
401bbe686be29157b575e53fbed328613117b525f26Chris Lattner  /// integer element type.
4024b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  bool isSignedIntegerType() const;
4034b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
4044b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// isUnsignedIntegerType - Return true if this is an integer type that is
405bbe686be29157b575e53fbed328613117b525f26Chris Lattner  /// unsigned, according to C99 6.2.5p6 [which returns true for _Bool], an enum
406bbe686be29157b575e53fbed328613117b525f26Chris Lattner  /// decl which has an unsigned representation, or a vector of unsigned integer
407bbe686be29157b575e53fbed328613117b525f26Chris Lattner  /// element type.
4084b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  bool isUnsignedIntegerType() const;
409bbe686be29157b575e53fbed328613117b525f26Chris Lattner
4104b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// isConstantSizeType - Return true if this is not a variable sized type,
4110448b4f2fecceebc0bddd67fe0f2c89afe604fdfChris Lattner  /// according to the rules of C99 6.7.5p3.  It is not legal to call this on
4120448b4f2fecceebc0bddd67fe0f2c89afe604fdfChris Lattner  /// incomplete types.
41362f67fd7f670f1a8b222c6565b257c05e8e80faeEli Friedman  bool isConstantSizeType() const;
414a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner
4154b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  QualType getCanonicalTypeInternal() const { return CanonicalType; }
416a55e321bd645398b514e246981c04a4889ee2472Chris Lattner  void dump() const;
4174b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  virtual void getAsStringInternal(std::string &InnerString) const = 0;
4184b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static bool classof(const Type *) { return true; }
419034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek
420034a78cafc3505323698ea72db19dc5095324e06Ted Kremenekprotected:
421034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek  /// Emit - Emit a Type to bitcode.  Used by ASTContext.
422034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek  void Emit(llvm::Serializer& S) const;
423034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek
424034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek  /// Create - Construct a Type from bitcode.  Used by ASTContext.
425034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek  static void Create(ASTContext& Context, unsigned i, llvm::Deserializer& S);
426034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek
427034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek  /// EmitImpl - Subclasses must implement this method in order to
428034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek  ///  be serialized.
4299c7fd1e1ad0ec0c483560c9a9daeda23c3772055Daniel Dunbar  // FIXME: Make this abstract once implemented.
4309c7fd1e1ad0ec0c483560c9a9daeda23c3772055Daniel Dunbar  virtual void EmitImpl(llvm::Serializer& S) const {
4319c7fd1e1ad0ec0c483560c9a9daeda23c3772055Daniel Dunbar    assert (false && "Serializization for type not supported.");
4329c7fd1e1ad0ec0c483560c9a9daeda23c3772055Daniel Dunbar  }
4334b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner};
4344b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
4352a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb/// ASQualType - TR18037 (C embedded extensions) 6.2.5p26
4362a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb/// This supports address space qualified types.
4372a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb///
4382a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lambclass ASQualType : public Type, public llvm::FoldingSetNode {
43935fef52886c88e3855745917fcb0bf6a19fa0ba1Chris Lattner  /// BaseType - This is the underlying type that this qualifies.  All CVR
44035fef52886c88e3855745917fcb0bf6a19fa0ba1Chris Lattner  /// qualifiers are stored on the QualType that references this type, so we
44135fef52886c88e3855745917fcb0bf6a19fa0ba1Chris Lattner  /// can't have any here.
44235fef52886c88e3855745917fcb0bf6a19fa0ba1Chris Lattner  Type *BaseType;
4432a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  /// Address Space ID - The address space ID this type is qualified with.
4442a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  unsigned AddressSpace;
44535fef52886c88e3855745917fcb0bf6a19fa0ba1Chris Lattner  ASQualType(Type *Base, QualType CanonicalPtr, unsigned AddrSpace) :
4462a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb    Type(ASQual, CanonicalPtr), BaseType(Base), AddressSpace(AddrSpace) {
4472a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  }
4482a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  friend class ASTContext;  // ASTContext creates these.
4492a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lambpublic:
45035fef52886c88e3855745917fcb0bf6a19fa0ba1Chris Lattner  Type *getBaseType() const { return BaseType; }
4512a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  unsigned getAddressSpace() const { return AddressSpace; }
4522a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb
4532a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  virtual void getAsStringInternal(std::string &InnerString) const;
4542a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb
4552a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  void Profile(llvm::FoldingSetNodeID &ID) {
4562a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb    Profile(ID, getBaseType(), AddressSpace);
4572a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  }
45835fef52886c88e3855745917fcb0bf6a19fa0ba1Chris Lattner  static void Profile(llvm::FoldingSetNodeID &ID, Type *Base,
4592a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb                      unsigned AddrSpace) {
46035fef52886c88e3855745917fcb0bf6a19fa0ba1Chris Lattner    ID.AddPointer(Base);
4612a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb    ID.AddInteger(AddrSpace);
4622a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  }
4632a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb
4642a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  static bool classof(const Type *T) { return T->getTypeClass() == ASQual; }
4652a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  static bool classof(const ASQualType *) { return true; }
4662a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb
4672a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lambprotected:
4682a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  virtual void EmitImpl(llvm::Serializer& S) const;
4692a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  static Type* CreateImpl(ASTContext& Context,llvm::Deserializer& D);
4702a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  friend class Type;
4712a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb};
4722a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb
4732a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb
4744b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// BuiltinType - This class is used for builtin types like 'int'.  Builtin
4754b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// types are always canonical and have a literal name field.
4764b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerclass BuiltinType : public Type {
4774b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerpublic:
4784b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  enum Kind {
4794b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    Void,
4804b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
4814b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    Bool,     // This is bool and/or _Bool.
4824b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    Char_U,   // This is 'char' for targets where char is unsigned.
4834b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    UChar,    // This is explicitly qualified unsigned char.
4844b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    UShort,
4854b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    UInt,
4864b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    ULong,
4874b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    ULongLong,
4884b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
4894b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    Char_S,   // This is 'char' for targets where char is signed.
4904b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    SChar,    // This is explicitly qualified signed char.
49185bd81edce4057156d7f49408147f07daa675096Argiris Kirtzidis    WChar,    // This is 'wchar_t' for C++.
4924b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    Short,
4934b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    Int,
4944b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    Long,
4954b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    LongLong,
4964b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
49785bd81edce4057156d7f49408147f07daa675096Argiris Kirtzidis    Float, Double, LongDouble
4984b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  };
4994b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerprivate:
5004b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  Kind TypeKind;
5014b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerpublic:
5024b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  BuiltinType(Kind K) : Type(Builtin, QualType()), TypeKind(K) {}
5034b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
5044b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  Kind getKind() const { return TypeKind; }
5054b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  const char *getName() const;
5064b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
5074b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  virtual void getAsStringInternal(std::string &InnerString) const;
5084b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
5094b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static bool classof(const Type *T) { return T->getTypeClass() == Builtin; }
5104b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static bool classof(const BuiltinType *) { return true; }
5114b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner};
5124b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
5134b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// ComplexType - C99 6.2.5p11 - Complex values.  This supports the C99 complex
5144b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// types (_Complex float etc) as well as the GCC integer complex extensions.
5154b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner///
5164b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerclass ComplexType : public Type, public llvm::FoldingSetNode {
5174b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  QualType ElementType;
5184b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  ComplexType(QualType Element, QualType CanonicalPtr) :
5194b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    Type(Complex, CanonicalPtr), ElementType(Element) {
5204b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
5214b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  friend class ASTContext;  // ASTContext creates these.
5224b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerpublic:
5234b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  QualType getElementType() const { return ElementType; }
5244b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
5254b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  virtual void getAsStringInternal(std::string &InnerString) const;
526034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek
5274b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  void Profile(llvm::FoldingSetNodeID &ID) {
5284b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    Profile(ID, getElementType());
5294b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
5304b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static void Profile(llvm::FoldingSetNodeID &ID, QualType Element) {
5314b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    ID.AddPointer(Element.getAsOpaquePtr());
5324b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
5334b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
5344b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static bool classof(const Type *T) { return T->getTypeClass() == Complex; }
5354b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static bool classof(const ComplexType *) { return true; }
53678f138f44886abc5ab7fc1551d501308f1846d80Ted Kremenek
537034a78cafc3505323698ea72db19dc5095324e06Ted Kremenekprotected:
538034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek  virtual void EmitImpl(llvm::Serializer& S) const;
539034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek  static Type* CreateImpl(ASTContext& Context,llvm::Deserializer& D);
540034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek  friend class Type;
5414b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner};
5424b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
543cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner/// PointerLikeType - Common base class for pointers and references.
5444fea7b688be1fd4fd3fd34ed70127c78904eaa91Steve Naroff/// FIXME: Add more documentation on this classes design point. For example,
5454fea7b688be1fd4fd3fd34ed70127c78904eaa91Steve Naroff/// should BlockPointerType inherit from it? Is the concept of a PointerLikeType
5464fea7b688be1fd4fd3fd34ed70127c78904eaa91Steve Naroff/// in the C++ standard?
547cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner///
548cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattnerclass PointerLikeType : public Type {
549cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner  QualType PointeeType;
550cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattnerprotected:
551cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner  PointerLikeType(TypeClass K, QualType Pointee, QualType CanonicalPtr) :
552cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner    Type(K, CanonicalPtr), PointeeType(Pointee) {
553cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner  }
554cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattnerpublic:
555cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner
556cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner  QualType getPointeeType() const { return PointeeType; }
557cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner
558cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner  static bool classof(const Type *T) {
559cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner    return T->getTypeClass() == Pointer || T->getTypeClass() == Reference;
560cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner  }
561cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner  static bool classof(const PointerLikeType *) { return true; }
562cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner};
5634b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
5644b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// PointerType - C99 6.7.5.1 - Pointer Declarators.
5654b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner///
566cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattnerclass PointerType : public PointerLikeType, public llvm::FoldingSetNode {
5674b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  PointerType(QualType Pointee, QualType CanonicalPtr) :
568cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner    PointerLikeType(Pointer, Pointee, CanonicalPtr) {
5694b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
5704b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  friend class ASTContext;  // ASTContext creates these.
5714b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerpublic:
5724b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
5734b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  virtual void getAsStringInternal(std::string &InnerString) const;
5744b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
5754b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  void Profile(llvm::FoldingSetNodeID &ID) {
5764b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    Profile(ID, getPointeeType());
5774b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
5784b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static void Profile(llvm::FoldingSetNodeID &ID, QualType Pointee) {
5794b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    ID.AddPointer(Pointee.getAsOpaquePtr());
5804b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
5814b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
5824b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static bool classof(const Type *T) { return T->getTypeClass() == Pointer; }
5834b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static bool classof(const PointerType *) { return true; }
584034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek
585034a78cafc3505323698ea72db19dc5095324e06Ted Kremenekprotected:
586034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek  virtual void EmitImpl(llvm::Serializer& S) const;
587034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek  static Type* CreateImpl(ASTContext& Context,llvm::Deserializer& D);
588034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek  friend class Type;
5894b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner};
5904b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
5917aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff/// BlockPointerType - pointer to a block type.
5927aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff/// This type is to represent types syntactically represented as
5937aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff/// "void (^)(int)", etc. Pointee is required to always be a function type.
5944fea7b688be1fd4fd3fd34ed70127c78904eaa91Steve Naroff/// FIXME: Should BlockPointerType inherit from PointerLikeType? It could
5954fea7b688be1fd4fd3fd34ed70127c78904eaa91Steve Naroff/// simplfy some type checking code, however PointerLikeType doesn't appear
5964fea7b688be1fd4fd3fd34ed70127c78904eaa91Steve Naroff/// to be used by the type checker.
5977aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff///
5987aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroffclass BlockPointerType : public Type, public llvm::FoldingSetNode {
5997aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff  QualType PointeeType;  // Block is some kind of pointer type
6007aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff  BlockPointerType(QualType Pointee, QualType CanonicalCls) :
6017aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff    Type(BlockPointer, CanonicalCls), PointeeType(Pointee) {
6027aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff  }
6037aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff  friend class ASTContext;  // ASTContext creates these.
6047aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroffpublic:
6057aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff
6067aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff  // Get the pointee type. Pointee is required to always be a function type.
6077aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff  QualType getPointeeType() const { return PointeeType; }
6087aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff
6097aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff  virtual void getAsStringInternal(std::string &InnerString) const;
6107aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff
6117aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff  void Profile(llvm::FoldingSetNodeID &ID) {
6127aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff      Profile(ID, getPointeeType());
6137aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff  }
6147aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff  static void Profile(llvm::FoldingSetNodeID &ID, QualType Pointee) {
6157aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff      ID.AddPointer(Pointee.getAsOpaquePtr());
6167aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff  }
6177aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff
6187aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff  static bool classof(const Type *T) {
6197aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff    return T->getTypeClass() == BlockPointer;
6207aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff  }
6217aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff  static bool classof(const BlockPointerType *) { return true; }
6227aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff
6237aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff  protected:
6247aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff    virtual void EmitImpl(llvm::Serializer& S) const;
6257aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff    static Type* CreateImpl(ASTContext& Context,llvm::Deserializer& D);
6267aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff    friend class Type;
6277aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff};
6287aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff
6294b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// ReferenceType - C++ 8.3.2 - Reference Declarators.
6304b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner///
631cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattnerclass ReferenceType : public PointerLikeType, public llvm::FoldingSetNode {
6324b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  ReferenceType(QualType Referencee, QualType CanonicalRef) :
633cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner    PointerLikeType(Reference, Referencee, CanonicalRef) {
6344b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
6354b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  friend class ASTContext;  // ASTContext creates these.
6364b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerpublic:
6374b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  virtual void getAsStringInternal(std::string &InnerString) const;
6384b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
6394b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  void Profile(llvm::FoldingSetNodeID &ID) {
640cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner    Profile(ID, getPointeeType());
6414b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
6424b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static void Profile(llvm::FoldingSetNodeID &ID, QualType Referencee) {
6434b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    ID.AddPointer(Referencee.getAsOpaquePtr());
6444b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
6454b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
6464b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static bool classof(const Type *T) { return T->getTypeClass() == Reference; }
6474b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static bool classof(const ReferenceType *) { return true; }
6484b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner};
6494b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
6504b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// ArrayType - C99 6.7.5.2 - Array Declarators.
6514b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner///
652c8253192b917a5684717c58f4032e0891d089b00Ted Kremenekclass ArrayType : public Type, public llvm::FoldingSetNode {
6534b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerpublic:
6544b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// ArraySizeModifier - Capture whether this is a normal array (e.g. int X[4])
6554b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// an array with a static size (e.g. int X[static 4]), or with a star size
65624c9b98cc6a8de4a080e2dedb2797bdc2eeb688bSteve Naroff  /// (e.g. int X[*]). 'static' is only allowed on function parameters.
6574b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  enum ArraySizeModifier {
6584b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    Normal, Static, Star
6594b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  };
6604b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerprivate:
66183c13010359c33354c581acee65d0c986a75247eSteve Naroff  /// ElementType - The element type of the array.
66283c13010359c33354c581acee65d0c986a75247eSteve Naroff  QualType ElementType;
66324c9b98cc6a8de4a080e2dedb2797bdc2eeb688bSteve Naroff
664dbd96b23eae3784172d91cfb086abb8ca732f92eTed Kremenek  // NOTE: VC++ treats enums as signed, avoid using the ArraySizeModifier enum
66524c9b98cc6a8de4a080e2dedb2797bdc2eeb688bSteve Naroff  /// NOTE: These fields are packed into the bitfields space in the Type class.
666dbd96b23eae3784172d91cfb086abb8ca732f92eTed Kremenek  unsigned SizeModifier : 2;
66724c9b98cc6a8de4a080e2dedb2797bdc2eeb688bSteve Naroff
66824c9b98cc6a8de4a080e2dedb2797bdc2eeb688bSteve Naroff  /// IndexTypeQuals - Capture qualifiers in declarations like:
66924c9b98cc6a8de4a080e2dedb2797bdc2eeb688bSteve Naroff  /// 'int X[static restrict 4]'. For function parameters only.
67024c9b98cc6a8de4a080e2dedb2797bdc2eeb688bSteve Naroff  unsigned IndexTypeQuals : 3;
67124c9b98cc6a8de4a080e2dedb2797bdc2eeb688bSteve Naroff
67283c13010359c33354c581acee65d0c986a75247eSteve Naroffprotected:
67324c9b98cc6a8de4a080e2dedb2797bdc2eeb688bSteve Naroff  ArrayType(TypeClass tc, QualType et, QualType can,
67424c9b98cc6a8de4a080e2dedb2797bdc2eeb688bSteve Naroff            ArraySizeModifier sm, unsigned tq)
67524c9b98cc6a8de4a080e2dedb2797bdc2eeb688bSteve Naroff    : Type(tc, can), ElementType(et), SizeModifier(sm), IndexTypeQuals(tq) {}
67683c13010359c33354c581acee65d0c986a75247eSteve Naroff  friend class ASTContext;  // ASTContext creates these.
67783c13010359c33354c581acee65d0c986a75247eSteve Naroffpublic:
67883c13010359c33354c581acee65d0c986a75247eSteve Naroff  QualType getElementType() const { return ElementType; }
679dbd96b23eae3784172d91cfb086abb8ca732f92eTed Kremenek  ArraySizeModifier getSizeModifier() const {
680dbd96b23eae3784172d91cfb086abb8ca732f92eTed Kremenek    return ArraySizeModifier(SizeModifier);
681dbd96b23eae3784172d91cfb086abb8ca732f92eTed Kremenek  }
68224c9b98cc6a8de4a080e2dedb2797bdc2eeb688bSteve Naroff  unsigned getIndexTypeQualifier() const { return IndexTypeQuals; }
68383c13010359c33354c581acee65d0c986a75247eSteve Naroff
68483c13010359c33354c581acee65d0c986a75247eSteve Naroff  static bool classof(const Type *T) {
68583c13010359c33354c581acee65d0c986a75247eSteve Naroff    return T->getTypeClass() == ConstantArray ||
6868ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman           T->getTypeClass() == VariableArray ||
6878ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman           T->getTypeClass() == IncompleteArray;
68883c13010359c33354c581acee65d0c986a75247eSteve Naroff  }
68983c13010359c33354c581acee65d0c986a75247eSteve Naroff  static bool classof(const ArrayType *) { return true; }
69083c13010359c33354c581acee65d0c986a75247eSteve Naroff};
69183c13010359c33354c581acee65d0c986a75247eSteve Naroff
69256846f2ed2594f49d78eee3645482a5e77d5e236Chris Lattner/// ConstantArrayType - This class represents C arrays with a specified constant
69356846f2ed2594f49d78eee3645482a5e77d5e236Chris Lattner/// size.  For example 'int A[100]' has ConstantArrayType where the element type
69456846f2ed2594f49d78eee3645482a5e77d5e236Chris Lattner/// is 'int' and the size is 100.
695c8253192b917a5684717c58f4032e0891d089b00Ted Kremenekclass ConstantArrayType : public ArrayType {
69683c13010359c33354c581acee65d0c986a75247eSteve Naroff  llvm::APInt Size; // Allows us to unique the type.
69783c13010359c33354c581acee65d0c986a75247eSteve Naroff
69824c9b98cc6a8de4a080e2dedb2797bdc2eeb688bSteve Naroff  ConstantArrayType(QualType et, QualType can, llvm::APInt sz,
69924c9b98cc6a8de4a080e2dedb2797bdc2eeb688bSteve Naroff                    ArraySizeModifier sm, unsigned tq)
70024c9b98cc6a8de4a080e2dedb2797bdc2eeb688bSteve Naroff    : ArrayType(ConstantArray, et, can, sm, tq), Size(sz) {}
70183c13010359c33354c581acee65d0c986a75247eSteve Naroff  friend class ASTContext;  // ASTContext creates these.
70283c13010359c33354c581acee65d0c986a75247eSteve Naroffpublic:
703a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner  const llvm::APInt &getSize() const { return Size; }
70483c13010359c33354c581acee65d0c986a75247eSteve Naroff  virtual void getAsStringInternal(std::string &InnerString) const;
70583c13010359c33354c581acee65d0c986a75247eSteve Naroff
70683c13010359c33354c581acee65d0c986a75247eSteve Naroff  void Profile(llvm::FoldingSetNodeID &ID) {
70783c13010359c33354c581acee65d0c986a75247eSteve Naroff    Profile(ID, getElementType(), getSize());
70883c13010359c33354c581acee65d0c986a75247eSteve Naroff  }
70983c13010359c33354c581acee65d0c986a75247eSteve Naroff  static void Profile(llvm::FoldingSetNodeID &ID, QualType ET,
71083c13010359c33354c581acee65d0c986a75247eSteve Naroff                      llvm::APInt ArraySize) {
71183c13010359c33354c581acee65d0c986a75247eSteve Naroff    ID.AddPointer(ET.getAsOpaquePtr());
71283c13010359c33354c581acee65d0c986a75247eSteve Naroff    ID.AddInteger(ArraySize.getZExtValue());
71383c13010359c33354c581acee65d0c986a75247eSteve Naroff  }
71483c13010359c33354c581acee65d0c986a75247eSteve Naroff  static bool classof(const Type *T) {
71583c13010359c33354c581acee65d0c986a75247eSteve Naroff    return T->getTypeClass() == ConstantArray;
71683c13010359c33354c581acee65d0c986a75247eSteve Naroff  }
71783c13010359c33354c581acee65d0c986a75247eSteve Naroff  static bool classof(const ConstantArrayType *) { return true; }
7184234c1b1a9c858b005f4ad7dc85908b63adcafddTed Kremenek
7194234c1b1a9c858b005f4ad7dc85908b63adcafddTed Kremenekprotected:
7204234c1b1a9c858b005f4ad7dc85908b63adcafddTed Kremenek  virtual void EmitImpl(llvm::Serializer& S) const;
7214234c1b1a9c858b005f4ad7dc85908b63adcafddTed Kremenek  static Type* CreateImpl(ASTContext& Context, llvm::Deserializer& D);
7224234c1b1a9c858b005f4ad7dc85908b63adcafddTed Kremenek  friend class Type;
72383c13010359c33354c581acee65d0c986a75247eSteve Naroff};
72483c13010359c33354c581acee65d0c986a75247eSteve Naroff
72556846f2ed2594f49d78eee3645482a5e77d5e236Chris Lattner/// IncompleteArrayType - This class represents C arrays with an unspecified
72656846f2ed2594f49d78eee3645482a5e77d5e236Chris Lattner/// size.  For example 'int A[]' has an IncompleteArrayType where the element
72756846f2ed2594f49d78eee3645482a5e77d5e236Chris Lattner/// type is 'int' and the size is unspecified.
7288ff077864feed2c2b75424d37724f60e56d5a597Eli Friedmanclass IncompleteArrayType : public ArrayType {
7298ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman  IncompleteArrayType(QualType et, QualType can,
7308ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman                    ArraySizeModifier sm, unsigned tq)
7318ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman    : ArrayType(IncompleteArray, et, can, sm, tq) {}
7328ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman  friend class ASTContext;  // ASTContext creates these.
7338ff077864feed2c2b75424d37724f60e56d5a597Eli Friedmanpublic:
7348ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman
7358ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman  virtual void getAsStringInternal(std::string &InnerString) const;
7368ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman
7378ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman  static bool classof(const Type *T) {
7388ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman    return T->getTypeClass() == IncompleteArray;
7398ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman  }
7408ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman  static bool classof(const IncompleteArrayType *) { return true; }
7418ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman
7428ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman  friend class StmtIteratorBase;
7438ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman
7448ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman  void Profile(llvm::FoldingSetNodeID &ID) {
7458ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman    Profile(ID, getElementType());
7468ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman  }
7478ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman
7488ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman  static void Profile(llvm::FoldingSetNodeID &ID, QualType ET) {
7498ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman    ID.AddPointer(ET.getAsOpaquePtr());
7508ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman  }
7518ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman
7528ff077864feed2c2b75424d37724f60e56d5a597Eli Friedmanprotected:
7538ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman  virtual void EmitImpl(llvm::Serializer& S) const;
7548ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman  static Type* CreateImpl(ASTContext& Context,llvm::Deserializer& D);
7558ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman  friend class Type;
7568ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman};
7578ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman
75856846f2ed2594f49d78eee3645482a5e77d5e236Chris Lattner/// VariableArrayType - This class represents C arrays with a specified size
75956846f2ed2594f49d78eee3645482a5e77d5e236Chris Lattner/// which is not an integer-constant-expression.  For example, 'int s[x+foo()]'.
76056846f2ed2594f49d78eee3645482a5e77d5e236Chris Lattner/// Since the size expression is an arbitrary expression, we store it as such.
76156846f2ed2594f49d78eee3645482a5e77d5e236Chris Lattner///
76256846f2ed2594f49d78eee3645482a5e77d5e236Chris Lattner/// Note: VariableArrayType's aren't uniqued (since the expressions aren't) and
76356846f2ed2594f49d78eee3645482a5e77d5e236Chris Lattner/// should not be: two lexically equivalent variable array types could mean
76456846f2ed2594f49d78eee3645482a5e77d5e236Chris Lattner/// different things, for example, these variables do not have the same type
76556846f2ed2594f49d78eee3645482a5e77d5e236Chris Lattner/// dynamically:
76656846f2ed2594f49d78eee3645482a5e77d5e236Chris Lattner///
76756846f2ed2594f49d78eee3645482a5e77d5e236Chris Lattner/// void foo(int x) {
76856846f2ed2594f49d78eee3645482a5e77d5e236Chris Lattner///   int Y[x];
76956846f2ed2594f49d78eee3645482a5e77d5e236Chris Lattner///   ++x;
77056846f2ed2594f49d78eee3645482a5e77d5e236Chris Lattner///   int Z[x];
77156846f2ed2594f49d78eee3645482a5e77d5e236Chris Lattner/// }
77256846f2ed2594f49d78eee3645482a5e77d5e236Chris Lattner///
773c8253192b917a5684717c58f4032e0891d089b00Ted Kremenekclass VariableArrayType : public ArrayType {
77483c13010359c33354c581acee65d0c986a75247eSteve Naroff  /// SizeExpr - An assignment expression. VLA's are only permitted within
77583c13010359c33354c581acee65d0c986a75247eSteve Naroff  /// a function block.
776718b6638e0d259d1b8371ef30e475e9c2e981ffcTed Kremenek  Stmt *SizeExpr;
7774b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
77824c9b98cc6a8de4a080e2dedb2797bdc2eeb688bSteve Naroff  VariableArrayType(QualType et, QualType can, Expr *e,
77924c9b98cc6a8de4a080e2dedb2797bdc2eeb688bSteve Naroff                    ArraySizeModifier sm, unsigned tq)
780718b6638e0d259d1b8371ef30e475e9c2e981ffcTed Kremenek    : ArrayType(VariableArray, et, can, sm, tq), SizeExpr((Stmt*) e) {}
7814b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  friend class ASTContext;  // ASTContext creates these.
782db4d5970d9243fb699f250f74eab6b7cce901a40Ted Kremenek  virtual void Destroy(ASTContext& C);
783db4d5970d9243fb699f250f74eab6b7cce901a40Ted Kremenek
7844b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerpublic:
785a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner  Expr *getSizeExpr() const {
786718b6638e0d259d1b8371ef30e475e9c2e981ffcTed Kremenek    // We use C-style casts instead of cast<> here because we do not wish
787718b6638e0d259d1b8371ef30e475e9c2e981ffcTed Kremenek    // to have a dependency of Type.h on Stmt.h/Expr.h.
788718b6638e0d259d1b8371ef30e475e9c2e981ffcTed Kremenek    return (Expr*) SizeExpr;
789718b6638e0d259d1b8371ef30e475e9c2e981ffcTed Kremenek  }
7904b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
7914b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  virtual void getAsStringInternal(std::string &InnerString) const;
7924b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
79383c13010359c33354c581acee65d0c986a75247eSteve Naroff  static bool classof(const Type *T) {
79483c13010359c33354c581acee65d0c986a75247eSteve Naroff    return T->getTypeClass() == VariableArray;
7954b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
79683c13010359c33354c581acee65d0c986a75247eSteve Naroff  static bool classof(const VariableArrayType *) { return true; }
79727a32d6f18844a97446d6e2002bf181da591332aTed Kremenek
798fce813e3159a67a57a03cdca45ac4e10d4cffac3Ted Kremenek  friend class StmtIteratorBase;
7993793e1ab25169c0d5be43f3abe2b4dc92989c043Ted Kremenek
8003793e1ab25169c0d5be43f3abe2b4dc92989c043Ted Kremenek  void Profile(llvm::FoldingSetNodeID &ID) {
8018ff077864feed2c2b75424d37724f60e56d5a597Eli Friedman    assert (0 && "Cannnot unique VariableArrayTypes.");
8023793e1ab25169c0d5be43f3abe2b4dc92989c043Ted Kremenek  }
8035cde3834f43c0946ec8debfda9c6fb588b6b33fdTed Kremenek
8045cde3834f43c0946ec8debfda9c6fb588b6b33fdTed Kremenekprotected:
8055cde3834f43c0946ec8debfda9c6fb588b6b33fdTed Kremenek  virtual void EmitImpl(llvm::Serializer& S) const;
8065cde3834f43c0946ec8debfda9c6fb588b6b33fdTed Kremenek  static Type* CreateImpl(ASTContext& Context,llvm::Deserializer& D);
8075cde3834f43c0946ec8debfda9c6fb588b6b33fdTed Kremenek  friend class Type;
8084b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner};
8094b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
8104b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// VectorType - GCC generic vector type. This type is created using
8114b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// __attribute__((vector_size(n)), where "n" specifies the vector size in
8124b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// bytes. Since the constructor takes the number of vector elements, the
8134b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// client is responsible for converting the size into the number of elements.
8144b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerclass VectorType : public Type, public llvm::FoldingSetNode {
8154b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerprotected:
8164b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// ElementType - The element type of the vector.
8174b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  QualType ElementType;
8184b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
8194b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// NumElements - The number of elements in the vector.
8204b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  unsigned NumElements;
8214b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
8224b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  VectorType(QualType vecType, unsigned nElements, QualType canonType) :
8234b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    Type(Vector, canonType), ElementType(vecType), NumElements(nElements) {}
8244b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  VectorType(TypeClass tc, QualType vecType, unsigned nElements,
8254b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    QualType canonType) : Type(tc, canonType), ElementType(vecType),
8264b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    NumElements(nElements) {}
8274b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  friend class ASTContext;  // ASTContext creates these.
8284b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerpublic:
8294b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
8304b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  QualType getElementType() const { return ElementType; }
8314b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  unsigned getNumElements() const { return NumElements; }
8324b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
8334b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  virtual void getAsStringInternal(std::string &InnerString) const;
8344b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
8354b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  void Profile(llvm::FoldingSetNodeID &ID) {
8364b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    Profile(ID, getElementType(), getNumElements(), getTypeClass());
8374b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
8384b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static void Profile(llvm::FoldingSetNodeID &ID, QualType ElementType,
8394b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner                      unsigned NumElements, TypeClass TypeClass) {
8404b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    ID.AddPointer(ElementType.getAsOpaquePtr());
8414b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    ID.AddInteger(NumElements);
8424b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    ID.AddInteger(TypeClass);
8434b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
8444b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static bool classof(const Type *T) {
845af6ed504d90dc3b813c573bfbee8bc0e92e7fdc0Nate Begeman    return T->getTypeClass() == Vector || T->getTypeClass() == ExtVector;
8464b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
8474b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static bool classof(const VectorType *) { return true; }
8484b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner};
8494b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
850af6ed504d90dc3b813c573bfbee8bc0e92e7fdc0Nate Begeman/// ExtVectorType - Extended vector type. This type is created using
851af6ed504d90dc3b813c573bfbee8bc0e92e7fdc0Nate Begeman/// __attribute__((ext_vector_type(n)), where "n" is the number of elements.
852af6ed504d90dc3b813c573bfbee8bc0e92e7fdc0Nate Begeman/// Unlike vector_size, ext_vector_type is only allowed on typedef's. This
8536154214e20225a883a8a00226499534e9b514315Steve Naroff/// class enables syntactic extensions, like Vector Components for accessing
8546154214e20225a883a8a00226499534e9b514315Steve Naroff/// points, colors, and textures (modeled after OpenGL Shading Language).
855af6ed504d90dc3b813c573bfbee8bc0e92e7fdc0Nate Begemanclass ExtVectorType : public VectorType {
856af6ed504d90dc3b813c573bfbee8bc0e92e7fdc0Nate Begeman  ExtVectorType(QualType vecType, unsigned nElements, QualType canonType) :
857af6ed504d90dc3b813c573bfbee8bc0e92e7fdc0Nate Begeman    VectorType(ExtVector, vecType, nElements, canonType) {}
8584b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  friend class ASTContext;  // ASTContext creates these.
8594b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerpublic:
8609096b795541c783297fb19684a58c54d0fe823b8Chris Lattner  static int getPointAccessorIdx(char c) {
8619096b795541c783297fb19684a58c54d0fe823b8Chris Lattner    switch (c) {
8629096b795541c783297fb19684a58c54d0fe823b8Chris Lattner    default: return -1;
8639096b795541c783297fb19684a58c54d0fe823b8Chris Lattner    case 'x': return 0;
8649096b795541c783297fb19684a58c54d0fe823b8Chris Lattner    case 'y': return 1;
8659096b795541c783297fb19684a58c54d0fe823b8Chris Lattner    case 'z': return 2;
8669096b795541c783297fb19684a58c54d0fe823b8Chris Lattner    case 'w': return 3;
8679096b795541c783297fb19684a58c54d0fe823b8Chris Lattner    }
8681b8a46c945927340ae7e79b771e93e7d36da4851Steve Naroff  }
8699096b795541c783297fb19684a58c54d0fe823b8Chris Lattner  static int getColorAccessorIdx(char c) {
8709096b795541c783297fb19684a58c54d0fe823b8Chris Lattner    switch (c) {
8719096b795541c783297fb19684a58c54d0fe823b8Chris Lattner    default: return -1;
8729096b795541c783297fb19684a58c54d0fe823b8Chris Lattner    case 'r': return 0;
8739096b795541c783297fb19684a58c54d0fe823b8Chris Lattner    case 'g': return 1;
8749096b795541c783297fb19684a58c54d0fe823b8Chris Lattner    case 'b': return 2;
8759096b795541c783297fb19684a58c54d0fe823b8Chris Lattner    case 'a': return 3;
8769096b795541c783297fb19684a58c54d0fe823b8Chris Lattner    }
8771b8a46c945927340ae7e79b771e93e7d36da4851Steve Naroff  }
8789096b795541c783297fb19684a58c54d0fe823b8Chris Lattner  static int getTextureAccessorIdx(char c) {
8799096b795541c783297fb19684a58c54d0fe823b8Chris Lattner    switch (c) {
8809096b795541c783297fb19684a58c54d0fe823b8Chris Lattner    default: return -1;
8819096b795541c783297fb19684a58c54d0fe823b8Chris Lattner    case 's': return 0;
8829096b795541c783297fb19684a58c54d0fe823b8Chris Lattner    case 't': return 1;
8839096b795541c783297fb19684a58c54d0fe823b8Chris Lattner    case 'p': return 2;
8849096b795541c783297fb19684a58c54d0fe823b8Chris Lattner    case 'q': return 3;
8851b8a46c945927340ae7e79b771e93e7d36da4851Steve Naroff    }
8869096b795541c783297fb19684a58c54d0fe823b8Chris Lattner  };
88742158e7b3a95f41d3482f1fb3a67392dbbf745daChris Lattner
88842158e7b3a95f41d3482f1fb3a67392dbbf745daChris Lattner  static int getAccessorIdx(char c) {
88942158e7b3a95f41d3482f1fb3a67392dbbf745daChris Lattner    if (int idx = getPointAccessorIdx(c)+1) return idx-1;
89042158e7b3a95f41d3482f1fb3a67392dbbf745daChris Lattner    if (int idx = getColorAccessorIdx(c)+1) return idx-1;
89142158e7b3a95f41d3482f1fb3a67392dbbf745daChris Lattner    return getTextureAccessorIdx(c);
89242158e7b3a95f41d3482f1fb3a67392dbbf745daChris Lattner  }
89342158e7b3a95f41d3482f1fb3a67392dbbf745daChris Lattner
8949096b795541c783297fb19684a58c54d0fe823b8Chris Lattner  bool isAccessorWithinNumElements(char c) const {
89542158e7b3a95f41d3482f1fb3a67392dbbf745daChris Lattner    if (int idx = getAccessorIdx(c)+1)
8969096b795541c783297fb19684a58c54d0fe823b8Chris Lattner      return unsigned(idx-1) < NumElements;
8979096b795541c783297fb19684a58c54d0fe823b8Chris Lattner    return false;
8981b8a46c945927340ae7e79b771e93e7d36da4851Steve Naroff  }
899c11705f9b742b542724dd56796bf90e07191e342Steve Naroff  virtual void getAsStringInternal(std::string &InnerString) const;
900c11705f9b742b542724dd56796bf90e07191e342Steve Naroff
901806b319509d01bffe47317f11140c930da800dbbSteve Naroff  static bool classof(const Type *T) {
902af6ed504d90dc3b813c573bfbee8bc0e92e7fdc0Nate Begeman    return T->getTypeClass() == ExtVector;
9034b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
904af6ed504d90dc3b813c573bfbee8bc0e92e7fdc0Nate Begeman  static bool classof(const ExtVectorType *) { return true; }
9054b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner};
9064b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
9074b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// FunctionType - C99 6.7.5.3 - Function Declarators.  This is the common base
9084b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// class of FunctionTypeNoProto and FunctionTypeProto.
9094b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner///
9104b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerclass FunctionType : public Type {
9114b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// SubClassData - This field is owned by the subclass, put here to pack
9124b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// tightly with the ivars in Type.
9134b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  bool SubClassData : 1;
9144b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
9154b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  // The type returned by the function.
9164b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  QualType ResultType;
9174b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerprotected:
9184b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  FunctionType(TypeClass tc, QualType res, bool SubclassInfo,QualType Canonical)
9194b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    : Type(tc, Canonical), SubClassData(SubclassInfo), ResultType(res) {}
9204b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  bool getSubClassData() const { return SubClassData; }
9214b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerpublic:
9224b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
9234b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  QualType getResultType() const { return ResultType; }
9244b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
9254b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
9264b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static bool classof(const Type *T) {
9274b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    return T->getTypeClass() == FunctionNoProto ||
9284b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner           T->getTypeClass() == FunctionProto;
9294b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
9304b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static bool classof(const FunctionType *) { return true; }
9314b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner};
9324b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
9334b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// FunctionTypeNoProto - Represents a K&R-style 'int foo()' function, which has
9344b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// no information available about its arguments.
9354b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerclass FunctionTypeNoProto : public FunctionType, public llvm::FoldingSetNode {
9364b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  FunctionTypeNoProto(QualType Result, QualType Canonical)
9374b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    : FunctionType(FunctionNoProto, Result, false, Canonical) {}
9384b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  friend class ASTContext;  // ASTContext creates these.
9394b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerpublic:
9404b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  // No additional state past what FunctionType provides.
9414b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
9424b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  virtual void getAsStringInternal(std::string &InnerString) const;
9434b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
9444b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  void Profile(llvm::FoldingSetNodeID &ID) {
9454b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    Profile(ID, getResultType());
9464b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
9474b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static void Profile(llvm::FoldingSetNodeID &ID, QualType ResultType) {
9484b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    ID.AddPointer(ResultType.getAsOpaquePtr());
9494b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
9504b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
9514b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static bool classof(const Type *T) {
9524b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    return T->getTypeClass() == FunctionNoProto;
9534b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
9544b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static bool classof(const FunctionTypeNoProto *) { return true; }
95587f0429f888ee5d332304641611b88f7b54b5065Ted Kremenek
95687f0429f888ee5d332304641611b88f7b54b5065Ted Kremenekprotected:
95787f0429f888ee5d332304641611b88f7b54b5065Ted Kremenek  virtual void EmitImpl(llvm::Serializer& S) const;
95887f0429f888ee5d332304641611b88f7b54b5065Ted Kremenek  static Type* CreateImpl(ASTContext& Context,llvm::Deserializer& D);
95987f0429f888ee5d332304641611b88f7b54b5065Ted Kremenek  friend class Type;
9604b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner};
9614b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
9624b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// FunctionTypeProto - Represents a prototype with argument type info, e.g.
9634b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// 'int foo(int)' or 'int foo(void)'.  'void' is represented as having no
9644b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner/// arguments, not as having a single void argument.
9654b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerclass FunctionTypeProto : public FunctionType, public llvm::FoldingSetNode {
96636104c1a2a18f1f78eba031e3a7a76d40416c4a7Eli Friedman  FunctionTypeProto(QualType Result, const QualType *ArgArray, unsigned numArgs,
9674b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner                    bool isVariadic, QualType Canonical)
9684b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    : FunctionType(FunctionProto, Result, isVariadic, Canonical),
9694b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner      NumArgs(numArgs) {
9704b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    // Fill in the trailing argument array.
9714b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    QualType *ArgInfo = reinterpret_cast<QualType *>(this+1);;
9724b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    for (unsigned i = 0; i != numArgs; ++i)
9734b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner      ArgInfo[i] = ArgArray[i];
9744b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
9754b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
9764b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// NumArgs - The number of arguments this function has, not counting '...'.
9774b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  unsigned NumArgs;
9784b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
9794b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// ArgInfo - There is an variable size array after the class in memory that
9804b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// holds the argument types.
981db4d5970d9243fb699f250f74eab6b7cce901a40Ted Kremenek
9824b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  friend class ASTContext;  // ASTContext creates these.
983db4d5970d9243fb699f250f74eab6b7cce901a40Ted Kremenek  virtual void Destroy(ASTContext& C);
984db4d5970d9243fb699f250f74eab6b7cce901a40Ted Kremenek
9854b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerpublic:
9864b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  unsigned getNumArgs() const { return NumArgs; }
9874b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  QualType getArgType(unsigned i) const {
9884b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    assert(i < NumArgs && "Invalid argument number!");
9894b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    return arg_type_begin()[i];
9904b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
9914b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
9924b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  bool isVariadic() const { return getSubClassData(); }
9934b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
9944b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  typedef const QualType *arg_type_iterator;
9954b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  arg_type_iterator arg_type_begin() const {
9964b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    return reinterpret_cast<const QualType *>(this+1);
9974b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
9984b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  arg_type_iterator arg_type_end() const { return arg_type_begin()+NumArgs; }
9994b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
10004b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  virtual void getAsStringInternal(std::string &InnerString) const;
10014b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
10024b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static bool classof(const Type *T) {
10034b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    return T->getTypeClass() == FunctionProto;
10044b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
10054b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static bool classof(const FunctionTypeProto *) { return true; }
10064b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
10074b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  void Profile(llvm::FoldingSetNodeID &ID);
10084b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static void Profile(llvm::FoldingSetNodeID &ID, QualType Result,
10094b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner                      arg_type_iterator ArgTys, unsigned NumArgs,
10104b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner                      bool isVariadic);
1011034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek
1012034a78cafc3505323698ea72db19dc5095324e06Ted Kremenekprotected:
1013034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek  virtual void EmitImpl(llvm::Serializer& S) const;
1014034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek  static Type* CreateImpl(ASTContext& Context,llvm::Deserializer& D);
1015034a78cafc3505323698ea72db19dc5095324e06Ted Kremenek  friend class Type;
10164b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner};
10174b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
10184b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
10194b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerclass TypedefType : public Type {
10204b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  TypedefDecl *Decl;
1021e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanianprotected:
1022e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian  TypedefType(TypeClass tc, TypedefDecl *D, QualType can)
1023e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian    : Type(tc, can), Decl(D) {
10244b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner    assert(!isa<TypedefType>(can) && "Invalid canonical type");
10254b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  }
10264b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  friend class ASTContext;  // ASTContext creates these.
10274b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerpublic:
10284b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
10294b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  TypedefDecl *getDecl() const { return Decl; }
10304b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
10314b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// LookThroughTypedefs - Return the ultimate type this typedef corresponds to
10324b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// potentially looking through *all* consequtive typedefs.  This returns the
10334b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// sum of the type qualifiers, so if you have:
10344b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  ///   typedef const int A;
10354b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  ///   typedef volatile A B;
10364b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  /// looking through the typedefs for B will give you "const volatile A".
10374b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  QualType LookThroughTypedefs() const;
10384b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
10394b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  virtual void getAsStringInternal(std::string &InnerString) const;
10404b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
10414b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static bool classof(const Type *T) { return T->getTypeClass() == TypeName; }
10424b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static bool classof(const TypedefType *) { return true; }
10432f665cd2aa263b89ac880dc45283847e5322a6c2Ted Kremenek
10442f665cd2aa263b89ac880dc45283847e5322a6c2Ted Kremenekprotected:
10452f665cd2aa263b89ac880dc45283847e5322a6c2Ted Kremenek  virtual void EmitImpl(llvm::Serializer& S) const;
10462f665cd2aa263b89ac880dc45283847e5322a6c2Ted Kremenek  static Type* CreateImpl(ASTContext& Context,llvm::Deserializer& D);
10472f665cd2aa263b89ac880dc45283847e5322a6c2Ted Kremenek  friend class Type;
10484b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner};
10494b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
10507cbb14653934a298c09002b87704dc6531261771Steve Naroff/// TypeOfExpr (GCC extension).
10517cbb14653934a298c09002b87704dc6531261771Steve Naroffclass TypeOfExpr : public Type {
10527cbb14653934a298c09002b87704dc6531261771Steve Naroff  Expr *TOExpr;
10537cbb14653934a298c09002b87704dc6531261771Steve Naroff  TypeOfExpr(Expr *E, QualType can) : Type(TypeOfExp, can), TOExpr(E) {
10547cbb14653934a298c09002b87704dc6531261771Steve Naroff    assert(!isa<TypedefType>(can) && "Invalid canonical type");
10557cbb14653934a298c09002b87704dc6531261771Steve Naroff  }
10567cbb14653934a298c09002b87704dc6531261771Steve Naroff  friend class ASTContext;  // ASTContext creates these.
10577cbb14653934a298c09002b87704dc6531261771Steve Naroffpublic:
10587cbb14653934a298c09002b87704dc6531261771Steve Naroff  Expr *getUnderlyingExpr() const { return TOExpr; }
10597cbb14653934a298c09002b87704dc6531261771Steve Naroff
10607cbb14653934a298c09002b87704dc6531261771Steve Naroff  virtual void getAsStringInternal(std::string &InnerString) const;
10617cbb14653934a298c09002b87704dc6531261771Steve Naroff
10627cbb14653934a298c09002b87704dc6531261771Steve Naroff  static bool classof(const Type *T) { return T->getTypeClass() == TypeOfExp; }
10637cbb14653934a298c09002b87704dc6531261771Steve Naroff  static bool classof(const TypeOfExpr *) { return true; }
10647cbb14653934a298c09002b87704dc6531261771Steve Naroff};
10657cbb14653934a298c09002b87704dc6531261771Steve Naroff
10667cbb14653934a298c09002b87704dc6531261771Steve Naroff/// TypeOfType (GCC extension).
10677cbb14653934a298c09002b87704dc6531261771Steve Naroffclass TypeOfType : public Type {
10687cbb14653934a298c09002b87704dc6531261771Steve Naroff  QualType TOType;
10697cbb14653934a298c09002b87704dc6531261771Steve Naroff  TypeOfType(QualType T, QualType can) : Type(TypeOfTyp, can), TOType(T) {
10707cbb14653934a298c09002b87704dc6531261771Steve Naroff    assert(!isa<TypedefType>(can) && "Invalid canonical type");
10717cbb14653934a298c09002b87704dc6531261771Steve Naroff  }
10727cbb14653934a298c09002b87704dc6531261771Steve Naroff  friend class ASTContext;  // ASTContext creates these.
10737cbb14653934a298c09002b87704dc6531261771Steve Naroffpublic:
10747cbb14653934a298c09002b87704dc6531261771Steve Naroff  QualType getUnderlyingType() const { return TOType; }
10757cbb14653934a298c09002b87704dc6531261771Steve Naroff
10767cbb14653934a298c09002b87704dc6531261771Steve Naroff  virtual void getAsStringInternal(std::string &InnerString) const;
10777cbb14653934a298c09002b87704dc6531261771Steve Naroff
10787cbb14653934a298c09002b87704dc6531261771Steve Naroff  static bool classof(const Type *T) { return T->getTypeClass() == TypeOfTyp; }
10797cbb14653934a298c09002b87704dc6531261771Steve Naroff  static bool classof(const TypeOfType *) { return true; }
10807cbb14653934a298c09002b87704dc6531261771Steve Naroff};
10814b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
10824b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattnerclass TagType : public Type {
1083581571c848395ba6c7401b5384f91ead457c9adcTed Kremenek  TagDecl *decl;
108446a837c7ced306c55d1686cea5f77cb7a2f3b908Ted Kremenek  friend class ASTContext;
10851d661556b9263f4d635372aecdea8c55dac84e83Douglas Gregor
10861d661556b9263f4d635372aecdea8c55dac84e83Douglas Gregorprotected:
1087581571c848395ba6c7401b5384f91ead457c9adcTed Kremenek  TagType(TagDecl *D, QualType can) : Type(Tagged, can), decl(D) {}
10881d661556b9263f4d635372aecdea8c55dac84e83Douglas Gregor
10891d661556b9263f4d635372aecdea8c55dac84e83Douglas Gregorpublic:
1090581571c848395ba6c7401b5384f91ead457c9adcTed Kremenek  TagDecl *getDecl() const { return decl; }
10914b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
10924b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  virtual void getAsStringInternal(std::string &InnerString) const;
10934b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
10944b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static bool classof(const Type *T) { return T->getTypeClass() == Tagged; }
10954b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner  static bool classof(const TagType *) { return true; }
10968db5aa1ca0d42cf8aeaa78cbe196a50f70fc9fc1Ted Kremenek
10978db5aa1ca0d42cf8aeaa78cbe196a50f70fc9fc1Ted Kremenekprotected:
10988db5aa1ca0d42cf8aeaa78cbe196a50f70fc9fc1Ted Kremenek  virtual void EmitImpl(llvm::Serializer& S) const;
109964be4ada44c719304c1dee75fb1e551f84b7779aTed Kremenek  static Type* CreateImpl(ASTContext& Context, llvm::Deserializer& D);
11008db5aa1ca0d42cf8aeaa78cbe196a50f70fc9fc1Ted Kremenek  friend class Type;
11014b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner};
11024b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
11031baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner/// RecordType - This is a helper class that allows the use of isa/cast/dyncast
11041baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner/// to detect TagType objects of structs/unions/classes.
11051baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattnerclass RecordType : public TagType {
1106ea29d1ec6b76c3722d7c0fb6a3d35c2d8cc74a79Argiris Kirtzidisprotected:
11073cbc064cf343c2151488b7822430ed327ade176eArgiris Kirtzidis  explicit RecordType(RecordDecl *D)
11083cbc064cf343c2151488b7822430ed327ade176eArgiris Kirtzidis    : TagType(reinterpret_cast<TagDecl*>(D), QualType()) { }
11091d661556b9263f4d635372aecdea8c55dac84e83Douglas Gregor  friend class ASTContext;   // ASTContext creates these.
11101baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattnerpublic:
11111baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner
11121baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner  RecordDecl *getDecl() const {
11131baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner    return reinterpret_cast<RecordDecl*>(TagType::getDecl());
11141baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner  }
11151baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner
11161baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner  // FIXME: This predicate is a helper to QualType/Type. It needs to
11171baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner  // recursively check all fields for const-ness. If any field is declared
11181baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner  // const, it needs to return false.
11191baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner  bool hasConstFields() const { return false; }
11201baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner
11211baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner  // FIXME: RecordType needs to check when it is created that all fields are in
11221baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner  // the same address space, and return that.
11231baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner  unsigned getAddressSpace() const { return 0; }
11241baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner
1125eae0eaa09f163aa27d2eb0244ed2d3ebed8eed6fChris Lattner  static bool classof(const TagType *T);
1126eae0eaa09f163aa27d2eb0244ed2d3ebed8eed6fChris Lattner  static bool classof(const Type *T) {
1127eae0eaa09f163aa27d2eb0244ed2d3ebed8eed6fChris Lattner    return isa<TagType>(T) && classof(cast<TagType>(T));
1128eae0eaa09f163aa27d2eb0244ed2d3ebed8eed6fChris Lattner  }
11291baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner  static bool classof(const RecordType *) { return true; }
11301baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner};
11311baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner
1132ea29d1ec6b76c3722d7c0fb6a3d35c2d8cc74a79Argiris Kirtzidis/// CXXRecordType - This is a helper class that allows the use of
1133ea29d1ec6b76c3722d7c0fb6a3d35c2d8cc74a79Argiris Kirtzidis/// isa/cast/dyncast to detect TagType objects of C++ structs/unions/classes.
1134ea29d1ec6b76c3722d7c0fb6a3d35c2d8cc74a79Argiris Kirtzidisclass CXXRecordType : public RecordType {
1135ea29d1ec6b76c3722d7c0fb6a3d35c2d8cc74a79Argiris Kirtzidis  explicit CXXRecordType(CXXRecordDecl *D)
1136ea29d1ec6b76c3722d7c0fb6a3d35c2d8cc74a79Argiris Kirtzidis    : RecordType(reinterpret_cast<RecordDecl*>(D)) { }
1137ea29d1ec6b76c3722d7c0fb6a3d35c2d8cc74a79Argiris Kirtzidis  friend class ASTContext;   // ASTContext creates these.
1138ea29d1ec6b76c3722d7c0fb6a3d35c2d8cc74a79Argiris Kirtzidispublic:
1139ea29d1ec6b76c3722d7c0fb6a3d35c2d8cc74a79Argiris Kirtzidis
1140ea29d1ec6b76c3722d7c0fb6a3d35c2d8cc74a79Argiris Kirtzidis  CXXRecordDecl *getDecl() const {
1141ea29d1ec6b76c3722d7c0fb6a3d35c2d8cc74a79Argiris Kirtzidis    return reinterpret_cast<CXXRecordDecl*>(RecordType::getDecl());
1142ea29d1ec6b76c3722d7c0fb6a3d35c2d8cc74a79Argiris Kirtzidis  }
1143ea29d1ec6b76c3722d7c0fb6a3d35c2d8cc74a79Argiris Kirtzidis
1144ea29d1ec6b76c3722d7c0fb6a3d35c2d8cc74a79Argiris Kirtzidis  static bool classof(const TagType *T);
1145ea29d1ec6b76c3722d7c0fb6a3d35c2d8cc74a79Argiris Kirtzidis  static bool classof(const Type *T) {
1146ea29d1ec6b76c3722d7c0fb6a3d35c2d8cc74a79Argiris Kirtzidis    return isa<TagType>(T) && classof(cast<TagType>(T));
1147ea29d1ec6b76c3722d7c0fb6a3d35c2d8cc74a79Argiris Kirtzidis  }
1148ea29d1ec6b76c3722d7c0fb6a3d35c2d8cc74a79Argiris Kirtzidis  static bool classof(const CXXRecordType *) { return true; }
1149ea29d1ec6b76c3722d7c0fb6a3d35c2d8cc74a79Argiris Kirtzidis};
1150ea29d1ec6b76c3722d7c0fb6a3d35c2d8cc74a79Argiris Kirtzidis
11511baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner/// EnumType - This is a helper class that allows the use of isa/cast/dyncast
11521baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner/// to detect TagType objects of enums.
11531baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattnerclass EnumType : public TagType {
11543cbc064cf343c2151488b7822430ed327ade176eArgiris Kirtzidis  explicit EnumType(EnumDecl *D)
11553cbc064cf343c2151488b7822430ed327ade176eArgiris Kirtzidis    : TagType(reinterpret_cast<TagDecl*>(D), QualType()) { }
11561d661556b9263f4d635372aecdea8c55dac84e83Douglas Gregor  friend class ASTContext;   // ASTContext creates these.
11571baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattnerpublic:
11581baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner
11591baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner  EnumDecl *getDecl() const {
11601baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner    return reinterpret_cast<EnumDecl*>(TagType::getDecl());
11611baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner  }
11621baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner
1163eae0eaa09f163aa27d2eb0244ed2d3ebed8eed6fChris Lattner  static bool classof(const TagType *T);
1164eae0eaa09f163aa27d2eb0244ed2d3ebed8eed6fChris Lattner  static bool classof(const Type *T) {
1165eae0eaa09f163aa27d2eb0244ed2d3ebed8eed6fChris Lattner    return isa<TagType>(T) && classof(cast<TagType>(T));
1166eae0eaa09f163aa27d2eb0244ed2d3ebed8eed6fChris Lattner  }
11671baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner  static bool classof(const EnumType *) { return true; }
11681baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner};
11691baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner
11701baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner
11711baaf13ea33c7b60742bf772bca8df2ccc1a51a8Chris Lattner
1172f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner/// ObjCInterfaceType - Interfaces are the core concept in Objective-C for
1173f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner/// object oriented design.  They basically correspond to C++ classes.  There
1174f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner/// are two kinds of interface types, normal interfaces like "NSString" and
1175f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner/// qualified interfaces, which are qualified with a protocol list like
1176f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner/// "NSString<NSCopyable, NSAmazing>".  Qualified interface types are instances
1177f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner/// of ObjCQualifiedInterfaceType, which is a subclass of ObjCInterfaceType.
117842730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenekclass ObjCInterfaceType : public Type {
117942730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek  ObjCInterfaceDecl *Decl;
11800c2f214d3500d1d080afa36b96db40407b91e70dFariborz Jahanianprotected:
118142730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek  ObjCInterfaceType(TypeClass tc, ObjCInterfaceDecl *D) :
11820c2f214d3500d1d080afa36b96db40407b91e70dFariborz Jahanian    Type(tc, QualType()), Decl(D) { }
118381f1bbabbdb7dce07802111e2d9648eedc866d51Steve Naroff  friend class ASTContext;  // ASTContext creates these.
118481f1bbabbdb7dce07802111e2d9648eedc866d51Steve Naroffpublic:
118581f1bbabbdb7dce07802111e2d9648eedc866d51Steve Naroff
118642730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek  ObjCInterfaceDecl *getDecl() const { return Decl; }
118781f1bbabbdb7dce07802111e2d9648eedc866d51Steve Naroff
1188f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner  /// qual_iterator and friends: this provides access to the (potentially empty)
1189f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner  /// list of protocols qualifying this interface.  If this is an instance of
1190f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner  /// ObjCQualifiedInterfaceType it returns the list, otherwise it returns an
1191f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner  /// empty list if there are no qualifying protocols.
1192f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner  typedef llvm::SmallVector<ObjCProtocolDecl*, 8>::const_iterator qual_iterator;
1193f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner  inline qual_iterator qual_begin() const;
1194f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner  inline qual_iterator qual_end() const;
1195f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner  bool qual_empty() const { return getTypeClass() != ObjCQualifiedInterface; }
1196f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner
1197f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner  /// getNumProtocols - Return the number of qualifying protocols in this
1198f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner  /// interface type, or 0 if there are none.
1199f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner  inline unsigned getNumProtocols() const;
1200f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner
1201d5f8179ed2b75e5c21109f3dd996836b5f743ecdChris Lattner  /// getProtocol - Return the specified qualifying protocol.
1202d5f8179ed2b75e5c21109f3dd996836b5f743ecdChris Lattner  inline ObjCProtocolDecl *getProtocol(unsigned i) const;
120391193f64449fe1faf9306a04ade6539d26f44037Fariborz Jahanian
1204f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner
1205f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner  virtual void getAsStringInternal(std::string &InnerString) const;
120681f1bbabbdb7dce07802111e2d9648eedc866d51Steve Naroff  static bool classof(const Type *T) {
1207b06cf30badcddfea862bc9a538447453bdd94598Chris Lattner    return T->getTypeClass() == ObjCInterface ||
1208b06cf30badcddfea862bc9a538447453bdd94598Chris Lattner           T->getTypeClass() == ObjCQualifiedInterface;
120981f1bbabbdb7dce07802111e2d9648eedc866d51Steve Naroff  }
121042730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek  static bool classof(const ObjCInterfaceType *) { return true; }
121181f1bbabbdb7dce07802111e2d9648eedc866d51Steve Naroff};
121281f1bbabbdb7dce07802111e2d9648eedc866d51Steve Naroff
121342730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek/// ObjCQualifiedInterfaceType - This class represents interface types
1214e86716008551d268871e9aa7b27ea1b64b462991Chris Lattner/// conforming to a list of protocols, such as INTF<Proto1, Proto2, Proto1>.
1215e86716008551d268871e9aa7b27ea1b64b462991Chris Lattner///
1216c5a342d3b1cc5fa6eef09653a6d8d091928366c0Fariborz Jahanian/// Duplicate protocols are removed and protocol list is canonicalized to be in
1217c5a342d3b1cc5fa6eef09653a6d8d091928366c0Fariborz Jahanian/// alphabetical order.
121842730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenekclass ObjCQualifiedInterfaceType : public ObjCInterfaceType,
12190c2f214d3500d1d080afa36b96db40407b91e70dFariborz Jahanian                                   public llvm::FoldingSetNode {
12200c2f214d3500d1d080afa36b96db40407b91e70dFariborz Jahanian
1221c04aff17dcfaa5f628bcfed0e393f2e946ea5184Fariborz Jahanian  // List of protocols for this protocol conforming object type
1222c04aff17dcfaa5f628bcfed0e393f2e946ea5184Fariborz Jahanian  // List is sorted on protocol name. No protocol is enterred more than once.
1223f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner  llvm::SmallVector<ObjCProtocolDecl*, 4> Protocols;
1224c04aff17dcfaa5f628bcfed0e393f2e946ea5184Fariborz Jahanian
122542730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek  ObjCQualifiedInterfaceType(ObjCInterfaceDecl *D,
1226b0c6a1fcc5d43696387d2870cc4722581f6db671Chris Lattner                             ObjCProtocolDecl **Protos, unsigned NumP) :
122742730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek    ObjCInterfaceType(ObjCQualifiedInterface, D),
1228d855a6ead44e3a875179400c472ac0b37df35f70Chris Lattner    Protocols(Protos, Protos+NumP) { }
122991193f64449fe1faf9306a04ade6539d26f44037Fariborz Jahanian  friend class ASTContext;  // ASTContext creates these.
1230c04aff17dcfaa5f628bcfed0e393f2e946ea5184Fariborz Jahanianpublic:
1231c04aff17dcfaa5f628bcfed0e393f2e946ea5184Fariborz Jahanian
1232d5f8179ed2b75e5c21109f3dd996836b5f743ecdChris Lattner  ObjCProtocolDecl *getProtocol(unsigned i) const {
123391193f64449fe1faf9306a04ade6539d26f44037Fariborz Jahanian    return Protocols[i];
123491193f64449fe1faf9306a04ade6539d26f44037Fariborz Jahanian  }
123591193f64449fe1faf9306a04ade6539d26f44037Fariborz Jahanian  unsigned getNumProtocols() const {
123691193f64449fe1faf9306a04ade6539d26f44037Fariborz Jahanian    return Protocols.size();
123791193f64449fe1faf9306a04ade6539d26f44037Fariborz Jahanian  }
1238b0c6a1fcc5d43696387d2870cc4722581f6db671Chris Lattner
1239b0c6a1fcc5d43696387d2870cc4722581f6db671Chris Lattner  qual_iterator qual_begin() const { return Protocols.begin(); }
1240b0c6a1fcc5d43696387d2870cc4722581f6db671Chris Lattner  qual_iterator qual_end() const   { return Protocols.end(); }
1241b0c6a1fcc5d43696387d2870cc4722581f6db671Chris Lattner
124291193f64449fe1faf9306a04ade6539d26f44037Fariborz Jahanian  virtual void getAsStringInternal(std::string &InnerString) const;
124391193f64449fe1faf9306a04ade6539d26f44037Fariborz Jahanian
124491193f64449fe1faf9306a04ade6539d26f44037Fariborz Jahanian  void Profile(llvm::FoldingSetNodeID &ID);
124591193f64449fe1faf9306a04ade6539d26f44037Fariborz Jahanian  static void Profile(llvm::FoldingSetNodeID &ID,
1246fd5690fe6b5ea1c553dfe20f99d3fef269a50bd1Chris Lattner                      const ObjCInterfaceDecl *Decl,
124742730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek                      ObjCProtocolDecl **protocols, unsigned NumProtocols);
124891193f64449fe1faf9306a04ade6539d26f44037Fariborz Jahanian
1249c04aff17dcfaa5f628bcfed0e393f2e946ea5184Fariborz Jahanian  static bool classof(const Type *T) {
125042730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek    return T->getTypeClass() == ObjCQualifiedInterface;
1251c04aff17dcfaa5f628bcfed0e393f2e946ea5184Fariborz Jahanian  }
125242730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek  static bool classof(const ObjCQualifiedInterfaceType *) { return true; }
1253c04aff17dcfaa5f628bcfed0e393f2e946ea5184Fariborz Jahanian};
1254f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner
1255f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattnerinline ObjCInterfaceType::qual_iterator ObjCInterfaceType::qual_begin() const {
1256f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner  if (const ObjCQualifiedInterfaceType *QIT =
1257f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner         dyn_cast<ObjCQualifiedInterfaceType>(this))
1258f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner    return QIT->qual_begin();
1259f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner  return 0;
1260f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner}
1261f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattnerinline ObjCInterfaceType::qual_iterator ObjCInterfaceType::qual_end() const {
1262f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner  if (const ObjCQualifiedInterfaceType *QIT =
1263f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner         dyn_cast<ObjCQualifiedInterfaceType>(this))
1264f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner    return QIT->qual_end();
1265f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner  return 0;
1266f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner}
1267f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner
1268f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner/// getNumProtocols - Return the number of qualifying protocols in this
1269f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner/// interface type, or 0 if there are none.
1270f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattnerinline unsigned ObjCInterfaceType::getNumProtocols() const {
1271f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner  if (const ObjCQualifiedInterfaceType *QIT =
1272f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner        dyn_cast<ObjCQualifiedInterfaceType>(this))
1273f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner    return QIT->getNumProtocols();
1274f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner  return 0;
1275f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner}
1276f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner
1277d5f8179ed2b75e5c21109f3dd996836b5f743ecdChris Lattner/// getProtocol - Return the specified qualifying protocol.
1278d5f8179ed2b75e5c21109f3dd996836b5f743ecdChris Lattnerinline ObjCProtocolDecl *ObjCInterfaceType::getProtocol(unsigned i) const {
1279d5f8179ed2b75e5c21109f3dd996836b5f743ecdChris Lattner  return cast<ObjCQualifiedInterfaceType>(this)->getProtocol(i);
1280f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner}
1281f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner
1282f81d921ec2f5bac3f35a94392fe2b764473884eeChris Lattner
1283e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian
1284e86716008551d268871e9aa7b27ea1b64b462991Chris Lattner/// ObjCQualifiedIdType - to represent id<protocol-list>.
1285e86716008551d268871e9aa7b27ea1b64b462991Chris Lattner///
1286e86716008551d268871e9aa7b27ea1b64b462991Chris Lattner/// Duplicate protocols are removed and protocol list is canonicalized to be in
1287e86716008551d268871e9aa7b27ea1b64b462991Chris Lattner/// alphabetical order.
128842730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenekclass ObjCQualifiedIdType : public Type,
1289e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian                            public llvm::FoldingSetNode {
1290e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian  // List of protocols for this protocol conforming 'id' type
1291e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian  // List is sorted on protocol name. No protocol is enterred more than once.
129242730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek  llvm::SmallVector<ObjCProtocolDecl*, 8> Protocols;
1293e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian
12944a68fe04deb7ab89ac7566dc55b3b623129c72e5Chris Lattner  ObjCQualifiedIdType(ObjCProtocolDecl **Protos, unsigned NumP)
12954a68fe04deb7ab89ac7566dc55b3b623129c72e5Chris Lattner    : Type(ObjCQualifiedId, QualType()/*these are always canonical*/),
1296e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian  Protocols(Protos, Protos+NumP) { }
1297e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian  friend class ASTContext;  // ASTContext creates these.
1298e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanianpublic:
1299e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian
130042730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek  ObjCProtocolDecl *getProtocols(unsigned i) const {
1301e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian    return Protocols[i];
1302e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian  }
1303e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian  unsigned getNumProtocols() const {
1304e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian    return Protocols.size();
1305e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian  }
130642730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek  ObjCProtocolDecl **getReferencedProtocols() {
1307957442db1d23f62ee2d0d71310bee240606b267dFariborz Jahanian    return &Protocols[0];
1308b0c6a1fcc5d43696387d2870cc4722581f6db671Chris Lattner  }
1309b0c6a1fcc5d43696387d2870cc4722581f6db671Chris Lattner
1310b0c6a1fcc5d43696387d2870cc4722581f6db671Chris Lattner  typedef llvm::SmallVector<ObjCProtocolDecl*, 8>::const_iterator qual_iterator;
1311b0c6a1fcc5d43696387d2870cc4722581f6db671Chris Lattner  qual_iterator qual_begin() const { return Protocols.begin(); }
1312b0c6a1fcc5d43696387d2870cc4722581f6db671Chris Lattner  qual_iterator qual_end() const   { return Protocols.end(); }
1313e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian
1314e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian  virtual void getAsStringInternal(std::string &InnerString) const;
1315e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian
1316e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian  void Profile(llvm::FoldingSetNodeID &ID);
13174a68fe04deb7ab89ac7566dc55b3b623129c72e5Chris Lattner  static void Profile(llvm::FoldingSetNodeID &ID,
131842730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek                      ObjCProtocolDecl **protocols, unsigned NumProtocols);
1319e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian
1320e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian  static bool classof(const Type *T) {
132142730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek    return T->getTypeClass() == ObjCQualifiedId;
1322e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian  }
132342730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenek  static bool classof(const ObjCQualifiedIdType *) { return true; }
1324e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian
1325e76e8416ff29ee39140b64ed47731237c67434aeFariborz Jahanian};
1326c04aff17dcfaa5f628bcfed0e393f2e946ea5184Fariborz Jahanian
13274b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
1328b0fdfd50e1e4011486d5cb3773e1e87c8ec4325aChris Lattner// Inline function definitions.
13294b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
13302a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb/// getUnqualifiedType - Return the type without any qualifiers.
13312a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lambinline QualType QualType::getUnqualifiedType() const {
133235fef52886c88e3855745917fcb0bf6a19fa0ba1Chris Lattner  Type *TP = getTypePtr();
133335fef52886c88e3855745917fcb0bf6a19fa0ba1Chris Lattner  if (const ASQualType *ASQT = dyn_cast<ASQualType>(TP))
133435fef52886c88e3855745917fcb0bf6a19fa0ba1Chris Lattner    TP = ASQT->getBaseType();
133535fef52886c88e3855745917fcb0bf6a19fa0ba1Chris Lattner  return QualType(TP, 0);
13362a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb}
13372a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb
13382a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb/// getAddressSpace - Return the address space of this type.
13392a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lambinline unsigned QualType::getAddressSpace() const {
134001ee73fb7b2734d3ca1c5876dc623811518985dfChris Lattner  QualType CT = getTypePtr()->getCanonicalTypeInternal();
134101ee73fb7b2734d3ca1c5876dc623811518985dfChris Lattner  if (const ArrayType *AT = dyn_cast<ArrayType>(CT))
1342a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner    return AT->getElementType().getAddressSpace();
134301ee73fb7b2734d3ca1c5876dc623811518985dfChris Lattner  if (const RecordType *RT = dyn_cast<RecordType>(CT))
1344efc11216a5755f69b5540289aa2dd374d4bc82abNate Begeman    return RT->getAddressSpace();
134501ee73fb7b2734d3ca1c5876dc623811518985dfChris Lattner  if (const ASQualType *ASQT = dyn_cast<ASQualType>(CT))
13462a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb    return ASQT->getAddressSpace();
13472a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  return 0;
13482a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb}
1349b0fdfd50e1e4011486d5cb3773e1e87c8ec4325aChris Lattner
13505c45be48e6125c5981ad48708dc7e8267bace63aTed Kremenekinline const TypedefType* Type::getAsTypedefType() const {
13515c45be48e6125c5981ad48708dc7e8267bace63aTed Kremenek  return dyn_cast<TypedefType>(this);
13525c45be48e6125c5981ad48708dc7e8267bace63aTed Kremenek}
1353f914765ba1d70f599fa69bde38b8646c02d9b1aaChris Lattnerinline const ObjCInterfaceType *Type::getAsPointerToObjCInterfaceType() const {
1354f914765ba1d70f599fa69bde38b8646c02d9b1aaChris Lattner  if (const PointerType *PT = getAsPointerType())
1355f914765ba1d70f599fa69bde38b8646c02d9b1aaChris Lattner    return PT->getPointeeType()->getAsObjCInterfaceType();
1356f914765ba1d70f599fa69bde38b8646c02d9b1aaChris Lattner  return 0;
1357f914765ba1d70f599fa69bde38b8646c02d9b1aaChris Lattner}
1358f914765ba1d70f599fa69bde38b8646c02d9b1aaChris Lattner
1359a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner// NOTE: All of these methods use "getUnqualifiedType" to strip off address
1360a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner// space qualifiers if present.
1361b0fdfd50e1e4011486d5cb3773e1e87c8ec4325aChris Lattnerinline bool Type::isFunctionType() const {
13622a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  return isa<FunctionType>(CanonicalType.getUnqualifiedType());
1363b0fdfd50e1e4011486d5cb3773e1e87c8ec4325aChris Lattner}
1364b0fdfd50e1e4011486d5cb3773e1e87c8ec4325aChris Lattnerinline bool Type::isPointerType() const {
13652a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  return isa<PointerType>(CanonicalType.getUnqualifiedType());
1366b0fdfd50e1e4011486d5cb3773e1e87c8ec4325aChris Lattner}
13677aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroffinline bool Type::isBlockPointerType() const {
13687aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff    return isa<BlockPointerType>(CanonicalType);
13697aa5475ca2f62df5ba3f3b647ee141a40bf48fd3Steve Naroff}
1370cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattnerinline bool Type::isReferenceType() const {
1371cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner  return isa<ReferenceType>(CanonicalType.getUnqualifiedType());
1372cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner}
1373cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattnerinline bool Type::isPointerLikeType() const {
1374cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner  return isa<PointerLikeType>(CanonicalType.getUnqualifiedType());
1375cfac88de7de7d970a2436af939ea87c0e5a9cf9fChris Lattner}
137683b01279f2e6718581eeb1e5bdba58aa88e4649bTed Kremenekinline bool Type::isFunctionPointerType() const {
137774a340749eb63af1ba7098c67f3ef72bd48f5ae8Ted Kremenek  if (const PointerType* T = getAsPointerType())
137883b01279f2e6718581eeb1e5bdba58aa88e4649bTed Kremenek    return T->getPointeeType()->isFunctionType();
137983b01279f2e6718581eeb1e5bdba58aa88e4649bTed Kremenek  else
138083b01279f2e6718581eeb1e5bdba58aa88e4649bTed Kremenek    return false;
138183b01279f2e6718581eeb1e5bdba58aa88e4649bTed Kremenek}
1382b0fdfd50e1e4011486d5cb3773e1e87c8ec4325aChris Lattnerinline bool Type::isArrayType() const {
13832a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  return isa<ArrayType>(CanonicalType.getUnqualifiedType());
1384b0fdfd50e1e4011486d5cb3773e1e87c8ec4325aChris Lattner}
1385a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattnerinline bool Type::isConstantArrayType() const {
1386a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner  return isa<ConstantArrayType>(CanonicalType.getUnqualifiedType());
1387a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner}
1388a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattnerinline bool Type::isIncompleteArrayType() const {
1389a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner  return isa<IncompleteArrayType>(CanonicalType.getUnqualifiedType());
1390a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner}
1391a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattnerinline bool Type::isVariableArrayType() const {
1392a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner  return isa<VariableArrayType>(CanonicalType.getUnqualifiedType());
1393a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner}
1394b0fdfd50e1e4011486d5cb3773e1e87c8ec4325aChris Lattnerinline bool Type::isRecordType() const {
13952a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  return isa<RecordType>(CanonicalType.getUnqualifiedType());
1396b0fdfd50e1e4011486d5cb3773e1e87c8ec4325aChris Lattner}
13973277df47de6b65b55721726dc3f7b294e70ef6feChris Lattnerinline bool Type::isAnyComplexType() const {
1398a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner  return isa<ComplexType>(CanonicalType.getUnqualifiedType());
13993277df47de6b65b55721726dc3f7b294e70ef6feChris Lattner}
1400b0fdfd50e1e4011486d5cb3773e1e87c8ec4325aChris Lattnerinline bool Type::isVectorType() const {
14012a72bb32dfda134cb2bab50f5bb4a6b214f84348Christopher Lamb  return isa<VectorType>(CanonicalType.getUnqualifiedType());
1402b0fdfd50e1e4011486d5cb3773e1e87c8ec4325aChris Lattner}
1403af6ed504d90dc3b813c573bfbee8bc0e92e7fdc0Nate Begemaninline bool Type::isExtVectorType() const {
1404af6ed504d90dc3b813c573bfbee8bc0e92e7fdc0Nate Begeman  return isa<ExtVectorType>(CanonicalType.getUnqualifiedType());
1405b0fdfd50e1e4011486d5cb3773e1e87c8ec4325aChris Lattner}
140642730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenekinline bool Type::isObjCInterfaceType() const {
1407a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner  return isa<ObjCInterfaceType>(CanonicalType.getUnqualifiedType());
1408b06cf30badcddfea862bc9a538447453bdd94598Chris Lattner}
1409b06cf30badcddfea862bc9a538447453bdd94598Chris Lattnerinline bool Type::isObjCQualifiedInterfaceType() const {
1410a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner  return isa<ObjCQualifiedInterfaceType>(CanonicalType.getUnqualifiedType());
1411550e05034c6c8efcb7ab4c65f58048eee0892237Fariborz Jahanian}
141242730c53aeef9ac6c258d317065fdf38da4e043cTed Kremenekinline bool Type::isObjCQualifiedIdType() const {
1413a1923f6d95601582f4a5c3924b8e1c5ac3f658b3Chris Lattner  return isa<ObjCQualifiedIdType>(CanonicalType.getUnqualifiedType());
1414dcb2b1e489948a570ee07ca65e12d42edffa20efFariborz Jahanian}
14154b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner}  // end namespace clang
14164b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner
14174b0096578e961587d1ec0ed5dce45f592a65ed4Chris Lattner#endif
1418