xref: /llvm-project/clang/lib/Interpreter/InterpreterUtils.cpp (revision 458328ae23d318a5055d5bac66426b8551bce01f)
15111286fSJun Zhang //===--- InterpreterUtils.cpp - Incremental Utils --------*- C++ -*-===//
25111286fSJun Zhang //
35111286fSJun Zhang // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
45111286fSJun Zhang // See https://llvm.org/LICENSE.txt for license information.
55111286fSJun Zhang // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
65111286fSJun Zhang //
75111286fSJun Zhang //===----------------------------------------------------------------------===//
85111286fSJun Zhang //
95111286fSJun Zhang // This file implements some common utils used in the incremental library.
105111286fSJun Zhang //
115111286fSJun Zhang //===----------------------------------------------------------------------===//
125111286fSJun Zhang 
135111286fSJun Zhang #include "InterpreterUtils.h"
145111286fSJun Zhang 
155111286fSJun Zhang namespace clang {
165111286fSJun Zhang 
IntegerLiteralExpr(ASTContext & C,uint64_t Val)175111286fSJun Zhang IntegerLiteral *IntegerLiteralExpr(ASTContext &C, uint64_t Val) {
185111286fSJun Zhang   return IntegerLiteral::Create(C, llvm::APSInt::getUnsigned(Val),
195111286fSJun Zhang                                 C.UnsignedLongLongTy, SourceLocation());
205111286fSJun Zhang }
215111286fSJun Zhang 
CStyleCastPtrExpr(Sema & S,QualType Ty,Expr * E)225111286fSJun Zhang Expr *CStyleCastPtrExpr(Sema &S, QualType Ty, Expr *E) {
235111286fSJun Zhang   ASTContext &Ctx = S.getASTContext();
245111286fSJun Zhang   if (!Ty->isPointerType())
255111286fSJun Zhang     Ty = Ctx.getPointerType(Ty);
265111286fSJun Zhang 
275111286fSJun Zhang   TypeSourceInfo *TSI = Ctx.getTrivialTypeSourceInfo(Ty, SourceLocation());
285111286fSJun Zhang   Expr *Result =
295111286fSJun Zhang       S.BuildCStyleCastExpr(SourceLocation(), TSI, SourceLocation(), E).get();
305111286fSJun Zhang   assert(Result && "Cannot create CStyleCastPtrExpr");
315111286fSJun Zhang   return Result;
325111286fSJun Zhang }
335111286fSJun Zhang 
CStyleCastPtrExpr(Sema & S,QualType Ty,uintptr_t Ptr)345111286fSJun Zhang Expr *CStyleCastPtrExpr(Sema &S, QualType Ty, uintptr_t Ptr) {
355111286fSJun Zhang   ASTContext &Ctx = S.getASTContext();
365111286fSJun Zhang   return CStyleCastPtrExpr(S, Ty, IntegerLiteralExpr(Ctx, (uint64_t)Ptr));
375111286fSJun Zhang }
385111286fSJun Zhang 
CreateDGPtrFrom(Sema & S,Decl * D)395111286fSJun Zhang Sema::DeclGroupPtrTy CreateDGPtrFrom(Sema &S, Decl *D) {
405111286fSJun Zhang   SmallVector<Decl *, 1> DeclsInGroup;
415111286fSJun Zhang   DeclsInGroup.push_back(D);
425111286fSJun Zhang   Sema::DeclGroupPtrTy DeclGroupPtr = S.BuildDeclaratorGroup(DeclsInGroup);
435111286fSJun Zhang   return DeclGroupPtr;
445111286fSJun Zhang }
455111286fSJun Zhang 
LookupNamespace(Sema & S,llvm::StringRef Name,const DeclContext * Within)465111286fSJun Zhang NamespaceDecl *LookupNamespace(Sema &S, llvm::StringRef Name,
475111286fSJun Zhang                                const DeclContext *Within) {
485111286fSJun Zhang   DeclarationName DName = &S.Context.Idents.get(Name);
495111286fSJun Zhang   LookupResult R(S, DName, SourceLocation(),
505111286fSJun Zhang                  Sema::LookupNestedNameSpecifierName);
515111286fSJun Zhang   R.suppressDiagnostics();
525111286fSJun Zhang   if (!Within)
535111286fSJun Zhang     S.LookupName(R, S.TUScope);
545111286fSJun Zhang   else {
555111286fSJun Zhang     if (const auto *TD = dyn_cast<clang::TagDecl>(Within);
565111286fSJun Zhang         TD && !TD->getDefinition())
575111286fSJun Zhang       // No definition, no lookup result.
585111286fSJun Zhang       return nullptr;
595111286fSJun Zhang 
605111286fSJun Zhang     S.LookupQualifiedName(R, const_cast<DeclContext *>(Within));
615111286fSJun Zhang   }
625111286fSJun Zhang 
635111286fSJun Zhang   if (R.empty())
645111286fSJun Zhang     return nullptr;
655111286fSJun Zhang 
665111286fSJun Zhang   R.resolveKind();
675111286fSJun Zhang 
685111286fSJun Zhang   return dyn_cast<NamespaceDecl>(R.getFoundDecl());
695111286fSJun Zhang }
705111286fSJun Zhang 
LookupNamed(Sema & S,llvm::StringRef Name,const DeclContext * Within)715111286fSJun Zhang NamedDecl *LookupNamed(Sema &S, llvm::StringRef Name,
725111286fSJun Zhang                        const DeclContext *Within) {
735111286fSJun Zhang   DeclarationName DName = &S.Context.Idents.get(Name);
745111286fSJun Zhang   LookupResult R(S, DName, SourceLocation(), Sema::LookupOrdinaryName,
75*458328aeSVlad Serebrennikov                  RedeclarationKind::ForVisibleRedeclaration);
765111286fSJun Zhang 
775111286fSJun Zhang   R.suppressDiagnostics();
785111286fSJun Zhang 
795111286fSJun Zhang   if (!Within)
805111286fSJun Zhang     S.LookupName(R, S.TUScope);
815111286fSJun Zhang   else {
825111286fSJun Zhang     const DeclContext *PrimaryWithin = nullptr;
835111286fSJun Zhang     if (const auto *TD = dyn_cast<TagDecl>(Within))
845111286fSJun Zhang       PrimaryWithin = llvm::dyn_cast_or_null<DeclContext>(TD->getDefinition());
855111286fSJun Zhang     else
865111286fSJun Zhang       PrimaryWithin = Within->getPrimaryContext();
875111286fSJun Zhang 
885111286fSJun Zhang     // No definition, no lookup result.
895111286fSJun Zhang     if (!PrimaryWithin)
905111286fSJun Zhang       return nullptr;
915111286fSJun Zhang 
925111286fSJun Zhang     S.LookupQualifiedName(R, const_cast<DeclContext *>(PrimaryWithin));
935111286fSJun Zhang   }
945111286fSJun Zhang 
955111286fSJun Zhang   if (R.empty())
965111286fSJun Zhang     return nullptr;
975111286fSJun Zhang   R.resolveKind();
985111286fSJun Zhang 
995111286fSJun Zhang   if (R.isSingleResult())
1005111286fSJun Zhang     return llvm::dyn_cast<NamedDecl>(R.getFoundDecl());
1015111286fSJun Zhang 
1025111286fSJun Zhang   return nullptr;
1035111286fSJun Zhang }
1045111286fSJun Zhang 
GetFullTypeName(ASTContext & Ctx,QualType QT)1055111286fSJun Zhang std::string GetFullTypeName(ASTContext &Ctx, QualType QT) {
1065111286fSJun Zhang   PrintingPolicy Policy(Ctx.getPrintingPolicy());
1075111286fSJun Zhang   Policy.SuppressScope = false;
1085111286fSJun Zhang   Policy.AnonymousTagLocations = false;
1095111286fSJun Zhang   return QT.getAsString(Policy);
1105111286fSJun Zhang }
1115111286fSJun Zhang } // namespace clang
112