case Type::Tagged:
D.RegisterPtr(PtrID,TagType::CreateImpl(Context,D));
break;
+
+ case Type::TypeName:
+ D.RegisterPtr(PtrID,TypedefType::CreateImpl(Context,D));
+ break;
}
}
D.ReadPtr(T->Decl); // May be backpatched.
return T;
}
+
+//===----------------------------------------------------------------------===//
+// TypedefType
+//===----------------------------------------------------------------------===//
+
+void TypedefType::EmitImpl(Serializer& S) const {
+ S.Emit(QualType((Type*)this,0).getCanonicalType());
+ S.EmitPtr(Decl);
+}
+
+Type* TypedefType::CreateImpl(ASTContext& Context, Deserializer& D) {
+ std::vector<Type*>& Types =
+ const_cast<std::vector<Type*>&>(Context.getTypes());
+
+ TypedefType* T = new TypedefType(NULL,QualType::ReadVal(D));
+ Types.push_back(T);
+
+ D.ReadPtr(T->Decl); // May be backpatched.
+
+ return T;
+}
+
static bool classof(const Type *T) { return T->getTypeClass() == TypeName; }
static bool classof(const TypedefType *) { return true; }
+
+protected:
+ virtual void EmitImpl(llvm::Serializer& S) const;
+ static Type* CreateImpl(ASTContext& Context,llvm::Deserializer& D);
+ friend class Type;
};
/// TypeOfExpr (GCC extension).