diff --git a/clang/lib/AST/ASTImporter.cpp b/clang/lib/AST/ASTImporter.cpp --- a/clang/lib/AST/ASTImporter.cpp +++ b/clang/lib/AST/ASTImporter.cpp @@ -368,58 +368,9 @@ // Importing types ExpectedType VisitType(const Type *T); - ExpectedType VisitAtomicType(const AtomicType *T); - ExpectedType VisitBuiltinType(const BuiltinType *T); - ExpectedType VisitDecayedType(const DecayedType *T); - ExpectedType VisitComplexType(const ComplexType *T); - ExpectedType VisitPointerType(const PointerType *T); - ExpectedType VisitBlockPointerType(const BlockPointerType *T); - ExpectedType VisitLValueReferenceType(const LValueReferenceType *T); - ExpectedType VisitRValueReferenceType(const RValueReferenceType *T); - ExpectedType VisitMemberPointerType(const MemberPointerType *T); - ExpectedType VisitConstantArrayType(const ConstantArrayType *T); - ExpectedType VisitIncompleteArrayType(const IncompleteArrayType *T); - ExpectedType VisitVariableArrayType(const VariableArrayType *T); - ExpectedType VisitDependentSizedArrayType(const DependentSizedArrayType *T); - ExpectedType - VisitDependentSizedExtVectorType(const DependentSizedExtVectorType *T); - ExpectedType VisitVectorType(const VectorType *T); - ExpectedType VisitExtVectorType(const ExtVectorType *T); - ExpectedType VisitFunctionNoProtoType(const FunctionNoProtoType *T); - ExpectedType VisitFunctionProtoType(const FunctionProtoType *T); - ExpectedType VisitUnresolvedUsingType(const UnresolvedUsingType *T); - ExpectedType VisitParenType(const ParenType *T); - ExpectedType VisitTypedefType(const TypedefType *T); - ExpectedType VisitTypeOfExprType(const TypeOfExprType *T); - // FIXME: DependentTypeOfExprType - ExpectedType VisitTypeOfType(const TypeOfType *T); - ExpectedType VisitUsingType(const UsingType *T); - ExpectedType VisitDecltypeType(const DecltypeType *T); - ExpectedType VisitUnaryTransformType(const UnaryTransformType *T); - ExpectedType VisitAutoType(const AutoType *T); - ExpectedType VisitDeducedTemplateSpecializationType( - const DeducedTemplateSpecializationType *T); - ExpectedType VisitInjectedClassNameType(const InjectedClassNameType *T); - // FIXME: DependentDecltypeType - ExpectedType VisitRecordType(const RecordType *T); - ExpectedType VisitEnumType(const EnumType *T); - ExpectedType VisitAttributedType(const AttributedType *T); - ExpectedType VisitTemplateTypeParmType(const TemplateTypeParmType *T); - ExpectedType VisitSubstTemplateTypeParmType( - const SubstTemplateTypeParmType *T); - ExpectedType - VisitSubstTemplateTypeParmPackType(const SubstTemplateTypeParmPackType *T); - ExpectedType VisitTemplateSpecializationType( - const TemplateSpecializationType *T); - ExpectedType VisitElaboratedType(const ElaboratedType *T); - ExpectedType VisitDependentNameType(const DependentNameType *T); - ExpectedType VisitPackExpansionType(const PackExpansionType *T); - ExpectedType VisitDependentTemplateSpecializationType( - const DependentTemplateSpecializationType *T); - ExpectedType VisitObjCInterfaceType(const ObjCInterfaceType *T); - ExpectedType VisitObjCObjectType(const ObjCObjectType *T); - ExpectedType VisitObjCObjectPointerType(const ObjCObjectPointerType *T); - ExpectedType VisitMacroQualifiedType(const MacroQualifiedType *T); +#define TYPE(Class, Base) \ + ExpectedType Visit##Class##Type(const Class##Type *T); +#include "clang/AST/TypeNodes.inc" // Importing declarations Error ImportDeclParts(NamedDecl *D, DeclarationName &Name, NamedDecl *&ToD, @@ -1714,6 +1665,147 @@ ToIdentifier); } +ExpectedType clang::ASTNodeImporter::VisitAdjustedType(const AdjustedType *T) { + ExpectedType ToOriginalTypeOrErr = import(T->getOriginalType()); + if (!ToOriginalTypeOrErr) + return ToOriginalTypeOrErr.takeError(); + + ExpectedType ToAdjustedTypeOrErr = import(T->getAdjustedType()); + if (!ToAdjustedTypeOrErr) + return ToAdjustedTypeOrErr.takeError(); + + return Importer.getToContext().getAdjustedType(*ToOriginalTypeOrErr, + *ToAdjustedTypeOrErr); +} + +ExpectedType clang::ASTNodeImporter::VisitBitIntType(const BitIntType *T) { + return Importer.getToContext().getBitIntType(T->isUnsigned(), + T->getNumBits()); +} + +ExpectedType clang::ASTNodeImporter::VisitBTFTagAttributedType( + const clang::BTFTagAttributedType *T) { + auto ToBTFAttrOrErr = import(T->getAttr()); + if (!ToBTFAttrOrErr) + return ToBTFAttrOrErr.takeError(); + + ExpectedType ToWrappedTypeOrErr = import(T->getWrappedType()); + if (!ToWrappedTypeOrErr) + return ToWrappedTypeOrErr.takeError(); + + return Importer.getToContext().getBTFTagAttributedType(*ToBTFAttrOrErr, + *ToWrappedTypeOrErr); +} + +ExpectedType clang::ASTNodeImporter::VisitConstantMatrixType( + const clang::ConstantMatrixType *T) { + ExpectedType ToElementTypeOrErr = import(T->getElementType()); + if (!ToElementTypeOrErr) + return ToElementTypeOrErr.takeError(); + + return Importer.getToContext().getConstantMatrixType( + *ToElementTypeOrErr, T->getNumRows(), T->getNumColumns()); +} + +ExpectedType clang::ASTNodeImporter::VisitDependentAddressSpaceType( + const clang::DependentAddressSpaceType *T) { + ExpectedExpr ToAddrSpaceExprOrErr = import(T->getAddrSpaceExpr()); + if (!ToAddrSpaceExprOrErr) + return ToAddrSpaceExprOrErr.takeError(); + + ExpectedType ToPointeeTypeOrErr = import(T->getPointeeType()); + if (!ToPointeeTypeOrErr) + return ToPointeeTypeOrErr.takeError(); + + auto ToAttrLocOrErr = import(T->getAttributeLoc()); + if (!ToAttrLocOrErr) + return ToAttrLocOrErr.takeError(); + + return Importer.getToContext().getDependentAddressSpaceType( + *ToPointeeTypeOrErr, *ToAddrSpaceExprOrErr, *ToAttrLocOrErr); +} + +ExpectedType clang::ASTNodeImporter::VisitDependentBitIntType( + const clang::DependentBitIntType *T) { + ExpectedExpr ToNumBitsExprOrErr = import(T->getNumBitsExpr()); + if (!ToNumBitsExprOrErr) + return ToNumBitsExprOrErr.takeError(); + return Importer.getToContext().getDependentBitIntType(T->isUnsigned(), + *ToNumBitsExprOrErr); +} + +ExpectedType clang::ASTNodeImporter::VisitDependentSizedMatrixType( + const clang::DependentSizedMatrixType *T) { + ExpectedType ToElementTypeOrErr = import(T->getElementType()); + if (!ToElementTypeOrErr) + return ToElementTypeOrErr.takeError(); + + ExpectedExpr ToRowExprOrErr = import(T->getRowExpr()); + if (!ToRowExprOrErr) + return ToRowExprOrErr.takeError(); + + ExpectedExpr ToColumnExprOrErr = import(T->getColumnExpr()); + if (!ToColumnExprOrErr) + return ToColumnExprOrErr.takeError(); + + auto ToAttrLocOrErr = import(T->getAttributeLoc()); + if (!ToAttrLocOrErr) + return ToAttrLocOrErr.takeError(); + + return Importer.getToContext().getDependentSizedMatrixType( + *ToElementTypeOrErr, *ToRowExprOrErr, *ToColumnExprOrErr, + *ToAttrLocOrErr); +} + +ExpectedType clang::ASTNodeImporter::VisitDependentVectorType( + const clang::DependentVectorType *T) { + ExpectedType ToElementTypeOrErr = import(T->getElementType()); + if (!ToElementTypeOrErr) + return ToElementTypeOrErr.takeError(); + + ExpectedExpr ToSizeExprOrErr = import(T->getSizeExpr()); + if (!ToSizeExprOrErr) + return ToSizeExprOrErr.takeError(); + + auto ToAttrLocOrErr = import(T->getAttributeLoc()); + if (!ToAttrLocOrErr) + return ToAttrLocOrErr.takeError(); + + return Importer.getToContext().getDependentVectorType( + *ToElementTypeOrErr, *ToSizeExprOrErr, *ToAttrLocOrErr, + T->getVectorKind()); +} + +ExpectedType clang::ASTNodeImporter::VisitObjCTypeParamType( + const clang::ObjCTypeParamType *T) { + Expected ToDeclOrErr = import(T->getDecl()); + if (!ToDeclOrErr) + return ToDeclOrErr.takeError(); + + SmallVector ToProtocols; + for (ObjCProtocolDecl *FromProtocol : T->getProtocols()) { + Expected ToProtocolOrErr = import(FromProtocol); + if (!ToProtocolOrErr) + return ToProtocolOrErr.takeError(); + ToProtocols.push_back(*ToProtocolOrErr); + } + + return Importer.getToContext().getObjCTypeParamType(*ToDeclOrErr, + ToProtocols); +} + +ExpectedType clang::ASTNodeImporter::VisitPipeType(const clang::PipeType *T) { + ExpectedType ToElementTypeOrErr = import(T->getElementType()); + if (!ToElementTypeOrErr) + return ToElementTypeOrErr.takeError(); + + ASTContext &ToCtx = Importer.getToContext(); + if (T->isReadOnly()) + return ToCtx.getReadPipeType(*ToElementTypeOrErr); + else + return ToCtx.getWritePipeType(*ToElementTypeOrErr); +} + //---------------------------------------------------------------------------- // Import Declarations //---------------------------------------------------------------------------- @@ -4654,6 +4746,11 @@ ToColonLoc, ToTypeSourceInfo)) return Result; + // Only import 'ObjCTypeParamType' after the decl is created. + auto ToTypeForDecl = importChecked(Err, D->getTypeForDecl()); + if (Err) + return std::move(Err); + Result->setTypeForDecl(ToTypeForDecl); Result->setLexicalDeclContext(LexicalDC); return Result; } diff --git a/clang/unittests/AST/ASTImporterObjCTest.cpp b/clang/unittests/AST/ASTImporterObjCTest.cpp --- a/clang/unittests/AST/ASTImporterObjCTest.cpp +++ b/clang/unittests/AST/ASTImporterObjCTest.cpp @@ -77,6 +77,31 @@ } } +TEST_P(ImportObjCDecl, ImportObjCTypeParamDecl) { + Decl *FromTU = getTuDecl( + R"( + @interface X + @end + )", + Lang_OBJCXX, "input.mm"); + auto Pattern = objcTypeParamDecl(hasTypeForDecl(objcTypeParamType())); + auto *FromInterfaceDecl = FirstDeclMatcher().match( + FromTU, namedDecl(hasName("X"))); + auto *FromTypeParamDecl = + FirstDeclMatcher().match(FromInterfaceDecl, Pattern); + + auto ToTypeParamDeclImported = Import(FromTypeParamDecl, Lang_OBJCXX); + + auto *ToInterfaceDecl = FirstDeclMatcher().match( + ToTypeParamDeclImported->getTranslationUnitDecl(), + namedDecl(hasName("X"))); + auto *ToTypeParamDeclMatched = + FirstDeclMatcher().match(ToInterfaceDecl, Pattern); + ASSERT_TRUE(ToTypeParamDeclImported); + ASSERT_TRUE(ToTypeParamDeclMatched); + ASSERT_TRUE(ToTypeParamDeclImported == ToTypeParamDeclMatched); +} + static const auto ObjCTestArrayForRunOptions = std::array, 2>{ {std::vector{"-fno-objc-arc"}, diff --git a/clang/unittests/AST/ASTImporterTest.cpp b/clang/unittests/AST/ASTImporterTest.cpp --- a/clang/unittests/AST/ASTImporterTest.cpp +++ b/clang/unittests/AST/ASTImporterTest.cpp @@ -583,6 +583,88 @@ functionDecl(hasDescendant(typedefDecl(has(atomicType()))))); } +TEST_P(ImportType, ImportBitIntType) { + MatchVerifier Verifier; + testImport("_BitInt(10) declToImport;", Lang_CXX11, "", Lang_CXX11, Verifier, + varDecl(hasType(bitIntType()))); +} + +TEST_P(ImportType, ImportDependentBitIntType) { + MatchVerifier Verifier; + testImport("template using declToImport = _BitInt(Width);", + Lang_CXX11, "", Lang_CXX11, Verifier, + typeAliasTemplateDecl( + has(typeAliasDecl(hasType(dependentBitIntType()))))); +} + +TEST_P(ImportType, ImportDependentAddressSpaceType) { + MatchVerifier Verifier; + testImport( + R"( + template + using declToImport = T __attribute__((address_space(AddrSpace))); + )", + Lang_CXX11, "", Lang_CXX11, Verifier, + typeAliasTemplateDecl( + has(typeAliasDecl(hasType(dependentAddressSpaceType()))))); +} + +TEST_P(ImportType, ImportVectorType) { + MatchVerifier Verifier; + testImport("typedef int __attribute__((vector_size(12))) declToImport;", + Lang_CXX11, "", Lang_CXX11, Verifier, + typedefDecl(hasType(vectorType()))); +} + +TEST_P(ImportType, ImportDependentVectorType) { + MatchVerifier Verifier; + testImport( + R"( + template + using declToImport = T __attribute__((vector_size(Size))); + )", + Lang_CXX11, "", Lang_CXX11, Verifier, + typeAliasTemplateDecl( + has(typeAliasDecl(hasType(dependentVectorType()))))); +} + +struct ImportOpenCLPipe : ImportType { + std::vector getExtraArgs() const override { + return {"-x", "cl", "-cl-no-stdinc", "-cl-std=CL2.0"}; + } +}; + +TEST_P(ImportOpenCLPipe, ImportPipeType) { + MatchVerifier Verifier; + testImport("typedef pipe int declToImport;", Lang_OpenCL, "", Lang_OpenCL, + Verifier, typedefDecl(hasType(pipeType()))); +} + +struct ImportMatrixType : ImportType { + std::vector getExtraArgs() const override { + return {"-fenable-matrix"}; + } +}; + +TEST_P(ImportMatrixType, ImportConstantMatrixType) { + MatchVerifier Verifier; + testImport("typedef int __attribute__((matrix_type(5, 5))) declToImport;", + Lang_CXX11, "", Lang_CXX11, Verifier, + typedefDecl(hasType(constantMatrixType()))); +} + +TEST_P(ImportMatrixType, ImportDependentSizedMatrixType) { + MatchVerifier Verifier; + testImport( + R"( + template + using declToImport = T __attribute__((matrix_type(Rows, Cols))); + )", + Lang_CXX11, "", Lang_CXX11, Verifier, + typeAliasTemplateDecl( + has(typeAliasDecl(hasType(dependentSizedMatrixType()))))); +} + TEST_P(ImportType, ImportUsingType) { MatchVerifier Verifier; testImport("struct C {};"