48#include "llvm/ADT/ArrayRef.h"
49#include "llvm/ADT/STLExtras.h"
50#include "llvm/ADT/StringExtras.h"
51#include "llvm/ADT/StringRef.h"
52#include "llvm/Support/Compiler.h"
53#include "llvm/Support/ErrorHandling.h"
54#include "llvm/Support/raw_ostream.h"
67 class StmtPrinter :
public StmtVisitor<StmtPrinter> {
70 PrinterHelper* Helper;
71 PrintingPolicy Policy;
73 const ASTContext *Context;
76 StmtPrinter(raw_ostream &os, PrinterHelper *helper,
77 const PrintingPolicy &Policy,
unsigned Indentation = 0,
78 StringRef NL =
"\n",
const ASTContext *Context =
nullptr)
79 : OS(os), IndentLevel(Indentation), Helper(helper), Policy(Policy),
80 NL(NL), Context(Context) {}
82 void PrintStmt(Stmt *S) { PrintStmt(S, Policy.Indentation); }
84 void PrintStmt(Stmt *S,
int SubIndent) {
85 IndentLevel += SubIndent;
86 if (isa_and_nonnull<Expr>(S)) {
94 Indent() <<
"<<<NULL STATEMENT>>>" << NL;
96 IndentLevel -= SubIndent;
99 void PrintInitStmt(Stmt *S,
unsigned PrefixWidth) {
101 IndentLevel += (PrefixWidth + 1) / 2;
102 if (
auto *DS = dyn_cast<DeclStmt>(S))
103 PrintRawDeclStmt(DS);
107 IndentLevel -= (PrefixWidth + 1) / 2;
110 void PrintControlledStmt(Stmt *S) {
111 if (
auto *CS = dyn_cast<CompoundStmt>(S)) {
113 PrintRawCompoundStmt(CS);
122 void PrintRawDecl(Decl *D);
123 void PrintRawDeclStmt(
const DeclStmt *S);
124 void PrintRawIfStmt(IfStmt *
If);
125 void PrintRawCXXCatchStmt(CXXCatchStmt *Catch);
126 void PrintCallArgs(CallExpr *E);
127 void PrintRawSEHExceptHandler(SEHExceptStmt *S);
128 void PrintRawSEHFinallyStmt(SEHFinallyStmt *S);
129 void PrintOMPExecutableDirective(OMPExecutableDirective *S,
130 bool ForceNoStmt =
false);
132 void PrintOpenACCClauseList(OpenACCConstructStmt *S);
133 void PrintOpenACCConstruct(OpenACCConstructStmt *S);
135 void PrintExpr(Expr *E) {
142 raw_ostream &
Indent(
int Delta = 0) {
143 for (
int i = 0, e = IndentLevel+Delta; i < e; ++i)
148 void Visit(Stmt* S) {
149 if (Helper && Helper->handledStmt(S,OS))
151 else StmtVisitor<StmtPrinter>::Visit(S);
154 void VisitStmt(Stmt *Node) LLVM_ATTRIBUTE_UNUSED {
155 Indent() <<
"<<unknown stmt type>>" << NL;
158 void VisitExpr(Expr *Node) LLVM_ATTRIBUTE_UNUSED {
159 OS <<
"<<unknown expr type>>";
162 void VisitCXXNamedCastExpr(CXXNamedCastExpr *Node);
164#define ABSTRACT_STMT(CLASS)
165#define STMT(CLASS, PARENT) \
166 void Visit##CLASS(CLASS *Node);
167#include "clang/AST/StmtNodes.inc"
178void StmtPrinter::PrintRawCompoundStmt(
CompoundStmt *Node) {
179 assert(Node &&
"Compound statement cannot be null");
181 PrintFPPragmas(Node);
182 for (
auto *I : Node->
body())
192 bool FEnvAccess =
false;
193 if (FPO.hasAllowFEnvAccessOverride()) {
194 FEnvAccess = FPO.getAllowFEnvAccessOverride();
195 Indent() <<
"#pragma STDC FENV_ACCESS " << (FEnvAccess ?
"ON" :
"OFF")
198 if (FPO.hasSpecifiedExceptionModeOverride()) {
199 LangOptions::FPExceptionModeKind EM =
200 FPO.getSpecifiedExceptionModeOverride();
201 if (!FEnvAccess || EM != LangOptions::FPE_Strict) {
202 Indent() <<
"#pragma clang fp exceptions(";
203 switch (FPO.getSpecifiedExceptionModeOverride()) {
206 case LangOptions::FPE_Ignore:
209 case LangOptions::FPE_MayTrap:
212 case LangOptions::FPE_Strict:
219 if (FPO.hasConstRoundingModeOverride()) {
220 LangOptions::RoundingMode RM = FPO.getConstRoundingModeOverride();
221 Indent() <<
"#pragma STDC FENV_ROUND ";
223 case llvm::RoundingMode::TowardZero:
224 OS <<
"FE_TOWARDZERO";
226 case llvm::RoundingMode::NearestTiesToEven:
227 OS <<
"FE_TONEAREST";
229 case llvm::RoundingMode::TowardPositive:
232 case llvm::RoundingMode::TowardNegative:
235 case llvm::RoundingMode::NearestTiesToAway:
236 OS <<
"FE_TONEARESTFROMZERO";
238 case llvm::RoundingMode::Dynamic:
242 llvm_unreachable(
"Invalid rounding mode");
248void StmtPrinter::PrintRawDecl(Decl *D) {
252void StmtPrinter::PrintRawDeclStmt(
const DeclStmt *S) {
253 SmallVector<Decl *, 2> Decls(S->
decls());
257void StmtPrinter::VisitNullStmt(NullStmt *Node) {
261void StmtPrinter::VisitDeclStmt(DeclStmt *Node) {
263 PrintRawDeclStmt(Node);
271void StmtPrinter::VisitCompoundStmt(
CompoundStmt *Node) {
273 PrintRawCompoundStmt(Node);
277void StmtPrinter::VisitCaseStmt(CaseStmt *Node) {
279 PrintExpr(Node->
getLHS());
282 PrintExpr(Node->
getRHS());
289void StmtPrinter::VisitDefaultStmt(DefaultStmt *Node) {
290 Indent(-1) <<
"default:" << NL;
294void StmtPrinter::VisitLabelStmt(LabelStmt *Node) {
299void StmtPrinter::VisitAttributedStmt(AttributedStmt *Node) {
300 ArrayRef<const Attr *> Attrs = Node->
getAttrs();
301 for (
const auto *Attr : Attrs) {
302 Attr->printPretty(OS, Policy);
303 if (Attr != Attrs.back())
310void StmtPrinter::PrintRawIfStmt(IfStmt *
If) {
311 if (
If->isConsteval()) {
313 if (
If->isNegatedConsteval())
317 PrintStmt(
If->getThen());
318 if (Stmt *Else =
If->getElse()) {
329 PrintInitStmt(
If->getInit(), 4);
330 if (
const DeclStmt *DS =
If->getConditionVariableDeclStmt())
331 PrintRawDeclStmt(DS);
333 PrintExpr(
If->getCond());
336 if (
auto *CS = dyn_cast<CompoundStmt>(
If->getThen())) {
338 PrintRawCompoundStmt(CS);
339 OS << (
If->getElse() ?
" " : NL);
342 PrintStmt(
If->getThen());
346 if (Stmt *Else =
If->getElse()) {
349 if (
auto *CS = dyn_cast<CompoundStmt>(Else)) {
351 PrintRawCompoundStmt(CS);
353 }
else if (
auto *ElseIf = dyn_cast<IfStmt>(Else)) {
355 PrintRawIfStmt(ElseIf);
358 PrintStmt(
If->getElse());
363void StmtPrinter::VisitIfStmt(IfStmt *
If) {
368void StmtPrinter::VisitSwitchStmt(SwitchStmt *Node) {
371 PrintInitStmt(Node->
getInit(), 8);
373 PrintRawDeclStmt(DS);
377 PrintControlledStmt(Node->
getBody());
380void StmtPrinter::VisitWhileStmt(WhileStmt *Node) {
383 PrintRawDeclStmt(DS);
390void StmtPrinter::VisitDoStmt(DoStmt *Node) {
392 if (
auto *CS = dyn_cast<CompoundStmt>(Node->
getBody())) {
393 PrintRawCompoundStmt(CS);
406void StmtPrinter::VisitForStmt(ForStmt *Node) {
409 PrintInitStmt(Node->
getInit(), 5);
413 PrintRawDeclStmt(DS);
419 PrintExpr(Node->
getInc());
422 PrintControlledStmt(Node->
getBody());
425void StmtPrinter::VisitObjCForCollectionStmt(ObjCForCollectionStmt *Node) {
427 if (
auto *DS = dyn_cast<DeclStmt>(Node->
getElement()))
428 PrintRawDeclStmt(DS);
434 PrintControlledStmt(Node->
getBody());
437void StmtPrinter::VisitCXXForRangeStmt(CXXForRangeStmt *Node) {
440 PrintInitStmt(Node->
getInit(), 5);
441 PrintingPolicy SubPolicy(Policy);
442 SubPolicy.SuppressInitializers =
true;
447 PrintControlledStmt(Node->
getBody());
450void StmtPrinter::VisitMSDependentExistsStmt(MSDependentExistsStmt *Node) {
453 OS <<
"__if_exists (";
455 OS <<
"__if_not_exists (";
463void StmtPrinter::VisitGotoStmt(GotoStmt *Node) {
468void StmtPrinter::VisitIndirectGotoStmt(IndirectGotoStmt *Node) {
475void StmtPrinter::VisitContinueStmt(ContinueStmt *Node) {
485void StmtPrinter::VisitBreakStmt(BreakStmt *Node) {
494void StmtPrinter::VisitReturnStmt(ReturnStmt *Node) {
504void StmtPrinter::VisitGCCAsmStmt(GCCAsmStmt *Node) {
521 for (
unsigned i = 0, e = Node->
getNumOutputs(); i != e; ++i) {
542 for (
unsigned i = 0, e = Node->
getNumInputs(); i != e; ++i) {
573 for (
unsigned i = 0, e = Node->
getNumLabels(); i != e; ++i) {
583void StmtPrinter::VisitMSAsmStmt(MSAsmStmt *Node) {
593void StmtPrinter::VisitCapturedStmt(CapturedStmt *Node) {
597void StmtPrinter::VisitSYCLKernelCallStmt(SYCLKernelCallStmt *Node) {
601void StmtPrinter::VisitObjCAtTryStmt(ObjCAtTryStmt *Node) {
603 if (
auto *TS = dyn_cast<CompoundStmt>(Node->
getTryBody())) {
604 PrintRawCompoundStmt(TS);
608 for (ObjCAtCatchStmt *catchStmt : Node->
catch_stmts()) {
610 if (Decl *DS = catchStmt->getCatchParamDecl())
613 if (
auto *CS = dyn_cast<CompoundStmt>(catchStmt->getCatchBody())) {
614 PrintRawCompoundStmt(CS);
621 if (
auto *CS = dyn_cast<CompoundStmt>(FS->getFinallyBody())) {
622 PrintRawCompoundStmt(CS);
628void StmtPrinter::VisitObjCAtFinallyStmt(ObjCAtFinallyStmt *Node) {
631void StmtPrinter::VisitObjCAtCatchStmt (ObjCAtCatchStmt *Node) {
632 Indent() <<
"@catch (...) { /* todo */ } " << NL;
635void StmtPrinter::VisitObjCAtThrowStmt(ObjCAtThrowStmt *Node) {
644void StmtPrinter::VisitObjCAvailabilityCheckExpr(
645 ObjCAvailabilityCheckExpr *Node) {
646 OS <<
"@available(...)";
649void StmtPrinter::VisitObjCAtSynchronizedStmt(ObjCAtSynchronizedStmt *Node) {
650 Indent() <<
"@synchronized (";
657void StmtPrinter::VisitObjCAutoreleasePoolStmt(ObjCAutoreleasePoolStmt *Node) {
658 Indent() <<
"@autoreleasepool";
663void StmtPrinter::PrintRawCXXCatchStmt(CXXCatchStmt *Node) {
666 PrintRawDecl(ExDecl);
673void StmtPrinter::VisitCXXCatchStmt(CXXCatchStmt *Node) {
675 PrintRawCXXCatchStmt(Node);
679void StmtPrinter::VisitCXXTryStmt(CXXTryStmt *Node) {
689void StmtPrinter::VisitSEHTryStmt(SEHTryStmt *Node) {
695 PrintRawSEHExceptHandler(E);
697 assert(F &&
"Must have a finally block...");
698 PrintRawSEHFinallyStmt(F);
703void StmtPrinter::PrintRawSEHFinallyStmt(SEHFinallyStmt *Node) {
705 PrintRawCompoundStmt(Node->
getBlock());
709void StmtPrinter::PrintRawSEHExceptHandler(SEHExceptStmt *Node) {
713 PrintRawCompoundStmt(Node->
getBlock());
717void StmtPrinter::VisitSEHExceptStmt(SEHExceptStmt *Node) {
719 PrintRawSEHExceptHandler(Node);
723void StmtPrinter::VisitSEHFinallyStmt(SEHFinallyStmt *Node) {
725 PrintRawSEHFinallyStmt(Node);
729void StmtPrinter::VisitSEHLeaveStmt(SEHLeaveStmt *Node) {
738void StmtPrinter::VisitOMPCanonicalLoop(OMPCanonicalLoop *Node) {
739 PrintStmt(Node->getLoopStmt());
742void StmtPrinter::PrintOMPExecutableDirective(OMPExecutableDirective *S,
744 unsigned OpenMPVersion =
745 Context ? Context->
getLangOpts().OpenMP : llvm::omp::FallbackVersion;
746 OMPClausePrinter Printer(OS, Policy, OpenMPVersion);
747 ArrayRef<OMPClause *> Clauses = S->clauses();
748 for (
auto *Clause : Clauses)
749 if (Clause && !Clause->isImplicit()) {
751 Printer.Visit(Clause);
754 if (!ForceNoStmt && S->hasAssociatedStmt())
755 PrintStmt(S->getRawStmt());
758void StmtPrinter::VisitOMPMetaDirective(OMPMetaDirective *Node) {
759 Indent() <<
"#pragma omp metadirective";
760 PrintOMPExecutableDirective(Node);
763void StmtPrinter::VisitOMPParallelDirective(OMPParallelDirective *Node) {
764 Indent() <<
"#pragma omp parallel";
765 PrintOMPExecutableDirective(Node);
768void StmtPrinter::VisitOMPSimdDirective(OMPSimdDirective *Node) {
769 Indent() <<
"#pragma omp simd";
770 PrintOMPExecutableDirective(Node);
773void StmtPrinter::VisitOMPTileDirective(OMPTileDirective *Node) {
774 Indent() <<
"#pragma omp tile";
775 PrintOMPExecutableDirective(Node);
778void StmtPrinter::VisitOMPStripeDirective(OMPStripeDirective *Node) {
779 Indent() <<
"#pragma omp stripe";
780 PrintOMPExecutableDirective(Node);
783void StmtPrinter::VisitOMPUnrollDirective(OMPUnrollDirective *Node) {
784 Indent() <<
"#pragma omp unroll";
785 PrintOMPExecutableDirective(Node);
788void StmtPrinter::VisitOMPReverseDirective(OMPReverseDirective *Node) {
789 Indent() <<
"#pragma omp reverse";
790 PrintOMPExecutableDirective(Node);
793void StmtPrinter::VisitOMPInterchangeDirective(OMPInterchangeDirective *Node) {
794 Indent() <<
"#pragma omp interchange";
795 PrintOMPExecutableDirective(Node);
798void StmtPrinter::VisitOMPForDirective(OMPForDirective *Node) {
799 Indent() <<
"#pragma omp for";
800 PrintOMPExecutableDirective(Node);
803void StmtPrinter::VisitOMPForSimdDirective(OMPForSimdDirective *Node) {
804 Indent() <<
"#pragma omp for simd";
805 PrintOMPExecutableDirective(Node);
808void StmtPrinter::VisitOMPSectionsDirective(OMPSectionsDirective *Node) {
809 Indent() <<
"#pragma omp sections";
810 PrintOMPExecutableDirective(Node);
813void StmtPrinter::VisitOMPSectionDirective(OMPSectionDirective *Node) {
814 Indent() <<
"#pragma omp section";
815 PrintOMPExecutableDirective(Node);
818void StmtPrinter::VisitOMPScopeDirective(OMPScopeDirective *Node) {
819 Indent() <<
"#pragma omp scope";
820 PrintOMPExecutableDirective(Node);
823void StmtPrinter::VisitOMPSingleDirective(OMPSingleDirective *Node) {
824 Indent() <<
"#pragma omp single";
825 PrintOMPExecutableDirective(Node);
828void StmtPrinter::VisitOMPMasterDirective(OMPMasterDirective *Node) {
829 Indent() <<
"#pragma omp master";
830 PrintOMPExecutableDirective(Node);
833void StmtPrinter::VisitOMPCriticalDirective(OMPCriticalDirective *Node) {
834 Indent() <<
"#pragma omp critical";
835 if (Node->getDirectiveName().getName()) {
837 Node->getDirectiveName().printName(OS, Policy);
840 PrintOMPExecutableDirective(Node);
843void StmtPrinter::VisitOMPParallelForDirective(OMPParallelForDirective *Node) {
844 Indent() <<
"#pragma omp parallel for";
845 PrintOMPExecutableDirective(Node);
848void StmtPrinter::VisitOMPParallelForSimdDirective(
849 OMPParallelForSimdDirective *Node) {
850 Indent() <<
"#pragma omp parallel for simd";
851 PrintOMPExecutableDirective(Node);
854void StmtPrinter::VisitOMPParallelMasterDirective(
855 OMPParallelMasterDirective *Node) {
856 Indent() <<
"#pragma omp parallel master";
857 PrintOMPExecutableDirective(Node);
860void StmtPrinter::VisitOMPParallelMaskedDirective(
861 OMPParallelMaskedDirective *Node) {
862 Indent() <<
"#pragma omp parallel masked";
863 PrintOMPExecutableDirective(Node);
866void StmtPrinter::VisitOMPParallelSectionsDirective(
867 OMPParallelSectionsDirective *Node) {
868 Indent() <<
"#pragma omp parallel sections";
869 PrintOMPExecutableDirective(Node);
872void StmtPrinter::VisitOMPTaskDirective(OMPTaskDirective *Node) {
873 Indent() <<
"#pragma omp task";
874 PrintOMPExecutableDirective(Node);
877void StmtPrinter::VisitOMPTaskyieldDirective(OMPTaskyieldDirective *Node) {
878 Indent() <<
"#pragma omp taskyield";
879 PrintOMPExecutableDirective(Node);
882void StmtPrinter::VisitOMPBarrierDirective(OMPBarrierDirective *Node) {
883 Indent() <<
"#pragma omp barrier";
884 PrintOMPExecutableDirective(Node);
887void StmtPrinter::VisitOMPTaskwaitDirective(OMPTaskwaitDirective *Node) {
888 Indent() <<
"#pragma omp taskwait";
889 PrintOMPExecutableDirective(Node);
892void StmtPrinter::VisitOMPAssumeDirective(OMPAssumeDirective *Node) {
893 Indent() <<
"#pragma omp assume";
894 PrintOMPExecutableDirective(Node);
897void StmtPrinter::VisitOMPErrorDirective(OMPErrorDirective *Node) {
898 Indent() <<
"#pragma omp error";
899 PrintOMPExecutableDirective(Node);
902void StmtPrinter::VisitOMPTaskgroupDirective(OMPTaskgroupDirective *Node) {
903 Indent() <<
"#pragma omp taskgroup";
904 PrintOMPExecutableDirective(Node);
907void StmtPrinter::VisitOMPFlushDirective(OMPFlushDirective *Node) {
908 Indent() <<
"#pragma omp flush";
909 PrintOMPExecutableDirective(Node);
912void StmtPrinter::VisitOMPDepobjDirective(OMPDepobjDirective *Node) {
913 Indent() <<
"#pragma omp depobj";
914 PrintOMPExecutableDirective(Node);
917void StmtPrinter::VisitOMPScanDirective(OMPScanDirective *Node) {
918 Indent() <<
"#pragma omp scan";
919 PrintOMPExecutableDirective(Node);
922void StmtPrinter::VisitOMPOrderedDirective(OMPOrderedDirective *Node) {
923 Indent() <<
"#pragma omp ordered";
924 PrintOMPExecutableDirective(Node, Node->hasClausesOfKind<OMPDependClause>());
927void StmtPrinter::VisitOMPAtomicDirective(OMPAtomicDirective *Node) {
928 Indent() <<
"#pragma omp atomic";
929 PrintOMPExecutableDirective(Node);
932void StmtPrinter::VisitOMPTargetDirective(OMPTargetDirective *Node) {
933 Indent() <<
"#pragma omp target";
934 PrintOMPExecutableDirective(Node);
937void StmtPrinter::VisitOMPTargetDataDirective(OMPTargetDataDirective *Node) {
938 Indent() <<
"#pragma omp target data";
939 PrintOMPExecutableDirective(Node);
942void StmtPrinter::VisitOMPTargetEnterDataDirective(
943 OMPTargetEnterDataDirective *Node) {
944 Indent() <<
"#pragma omp target enter data";
945 PrintOMPExecutableDirective(Node,
true);
948void StmtPrinter::VisitOMPTargetExitDataDirective(
949 OMPTargetExitDataDirective *Node) {
950 Indent() <<
"#pragma omp target exit data";
951 PrintOMPExecutableDirective(Node,
true);
954void StmtPrinter::VisitOMPTargetParallelDirective(
955 OMPTargetParallelDirective *Node) {
956 Indent() <<
"#pragma omp target parallel";
957 PrintOMPExecutableDirective(Node);
960void StmtPrinter::VisitOMPTargetParallelForDirective(
961 OMPTargetParallelForDirective *Node) {
962 Indent() <<
"#pragma omp target parallel for";
963 PrintOMPExecutableDirective(Node);
966void StmtPrinter::VisitOMPTeamsDirective(OMPTeamsDirective *Node) {
967 Indent() <<
"#pragma omp teams";
968 PrintOMPExecutableDirective(Node);
971void StmtPrinter::VisitOMPCancellationPointDirective(
972 OMPCancellationPointDirective *Node) {
973 unsigned OpenMPVersion =
974 Context ? Context->
getLangOpts().OpenMP : llvm::omp::FallbackVersion;
975 Indent() <<
"#pragma omp cancellation point "
977 PrintOMPExecutableDirective(Node);
980void StmtPrinter::VisitOMPCancelDirective(OMPCancelDirective *Node) {
981 unsigned OpenMPVersion =
982 Context ? Context->
getLangOpts().OpenMP : llvm::omp::FallbackVersion;
983 Indent() <<
"#pragma omp cancel "
985 PrintOMPExecutableDirective(Node);
988void StmtPrinter::VisitOMPTaskLoopDirective(OMPTaskLoopDirective *Node) {
989 Indent() <<
"#pragma omp taskloop";
990 PrintOMPExecutableDirective(Node);
993void StmtPrinter::VisitOMPTaskLoopSimdDirective(
994 OMPTaskLoopSimdDirective *Node) {
995 Indent() <<
"#pragma omp taskloop simd";
996 PrintOMPExecutableDirective(Node);
999void StmtPrinter::VisitOMPMasterTaskLoopDirective(
1000 OMPMasterTaskLoopDirective *Node) {
1001 Indent() <<
"#pragma omp master taskloop";
1002 PrintOMPExecutableDirective(Node);
1005void StmtPrinter::VisitOMPMaskedTaskLoopDirective(
1006 OMPMaskedTaskLoopDirective *Node) {
1007 Indent() <<
"#pragma omp masked taskloop";
1008 PrintOMPExecutableDirective(Node);
1011void StmtPrinter::VisitOMPMasterTaskLoopSimdDirective(
1012 OMPMasterTaskLoopSimdDirective *Node) {
1013 Indent() <<
"#pragma omp master taskloop simd";
1014 PrintOMPExecutableDirective(Node);
1017void StmtPrinter::VisitOMPMaskedTaskLoopSimdDirective(
1018 OMPMaskedTaskLoopSimdDirective *Node) {
1019 Indent() <<
"#pragma omp masked taskloop simd";
1020 PrintOMPExecutableDirective(Node);
1023void StmtPrinter::VisitOMPParallelMasterTaskLoopDirective(
1024 OMPParallelMasterTaskLoopDirective *Node) {
1025 Indent() <<
"#pragma omp parallel master taskloop";
1026 PrintOMPExecutableDirective(Node);
1029void StmtPrinter::VisitOMPParallelMaskedTaskLoopDirective(
1030 OMPParallelMaskedTaskLoopDirective *Node) {
1031 Indent() <<
"#pragma omp parallel masked taskloop";
1032 PrintOMPExecutableDirective(Node);
1035void StmtPrinter::VisitOMPParallelMasterTaskLoopSimdDirective(
1036 OMPParallelMasterTaskLoopSimdDirective *Node) {
1037 Indent() <<
"#pragma omp parallel master taskloop simd";
1038 PrintOMPExecutableDirective(Node);
1041void StmtPrinter::VisitOMPParallelMaskedTaskLoopSimdDirective(
1042 OMPParallelMaskedTaskLoopSimdDirective *Node) {
1043 Indent() <<
"#pragma omp parallel masked taskloop simd";
1044 PrintOMPExecutableDirective(Node);
1047void StmtPrinter::VisitOMPDistributeDirective(OMPDistributeDirective *Node) {
1048 Indent() <<
"#pragma omp distribute";
1049 PrintOMPExecutableDirective(Node);
1052void StmtPrinter::VisitOMPTargetUpdateDirective(
1053 OMPTargetUpdateDirective *Node) {
1054 Indent() <<
"#pragma omp target update";
1055 PrintOMPExecutableDirective(Node,
true);
1058void StmtPrinter::VisitOMPDistributeParallelForDirective(
1059 OMPDistributeParallelForDirective *Node) {
1060 Indent() <<
"#pragma omp distribute parallel for";
1061 PrintOMPExecutableDirective(Node);
1064void StmtPrinter::VisitOMPDistributeParallelForSimdDirective(
1065 OMPDistributeParallelForSimdDirective *Node) {
1066 Indent() <<
"#pragma omp distribute parallel for simd";
1067 PrintOMPExecutableDirective(Node);
1070void StmtPrinter::VisitOMPDistributeSimdDirective(
1071 OMPDistributeSimdDirective *Node) {
1072 Indent() <<
"#pragma omp distribute simd";
1073 PrintOMPExecutableDirective(Node);
1076void StmtPrinter::VisitOMPTargetParallelForSimdDirective(
1077 OMPTargetParallelForSimdDirective *Node) {
1078 Indent() <<
"#pragma omp target parallel for simd";
1079 PrintOMPExecutableDirective(Node);
1082void StmtPrinter::VisitOMPTargetSimdDirective(OMPTargetSimdDirective *Node) {
1083 Indent() <<
"#pragma omp target simd";
1084 PrintOMPExecutableDirective(Node);
1087void StmtPrinter::VisitOMPTeamsDistributeDirective(
1088 OMPTeamsDistributeDirective *Node) {
1089 Indent() <<
"#pragma omp teams distribute";
1090 PrintOMPExecutableDirective(Node);
1093void StmtPrinter::VisitOMPTeamsDistributeSimdDirective(
1094 OMPTeamsDistributeSimdDirective *Node) {
1095 Indent() <<
"#pragma omp teams distribute simd";
1096 PrintOMPExecutableDirective(Node);
1099void StmtPrinter::VisitOMPTeamsDistributeParallelForSimdDirective(
1100 OMPTeamsDistributeParallelForSimdDirective *Node) {
1101 Indent() <<
"#pragma omp teams distribute parallel for simd";
1102 PrintOMPExecutableDirective(Node);
1105void StmtPrinter::VisitOMPTeamsDistributeParallelForDirective(
1106 OMPTeamsDistributeParallelForDirective *Node) {
1107 Indent() <<
"#pragma omp teams distribute parallel for";
1108 PrintOMPExecutableDirective(Node);
1111void StmtPrinter::VisitOMPTargetTeamsDirective(OMPTargetTeamsDirective *Node) {
1112 Indent() <<
"#pragma omp target teams";
1113 PrintOMPExecutableDirective(Node);
1116void StmtPrinter::VisitOMPTargetTeamsDistributeDirective(
1117 OMPTargetTeamsDistributeDirective *Node) {
1118 Indent() <<
"#pragma omp target teams distribute";
1119 PrintOMPExecutableDirective(Node);
1122void StmtPrinter::VisitOMPTargetTeamsDistributeParallelForDirective(
1123 OMPTargetTeamsDistributeParallelForDirective *Node) {
1124 Indent() <<
"#pragma omp target teams distribute parallel for";
1125 PrintOMPExecutableDirective(Node);
1128void StmtPrinter::VisitOMPTargetTeamsDistributeParallelForSimdDirective(
1129 OMPTargetTeamsDistributeParallelForSimdDirective *Node) {
1130 Indent() <<
"#pragma omp target teams distribute parallel for simd";
1131 PrintOMPExecutableDirective(Node);
1134void StmtPrinter::VisitOMPTargetTeamsDistributeSimdDirective(
1135 OMPTargetTeamsDistributeSimdDirective *Node) {
1136 Indent() <<
"#pragma omp target teams distribute simd";
1137 PrintOMPExecutableDirective(Node);
1140void StmtPrinter::VisitOMPInteropDirective(OMPInteropDirective *Node) {
1141 Indent() <<
"#pragma omp interop";
1142 PrintOMPExecutableDirective(Node);
1145void StmtPrinter::VisitOMPDispatchDirective(OMPDispatchDirective *Node) {
1146 Indent() <<
"#pragma omp dispatch";
1147 PrintOMPExecutableDirective(Node);
1150void StmtPrinter::VisitOMPMaskedDirective(OMPMaskedDirective *Node) {
1151 Indent() <<
"#pragma omp masked";
1152 PrintOMPExecutableDirective(Node);
1155void StmtPrinter::VisitOMPGenericLoopDirective(OMPGenericLoopDirective *Node) {
1156 Indent() <<
"#pragma omp loop";
1157 PrintOMPExecutableDirective(Node);
1160void StmtPrinter::VisitOMPTeamsGenericLoopDirective(
1161 OMPTeamsGenericLoopDirective *Node) {
1162 Indent() <<
"#pragma omp teams loop";
1163 PrintOMPExecutableDirective(Node);
1166void StmtPrinter::VisitOMPTargetTeamsGenericLoopDirective(
1167 OMPTargetTeamsGenericLoopDirective *Node) {
1168 Indent() <<
"#pragma omp target teams loop";
1169 PrintOMPExecutableDirective(Node);
1172void StmtPrinter::VisitOMPParallelGenericLoopDirective(
1173 OMPParallelGenericLoopDirective *Node) {
1174 Indent() <<
"#pragma omp parallel loop";
1175 PrintOMPExecutableDirective(Node);
1178void StmtPrinter::VisitOMPTargetParallelGenericLoopDirective(
1179 OMPTargetParallelGenericLoopDirective *Node) {
1180 Indent() <<
"#pragma omp target parallel loop";
1181 PrintOMPExecutableDirective(Node);
1187void StmtPrinter::PrintOpenACCClauseList(OpenACCConstructStmt *S) {
1190 OpenACCClausePrinter Printer(OS, Policy);
1191 Printer.VisitClauseList(S->
clauses());
1194void StmtPrinter::PrintOpenACCConstruct(OpenACCConstructStmt *S) {
1196 PrintOpenACCClauseList(S);
1200 PrintOpenACCConstruct(S);
1201 PrintStmt(S->getStructuredBlock());
1204void StmtPrinter::VisitOpenACCLoopConstruct(OpenACCLoopConstruct *S) {
1205 PrintOpenACCConstruct(S);
1209void StmtPrinter::VisitOpenACCCombinedConstruct(OpenACCCombinedConstruct *S) {
1210 PrintOpenACCConstruct(S);
1214void StmtPrinter::VisitOpenACCDataConstruct(OpenACCDataConstruct *S) {
1215 PrintOpenACCConstruct(S);
1218void StmtPrinter::VisitOpenACCHostDataConstruct(OpenACCHostDataConstruct *S) {
1219 PrintOpenACCConstruct(S);
1222void StmtPrinter::VisitOpenACCEnterDataConstruct(OpenACCEnterDataConstruct *S) {
1223 PrintOpenACCConstruct(S);
1225void StmtPrinter::VisitOpenACCExitDataConstruct(OpenACCExitDataConstruct *S) {
1226 PrintOpenACCConstruct(S);
1228void StmtPrinter::VisitOpenACCInitConstruct(OpenACCInitConstruct *S) {
1229 PrintOpenACCConstruct(S);
1231void StmtPrinter::VisitOpenACCShutdownConstruct(OpenACCShutdownConstruct *S) {
1232 PrintOpenACCConstruct(S);
1234void StmtPrinter::VisitOpenACCSetConstruct(OpenACCSetConstruct *S) {
1235 PrintOpenACCConstruct(S);
1237void StmtPrinter::VisitOpenACCUpdateConstruct(OpenACCUpdateConstruct *S) {
1238 PrintOpenACCConstruct(S);
1241void StmtPrinter::VisitOpenACCWaitConstruct(OpenACCWaitConstruct *S) {
1242 Indent() <<
"#pragma acc wait";
1255 E->printPretty(OS, nullptr, Policy);
1261 PrintOpenACCClauseList(S);
1265void StmtPrinter::VisitOpenACCAtomicConstruct(OpenACCAtomicConstruct *S) {
1266 Indent() <<
"#pragma acc atomic";
1271 PrintOpenACCClauseList(S);
1276void StmtPrinter::VisitOpenACCCacheConstruct(OpenACCCacheConstruct *S) {
1277 Indent() <<
"#pragma acc cache(";
1281 llvm::interleaveComma(S->
getVarList(), OS, [&](
const Expr *E) {
1282 E->printPretty(OS, nullptr, Policy);
1292void StmtPrinter::VisitSourceLocExpr(SourceLocExpr *Node) {
1296void StmtPrinter::VisitEmbedExpr(EmbedExpr *Node) {
1304void StmtPrinter::VisitConstantExpr(ConstantExpr *Node) {
1308void StmtPrinter::VisitDeclRefExpr(DeclRefExpr *Node) {
1309 ValueDecl *VD = Node->
getDecl();
1310 if (
const auto *OCED = dyn_cast<OMPCapturedExprDecl>(VD)) {
1311 OCED->getInit()->IgnoreImpCasts()->printPretty(OS,
nullptr, Policy);
1314 if (
const auto *TPOD = dyn_cast<TemplateParamObjectDecl>(VD)) {
1315 TPOD->printAsExpr(OS, Policy);
1322 bool ForceAnonymous =
1324 DeclarationNameInfo NameInfo = Node->
getNameInfo();
1330 OS <<
ID->deuglifiedName();
1335 case Decl::NonTypeTemplateParm: {
1337 OS <<
"value-parameter-" << TD->getDepth() <<
'-' << TD->getIndex() <<
"";
1340 case Decl::ParmVar: {
1342 OS <<
"function-parameter-" << PD->getFunctionScopeDepth() <<
'-'
1343 << PD->getFunctionScopeIndex();
1346 case Decl::Decomposition:
1347 OS <<
"decomposition";
1349 OS <<
'-' << I->getName();
1357 const TemplateParameterList *TPL =
nullptr;
1359 if (
auto *TD = dyn_cast<TemplateDecl>(VD))
1360 TPL = TD->getTemplateParameters();
1365void StmtPrinter::VisitDependentScopeDeclRefExpr(
1366 DependentScopeDeclRefExpr *Node) {
1375void StmtPrinter::VisitUnresolvedLookupExpr(UnresolvedLookupExpr *Node) {
1385 if (
const auto *DRE = dyn_cast<DeclRefExpr>(E)) {
1386 if (
const auto *PD = dyn_cast<ImplicitParamDecl>(DRE->getDecl())) {
1388 DRE->getBeginLoc().isInvalid())
1395void StmtPrinter::VisitObjCIvarRefExpr(ObjCIvarRefExpr *Node) {
1406void StmtPrinter::VisitObjCPropertyRefExpr(ObjCPropertyRefExpr *Node) {
1418 Getter->getSelector().print(OS);
1426void StmtPrinter::VisitObjCSubscriptRefExpr(ObjCSubscriptRefExpr *Node) {
1433void StmtPrinter::VisitSYCLUniqueStableNameExpr(
1434 SYCLUniqueStableNameExpr *Node) {
1435 OS <<
"__builtin_sycl_unique_stable_name(";
1440void StmtPrinter::VisitPredefinedExpr(PredefinedExpr *Node) {
1444void StmtPrinter::VisitOpenACCAsteriskSizeExpr(OpenACCAsteriskSizeExpr *Node) {
1448void StmtPrinter::VisitCharacterLiteral(CharacterLiteral *Node) {
1461 Context->getSourceManager(), Context->getLangOpts(), &
Invalid);
1469void StmtPrinter::VisitIntegerLiteral(IntegerLiteral *Node) {
1476 OS << (isSigned ?
"wb" :
"uwb");
1481 switch (Node->
getType()->
castAs<BuiltinType>()->getKind()) {
1482 default: llvm_unreachable(
"Unexpected type for integer literal!");
1483 case BuiltinType::Char_S:
1484 case BuiltinType::Char_U:
OS <<
"i8";
break;
1485 case BuiltinType::UChar:
OS <<
"Ui8";
break;
1486 case BuiltinType::SChar:
OS <<
"i8";
break;
1487 case BuiltinType::Short:
OS <<
"i16";
break;
1488 case BuiltinType::UShort:
OS <<
"Ui16";
break;
1489 case BuiltinType::Int:
break;
1490 case BuiltinType::UInt:
OS <<
'U';
break;
1491 case BuiltinType::Long:
OS <<
'L';
break;
1492 case BuiltinType::ULong:
OS <<
"UL";
break;
1493 case BuiltinType::LongLong:
OS <<
"LL";
break;
1494 case BuiltinType::ULongLong:
OS <<
"ULL";
break;
1495 case BuiltinType::Int128:
1497 case BuiltinType::UInt128:
1499 case BuiltinType::WChar_S:
1500 case BuiltinType::WChar_U:
1505void StmtPrinter::VisitFixedPointLiteral(FixedPointLiteral *Node) {
1510 switch (Node->
getType()->
castAs<BuiltinType>()->getKind()) {
1511 default: llvm_unreachable(
"Unexpected type for fixed point literal!");
1512 case BuiltinType::ShortFract:
OS <<
"hr";
break;
1513 case BuiltinType::ShortAccum:
OS <<
"hk";
break;
1514 case BuiltinType::UShortFract:
OS <<
"uhr";
break;
1515 case BuiltinType::UShortAccum:
OS <<
"uhk";
break;
1516 case BuiltinType::Fract:
OS <<
"r";
break;
1517 case BuiltinType::Accum:
OS <<
"k";
break;
1518 case BuiltinType::UFract:
OS <<
"ur";
break;
1519 case BuiltinType::UAccum:
OS <<
"uk";
break;
1520 case BuiltinType::LongFract:
OS <<
"lr";
break;
1521 case BuiltinType::LongAccum:
OS <<
"lk";
break;
1522 case BuiltinType::ULongFract:
OS <<
"ulr";
break;
1523 case BuiltinType::ULongAccum:
OS <<
"ulk";
break;
1532 if (Str.find_first_not_of(
"-0123456789") == StringRef::npos)
1540 default: llvm_unreachable(
"Unexpected type for float literal!");
1541 case BuiltinType::Half:
break;
1542 case BuiltinType::Ibm128:
break;
1543 case BuiltinType::Double:
break;
1544 case BuiltinType::Float16: OS <<
"F16";
break;
1545 case BuiltinType::Float: OS <<
'F';
break;
1546 case BuiltinType::LongDouble: OS <<
'L';
break;
1547 case BuiltinType::Float128: OS <<
'Q';
break;
1551void StmtPrinter::VisitFloatingLiteral(FloatingLiteral *Node) {
1557void StmtPrinter::VisitImaginaryLiteral(ImaginaryLiteral *Node) {
1562void StmtPrinter::VisitStringLiteral(StringLiteral *Str) {
1566void StmtPrinter::VisitParenExpr(ParenExpr *Node) {
1572void StmtPrinter::VisitUnaryOperator(UnaryOperator *Node) {
1598void StmtPrinter::VisitOffsetOfExpr(OffsetOfExpr *Node) {
1599 OS <<
"__builtin_offsetof(";
1602 bool PrintedSomething =
false;
1610 PrintedSomething =
true;
1623 if (PrintedSomething)
1626 PrintedSomething =
true;
1632void StmtPrinter::VisitUnaryExprOrTypeTraitExpr(
1633 UnaryExprOrTypeTraitExpr *Node) {
1635 if (Node->
getKind() == UETT_AlignOf) {
1637 Spelling =
"alignof";
1639 Spelling =
"_Alignof";
1641 Spelling =
"__alignof";
1656void StmtPrinter::VisitGenericSelectionExpr(GenericSelectionExpr *Node) {
1665 QualType
T = Assoc.getType();
1669 T.print(OS, Policy);
1671 PrintExpr(Assoc.getAssociationExpr());
1676void StmtPrinter::VisitArraySubscriptExpr(ArraySubscriptExpr *Node) {
1677 PrintExpr(Node->
getLHS());
1679 PrintExpr(Node->
getRHS());
1683void StmtPrinter::VisitMatrixSubscriptExpr(MatrixSubscriptExpr *Node) {
1693void StmtPrinter::VisitArraySectionExpr(ArraySectionExpr *Node) {
1711void StmtPrinter::VisitOMPArrayShapingExpr(OMPArrayShapingExpr *Node) {
1722void StmtPrinter::VisitOMPIteratorExpr(OMPIteratorExpr *Node) {
1729 PrintExpr(
Range.Begin);
1731 PrintExpr(
Range.End);
1734 PrintExpr(
Range.Step);
1742void StmtPrinter::PrintCallArgs(CallExpr *
Call) {
1743 for (
unsigned i = 0, e =
Call->getNumArgs(); i != e; ++i) {
1750 PrintExpr(
Call->getArg(i));
1754void StmtPrinter::VisitCallExpr(CallExpr *
Call) {
1755 PrintExpr(
Call->getCallee());
1757 PrintCallArgs(
Call);
1762 if (
const auto *TE = dyn_cast<CXXThisExpr>(E))
1763 return TE->isImplicit();
1767void StmtPrinter::VisitMemberExpr(MemberExpr *Node) {
1771 auto *ParentMember = dyn_cast<MemberExpr>(Node->
getBase());
1772 FieldDecl *ParentDecl =
1773 ParentMember ? dyn_cast<FieldDecl>(ParentMember->getMemberDecl())
1781 if (FD->isAnonymousStructOrUnion())
1788 const TemplateParameterList *TPL =
nullptr;
1789 if (
auto *FD = dyn_cast<FunctionDecl>(Node->
getMemberDecl())) {
1791 if (
auto *FTD = FD->getPrimaryTemplate())
1792 TPL = FTD->getTemplateParameters();
1793 }
else if (
auto *VTSD =
1794 dyn_cast<VarTemplateSpecializationDecl>(Node->
getMemberDecl()))
1795 TPL = VTSD->getSpecializedTemplate()->getTemplateParameters();
1800void StmtPrinter::VisitObjCIsaExpr(ObjCIsaExpr *Node) {
1802 OS << (Node->
isArrow() ?
"->isa" :
".isa");
1805void StmtPrinter::VisitExtVectorElementExpr(ExtVectorElementExpr *Node) {
1811void StmtPrinter::VisitCStyleCastExpr(CStyleCastExpr *Node) {
1818void StmtPrinter::VisitCompoundLiteralExpr(CompoundLiteralExpr *Node) {
1825void StmtPrinter::VisitImplicitCastExpr(ImplicitCastExpr *Node) {
1830void StmtPrinter::VisitBinaryOperator(BinaryOperator *Node) {
1831 PrintExpr(Node->
getLHS());
1833 PrintExpr(Node->
getRHS());
1836void StmtPrinter::VisitCompoundAssignOperator(CompoundAssignOperator *Node) {
1837 PrintExpr(Node->
getLHS());
1839 PrintExpr(Node->
getRHS());
1842void StmtPrinter::VisitConditionalOperator(ConditionalOperator *Node) {
1845 PrintExpr(Node->
getLHS());
1847 PrintExpr(Node->
getRHS());
1853StmtPrinter::VisitBinaryConditionalOperator(BinaryConditionalOperator *Node) {
1859void StmtPrinter::VisitAddrLabelExpr(AddrLabelExpr *Node) {
1863void StmtPrinter::VisitStmtExpr(StmtExpr *E) {
1869void StmtPrinter::VisitChooseExpr(ChooseExpr *Node) {
1870 OS <<
"__builtin_choose_expr(";
1873 PrintExpr(Node->
getLHS());
1875 PrintExpr(Node->
getRHS());
1879void StmtPrinter::VisitGNUNullExpr(GNUNullExpr *) {
1883void StmtPrinter::VisitShuffleVectorExpr(ShuffleVectorExpr *Node) {
1884 OS <<
"__builtin_shufflevector(";
1892void StmtPrinter::VisitConvertVectorExpr(ConvertVectorExpr *Node) {
1893 OS <<
"__builtin_convertvector(";
1900void StmtPrinter::VisitInitListExpr(InitListExpr* Node) {
1907 for (
unsigned i = 0, e = Node->
getNumInits(); i != e; ++i) {
1917void StmtPrinter::VisitArrayInitLoopExpr(ArrayInitLoopExpr *Node) {
1925void StmtPrinter::VisitArrayInitIndexExpr(ArrayInitIndexExpr *Node) {
1929void StmtPrinter::VisitParenListExpr(ParenListExpr* Node) {
1931 for (
unsigned i = 0, e = Node->
getNumExprs(); i != e; ++i) {
1938void StmtPrinter::VisitDesignatedInitExpr(DesignatedInitExpr *Node) {
1939 bool NeedsEquals =
true;
1940 for (
const DesignatedInitExpr::Designator &D : Node->
designators()) {
1941 if (D.isFieldDesignator()) {
1942 if (D.getDotLoc().isInvalid()) {
1943 if (
const IdentifierInfo *II = D.getFieldName()) {
1944 OS << II->getName() <<
":";
1945 NeedsEquals =
false;
1948 OS <<
"." << D.getFieldName()->getName();
1952 if (D.isArrayDesignator()) {
1970void StmtPrinter::VisitDesignatedInitUpdateExpr(
1971 DesignatedInitUpdateExpr *Node) {
1977 OS <<
"/*updater*/";
1982void StmtPrinter::VisitNoInitExpr(NoInitExpr *Node) {
1983 OS <<
"/*no init*/";
1986void StmtPrinter::VisitImplicitValueInitExpr(ImplicitValueInitExpr *Node) {
1988 OS <<
"/*implicit*/";
1992 OS <<
"/*implicit*/(";
2002void StmtPrinter::VisitVAArgExpr(VAArgExpr *Node) {
2003 OS <<
"__builtin_va_arg(";
2010void StmtPrinter::VisitPseudoObjectExpr(PseudoObjectExpr *Node) {
2014void StmtPrinter::VisitAtomicExpr(AtomicExpr *Node) {
2015 const char *Name =
nullptr;
2016 switch (Node->
getOp()) {
2017#define ATOMIC_BUILTIN(ID, TYPE, ATTRS) \
2018 case AtomicExpr::AO ## ID: \
2021#include "clang/Basic/Builtins.inc"
2026 PrintExpr(Node->
getPtr());
2027 if (Node->
getOp() != AtomicExpr::AO__c11_atomic_load &&
2028 Node->
getOp() != AtomicExpr::AO__atomic_load_n &&
2029 Node->
getOp() != AtomicExpr::AO__scoped_atomic_load_n &&
2030 Node->
getOp() != AtomicExpr::AO__opencl_atomic_load &&
2031 Node->
getOp() != AtomicExpr::AO__hip_atomic_load) {
2035 if (Node->
getOp() == AtomicExpr::AO__atomic_exchange ||
2040 if (Node->
getOp() == AtomicExpr::AO__atomic_compare_exchange ||
2041 Node->
getOp() == AtomicExpr::AO__atomic_compare_exchange_n) {
2045 if (Node->
getOp() != AtomicExpr::AO__c11_atomic_init &&
2046 Node->
getOp() != AtomicExpr::AO__opencl_atomic_init) {
2058void StmtPrinter::VisitCXXOperatorCallExpr(CXXOperatorCallExpr *Node) {
2060 if (Kind == OO_PlusPlus || Kind == OO_MinusMinus) {
2063 PrintExpr(Node->
getArg(0));
2065 PrintExpr(Node->
getArg(0));
2068 }
else if (Kind == OO_Arrow) {
2069 PrintExpr(Node->
getArg(0));
2070 }
else if (Kind == OO_Call || Kind == OO_Subscript) {
2071 PrintExpr(Node->
getArg(0));
2072 OS << (
Kind == OO_Call ?
'(' :
'[');
2073 for (
unsigned ArgIdx = 1; ArgIdx < Node->
getNumArgs(); ++ArgIdx) {
2077 PrintExpr(Node->
getArg(ArgIdx));
2079 OS << (
Kind == OO_Call ?
')' :
']');
2082 PrintExpr(Node->
getArg(0));
2084 PrintExpr(Node->
getArg(0));
2086 PrintExpr(Node->
getArg(1));
2088 llvm_unreachable(
"unknown overloaded operator");
2092void StmtPrinter::VisitCXXMemberCallExpr(CXXMemberCallExpr *Node) {
2095 if (isa_and_nonnull<CXXConversionDecl>(MD)) {
2102void StmtPrinter::VisitCUDAKernelCallExpr(CUDAKernelCallExpr *Node) {
2107 PrintCallArgs(Node);
2111void StmtPrinter::VisitCXXRewrittenBinaryOperator(
2112 CXXRewrittenBinaryOperator *Node) {
2113 CXXRewrittenBinaryOperator::DecomposedForm Decomposed =
2115 PrintExpr(
const_cast<Expr*
>(Decomposed.
LHS));
2117 PrintExpr(
const_cast<Expr*
>(Decomposed.
RHS));
2120void StmtPrinter::VisitCXXNamedCastExpr(CXXNamedCastExpr *Node) {
2128void StmtPrinter::VisitCXXStaticCastExpr(CXXStaticCastExpr *Node) {
2129 VisitCXXNamedCastExpr(Node);
2132void StmtPrinter::VisitCXXDynamicCastExpr(CXXDynamicCastExpr *Node) {
2133 VisitCXXNamedCastExpr(Node);
2136void StmtPrinter::VisitCXXReinterpretCastExpr(CXXReinterpretCastExpr *Node) {
2137 VisitCXXNamedCastExpr(Node);
2140void StmtPrinter::VisitCXXConstCastExpr(CXXConstCastExpr *Node) {
2141 VisitCXXNamedCastExpr(Node);
2144void StmtPrinter::VisitBuiltinBitCastExpr(BuiltinBitCastExpr *Node) {
2145 OS <<
"__builtin_bit_cast(";
2152void StmtPrinter::VisitCXXAddrspaceCastExpr(CXXAddrspaceCastExpr *Node) {
2153 VisitCXXNamedCastExpr(Node);
2156void StmtPrinter::VisitCXXTypeidExpr(CXXTypeidExpr *Node) {
2166void StmtPrinter::VisitCXXUuidofExpr(CXXUuidofExpr *Node) {
2176void StmtPrinter::VisitMSPropertyRefExpr(MSPropertyRefExpr *Node) {
2186void StmtPrinter::VisitMSPropertySubscriptExpr(MSPropertySubscriptExpr *Node) {
2189 PrintExpr(Node->
getIdx());
2193void StmtPrinter::VisitUserDefinedLiteral(UserDefinedLiteral *Node) {
2200 const TemplateArgumentList *Args =
2205 const TemplateParameterList *TPL =
nullptr;
2206 if (!DRE->hadMultipleCandidates())
2207 if (
const auto *TD = dyn_cast<TemplateDecl>(DRE->getDecl()))
2208 TPL = TD->getTemplateParameters();
2210 printTemplateArgumentList(OS, Args->
asArray(), Policy, TPL);
2215 const TemplateArgument &Pack = Args->
get(0);
2217 char C = (char)P.getAsIntegral().getZExtValue();
2242void StmtPrinter::VisitCXXBoolLiteralExpr(CXXBoolLiteralExpr *Node) {
2246void StmtPrinter::VisitCXXNullPtrLiteralExpr(CXXNullPtrLiteralExpr *Node) {
2250void StmtPrinter::VisitCXXThisExpr(CXXThisExpr *Node) {
2254void StmtPrinter::VisitCXXThrowExpr(CXXThrowExpr *Node) {
2263void StmtPrinter::VisitCXXDefaultArgExpr(CXXDefaultArgExpr *Node) {
2267void StmtPrinter::VisitCXXDefaultInitExpr(CXXDefaultInitExpr *Node) {
2271void StmtPrinter::VisitCXXFunctionalCastExpr(CXXFunctionalCastExpr *Node) {
2272 auto TargetType = Node->
getType();
2274 bool Bare =
Auto &&
Auto->isDeduced();
2279 TargetType.print(OS, Policy);
2291void StmtPrinter::VisitCXXBindTemporaryExpr(CXXBindTemporaryExpr *Node) {
2295void StmtPrinter::VisitCXXTemporaryObjectExpr(CXXTemporaryObjectExpr *Node) {
2303 for (CXXTemporaryObjectExpr::arg_iterator Arg = Node->
arg_begin(),
2305 Arg != ArgEnd; ++Arg) {
2306 if ((*Arg)->isDefaultArgument())
2320void StmtPrinter::VisitLambdaExpr(
LambdaExpr *Node) {
2322 bool NeedComma =
false;
2341 if (
C->capturesVLAType())
2348 switch (
C->getCaptureKind()) {
2360 OS <<
C->getCapturedVar()->getName();
2364 OS <<
C->getCapturedVar()->getName();
2368 llvm_unreachable(
"VLA type in explicit captures.");
2371 if (
C->isPackExpansion())
2378 llvm::StringRef
Pre;
2379 llvm::StringRef
Post;
2389 PrintExpr(D->getInit());
2405 for (
const auto *P :
Method->parameters()) {
2411 std::string ParamStr =
2413 ? P->getIdentifier()->deuglifiedName().str()
2414 : P->getNameAsString();
2415 P->getOriginalType().print(OS, Policy, ParamStr);
2417 if (
Method->isVariadic()) {
2427 auto *Proto =
Method->getType()->castAs<FunctionProtoType>();
2428 Proto->printExceptionSpecification(OS, Policy);
2435 Proto->getReturnType().print(OS, Policy);
2447void StmtPrinter::VisitCXXScalarValueInitExpr(CXXScalarValueInitExpr *Node) {
2449 TSInfo->getType().print(OS, Policy);
2455void StmtPrinter::VisitCXXNewExpr(CXXNewExpr *E) {
2463 for (
unsigned i = 1; i < NumPlace; ++i) {
2475 llvm::raw_string_ostream
s(TypeS);
2478 (*Size)->printPretty(
s, Helper, Policy);
2486 if (InitStyle != CXXNewInitializationStyle::None) {
2487 bool Bare = InitStyle == CXXNewInitializationStyle::Parens &&
2497void StmtPrinter::VisitCXXDeleteExpr(CXXDeleteExpr *E) {
2506void StmtPrinter::VisitCXXPseudoDestructorExpr(CXXPseudoDestructorExpr *E) {
2516 OS << II->getName();
2521void StmtPrinter::VisitCXXConstructExpr(CXXConstructExpr *E) {
2525 for (
unsigned i = 0, e = E->
getNumArgs(); i != e; ++i) {
2539void StmtPrinter::VisitCXXInheritedCtorInitExpr(CXXInheritedCtorInitExpr *E) {
2541 OS <<
"<forwarded>";
2544void StmtPrinter::VisitCXXStdInitializerListExpr(CXXStdInitializerListExpr *E) {
2548void StmtPrinter::VisitExprWithCleanups(ExprWithCleanups *E) {
2553void StmtPrinter::VisitCXXUnresolvedConstructExpr(
2554 CXXUnresolvedConstructExpr *Node) {
2558 for (
auto Arg = Node->
arg_begin(), ArgEnd = Node->
arg_end(); Arg != ArgEnd;
2568void StmtPrinter::VisitCXXDependentScopeMemberExpr(
2569 CXXDependentScopeMemberExpr *Node) {
2582void StmtPrinter::VisitUnresolvedMemberExpr(UnresolvedMemberExpr *Node) {
2595void StmtPrinter::VisitTypeTraitExpr(TypeTraitExpr *E) {
2597 for (
unsigned I = 0, N = E->
getNumArgs(); I != N; ++I) {
2605void StmtPrinter::VisitArrayTypeTraitExpr(ArrayTypeTraitExpr *E) {
2611void StmtPrinter::VisitExpressionTraitExpr(ExpressionTraitExpr *E) {
2617void StmtPrinter::VisitCXXNoexceptExpr(CXXNoexceptExpr *E) {
2623void StmtPrinter::VisitPackExpansionExpr(PackExpansionExpr *E) {
2628void StmtPrinter::VisitSizeOfPackExpr(SizeOfPackExpr *E) {
2629 OS <<
"sizeof...(" << *E->
getPack() <<
")";
2632void StmtPrinter::VisitPackIndexingExpr(PackIndexingExpr *E) {
2639void StmtPrinter::VisitSubstNonTypeTemplateParmPackExpr(
2640 SubstNonTypeTemplateParmPackExpr *Node) {
2644void StmtPrinter::VisitSubstNonTypeTemplateParmExpr(
2645 SubstNonTypeTemplateParmExpr *Node) {
2649void StmtPrinter::VisitFunctionParmPackExpr(FunctionParmPackExpr *E) {
2653void StmtPrinter::VisitMaterializeTemporaryExpr(MaterializeTemporaryExpr *Node){
2657void StmtPrinter::VisitCXXFoldExpr(CXXFoldExpr *E) {
2671void StmtPrinter::VisitCXXParenListInitExpr(CXXParenListInitExpr *Node) {
2673 [&](Expr *E) { PrintExpr(E); });
2676void StmtPrinter::VisitConceptSpecializationExpr(ConceptSpecializationExpr *E) {
2690 if (!LocalParameters.empty()) {
2692 for (ParmVarDecl *LocalParam : LocalParameters) {
2693 PrintRawDecl(LocalParam);
2694 if (LocalParam != LocalParameters.back())
2702 for (concepts::Requirement *Req : Requirements) {
2703 if (
auto *TypeReq = dyn_cast<concepts::TypeRequirement>(Req)) {
2704 if (TypeReq->isSubstitutionFailure())
2705 OS <<
"<<error-type>>";
2707 TypeReq->getType()->getType().print(OS, Policy);
2708 }
else if (
auto *ExprReq = dyn_cast<concepts::ExprRequirement>(Req)) {
2709 if (ExprReq->isCompound())
2711 if (ExprReq->isExprSubstitutionFailure())
2712 OS <<
"<<error-expression>>";
2714 PrintExpr(ExprReq->getExpr());
2715 if (ExprReq->isCompound()) {
2717 if (ExprReq->getNoexceptLoc().isValid())
2719 const auto &RetReq = ExprReq->getReturnTypeRequirement();
2720 if (!RetReq.isEmpty()) {
2722 if (RetReq.isSubstitutionFailure())
2723 OS <<
"<<error-type>>";
2724 else if (RetReq.isTypeConstraint())
2725 RetReq.getTypeConstraint()->print(OS, Policy);
2731 if (NestedReq->hasInvalidConstraint())
2732 OS <<
"<<error-expression>>";
2734 PrintExpr(NestedReq->getConstraintExpr());
2743void StmtPrinter::VisitCoroutineBodyStmt(CoroutineBodyStmt *S) {
2747void StmtPrinter::VisitCoreturnStmt(CoreturnStmt *S) {
2756void StmtPrinter::VisitCoawaitExpr(CoawaitExpr *S) {
2761void StmtPrinter::VisitDependentCoawaitExpr(DependentCoawaitExpr *S) {
2766void StmtPrinter::VisitCoyieldExpr(CoyieldExpr *S) {
2773void StmtPrinter::VisitObjCStringLiteral(ObjCStringLiteral *Node) {
2778void StmtPrinter::VisitObjCBoxedExpr(ObjCBoxedExpr *E) {
2783void StmtPrinter::VisitObjCArrayLiteral(ObjCArrayLiteral *E) {
2785 ObjCArrayLiteral::child_range Ch = E->
children();
2786 for (
auto I = Ch.begin(), E = Ch.end(); I != E; ++I) {
2787 if (I != Ch.begin())
2794void StmtPrinter::VisitObjCDictionaryLiteral(ObjCDictionaryLiteral *E) {
2803 Visit(Element.
Value);
2810void StmtPrinter::VisitObjCEncodeExpr(ObjCEncodeExpr *Node) {
2816void StmtPrinter::VisitObjCSelectorExpr(ObjCSelectorExpr *Node) {
2822void StmtPrinter::VisitObjCProtocolExpr(ObjCProtocolExpr *Node) {
2826void StmtPrinter::VisitObjCMessageExpr(ObjCMessageExpr *Mess) {
2848 for (
unsigned i = 0, e = Mess->
getNumArgs(); i != e; ++i) {
2850 if (i > 0)
OS <<
' ';
2858 PrintExpr(Mess->
getArg(i));
2864void StmtPrinter::VisitObjCBoolLiteralExpr(ObjCBoolLiteralExpr *Node) {
2865 OS << (Node->
getValue() ?
"__objc_yes" :
"__objc_no");
2869StmtPrinter::VisitObjCIndirectCopyRestoreExpr(ObjCIndirectCopyRestoreExpr *E) {
2874StmtPrinter::VisitObjCBridgedCastExpr(ObjCBridgedCastExpr *E) {
2881void StmtPrinter::VisitBlockExpr(BlockExpr *Node) {
2894 std::string ParamStr = (*AI)->getNameAsString();
2895 (*AI)->getType().print(OS, Policy, ParamStr);
2899 if (FT->isVariadic()) {
2908void StmtPrinter::VisitOpaqueValueExpr(OpaqueValueExpr *Node) {
2912void StmtPrinter::VisitRecoveryExpr(RecoveryExpr *Node) {
2913 OS <<
"<recovery-expr>(";
2914 const char *Sep =
"";
2923void StmtPrinter::VisitAsTypeExpr(AsTypeExpr *Node) {
2924 OS <<
"__builtin_astype(";
2931void StmtPrinter::VisitHLSLOutArgExpr(HLSLOutArgExpr *Node) {
2945 StringRef NL,
const ASTContext *Context)
const {
2946 StmtPrinter P(Out, Helper, Policy, Indentation, NL, Context);
2947 P.Visit(
const_cast<Stmt *
>(
this));
2952 unsigned Indentation, StringRef NL,
2954 StmtPrinter P(Out, Helper, Policy, Indentation, NL, Context);
2955 P.PrintControlledStmt(
const_cast<Stmt *
>(
this));
2961 llvm::raw_string_ostream TempOut(Buf);
Defines the clang::ASTContext interface.
Defines the C++ Decl subclasses, other than those for templates (found in DeclTemplate....
This file defines OpenACC nodes for declarative directives.
This file defines OpenMP nodes for declarative directives.
Defines the C++ template declaration subclasses.
Defines the clang::Expr interface and subclasses for C++ expressions.
Defines enumerations for expression traits intrinsics.
Defines the clang::IdentifierInfo, clang::IdentifierTable, and clang::Selector interfaces.
Forward-declares and imports various common LLVM datatypes that clang wants to use unqualified.
Defines several types used to describe C++ lambda expressions that are shared between the parser and ...
This file defines OpenMP AST classes for clauses.
Defines some OpenMP-specific enums and functions.
Defines an enumeration for C++ overloaded operators.
static std::string toString(const clang::SanitizerSet &Sanitizers)
Produce a string containing comma-separated names of sanitizers in Sanitizers set.
Defines the clang::SourceLocation class and associated facilities.
Defines the Objective-C statement AST node classes.
This file defines OpenMP AST classes for executable directives and clauses.
static bool isImplicitThis(const Expr *E)
static bool isImplicitSelf(const Expr *E)
static void PrintFloatingLiteral(raw_ostream &OS, FloatingLiteral *Node, bool PrintSuffix)
static bool printExprAsWritten(raw_ostream &OS, Expr *E, const ASTContext *Context)
Prints the given expression using the original source text.
This file defines SYCL AST classes used to represent calls to SYCL kernels.
Defines enumerations for the type traits support.
C Language Family Type Representation.
__device__ __2f16 float __ockl_bool s
OpenMPDirectiveKind getCancelRegion() const
Get cancellation region for the current cancellation point.
OpenMPDirectiveKind getCancelRegion() const
Get cancellation region for the current cancellation point.
const Stmt * getAssociatedStmt() const
OpenACCAtomicKind getAtomicKind() const
ArrayRef< Expr * > getVarList() const
Stmt * getStructuredBlock()
Stmt * getStructuredBlock()
bool hasQueuesTag() const
ArrayRef< Expr * > getQueueIdExprs()
bool hasDevNumExpr() const
SourceLocation getLParenLoc() const
Expr * getDevNumExpr() const
llvm::APInt getValue() const
Holds long-lived AST nodes (such as types and decls) that can be referred to throughout the semantic ...
const LangOptions & getLangOpts() const
LabelDecl * getLabel() const
Expr * getSubExpr() const
Get the initializer to use for each array element.
Expr * getBase()
Get base of the array section.
Expr * getLength()
Get length of array section.
bool isOMPArraySection() const
Expr * getStride()
Get stride of array section.
SourceLocation getColonLocSecond() const
Expr * getLowerBound()
Get lower bound of array section.
SourceLocation getColonLocFirst() const
Expr * getLHS()
An array access can be written A[4] or 4[A] (both are equivalent).
ArrayTypeTrait getTrait() const
QualType getQueriedType() const
Expr * getSrcExpr() const
getSrcExpr - Return the Expr to be converted.
unsigned getNumClobbers() const
unsigned getNumOutputs() const
unsigned getNumInputs() const
Expr * getOrderFail() const
ArrayRef< const Attr * > getAttrs() const
Expr * getFalseExpr() const
getFalseExpr - Return the subexpression which will be evaluated if the condition evaluates to false; ...
Expr * getCommon() const
getCommon - Return the common expression, written to the left of the condition.
StringRef getOpcodeStr() const
param_iterator param_end()
MutableArrayRef< ParmVarDecl * >::iterator param_iterator
param_iterator param_begin()
const FunctionProtoType * getFunctionType() const
getFunctionType - Return the underlying function type for this block.
const BlockDecl * getBlockDecl() const
This class is used for builtin types like 'int'.
const CallExpr * getConfig() const
const Expr * getSubExpr() const
Stmt * getHandlerBlock() const
VarDecl * getExceptionDecl() const
Expr * getArg(unsigned Arg)
Return the specified argument.
bool isStdInitListInitialization() const
Whether this constructor call was written as list-initialization, but was interpreted as forming a st...
bool isListInitialization() const
Whether this constructor call was written as list-initialization.
unsigned getNumArgs() const
Return the number of arguments to the constructor call.
bool isGlobalDelete() const
bool isArrow() const
Determine whether this member expression used the '->' operator; otherwise, it used the '.
NestedNameSpecifier getQualifier() const
Retrieve the nested-name-specifier that qualifies the member name.
const DeclarationNameInfo & getMemberNameInfo() const
Retrieve the name of the member that this expression refers to.
bool hasExplicitTemplateArgs() const
Determines whether this member expression actually had a C++ template argument list explicitly specif...
Expr * getBase() const
Retrieve the base object of this member expressions, e.g., the x in x.m.
bool hasTemplateKeyword() const
Determines whether the member name was preceded by the template keyword.
bool isImplicitAccess() const
True if this is an implicit access, i.e.
ArrayRef< TemplateArgumentLoc > template_arguments() const
BinaryOperatorKind getOperator() const
VarDecl * getLoopVariable()
bool isListInitialization() const
Determine whether this expression models list-initialization.
CXXMethodDecl * getMethodDecl() const
Retrieve the declaration of the called method.
Expr * getImplicitObjectArgument() const
Retrieve the implicit object argument for the member call.
const char * getCastName() const
getCastName - Get the name of the C++ cast being used, e.g., "static_cast", "dynamic_cast",...
QualType getAllocatedType() const
std::optional< Expr * > getArraySize()
This might return std::nullopt even if isArray() returns true, since there might not be an array size...
CXXNewInitializationStyle getInitializationStyle() const
The kind of initializer this new-expression has.
Expr * getPlacementArg(unsigned I)
unsigned getNumPlacementArgs() const
bool isParenTypeId() const
Expr * getInitializer()
The initializer of this new-expression.
Expr * getOperand() const
OverloadedOperatorKind getOperator() const
Returns the kind of overloaded operator that this expression refers to.
ArrayRef< Expr * > getUserSpecifiedInitExprs()
bool isArrow() const
Determine whether this pseudo-destructor expression was written using an '->' (otherwise,...
QualType getDestroyedType() const
Retrieve the type being destroyed.
NestedNameSpecifier getQualifier() const
If the member name was qualified, retrieves the nested-name-specifier that precedes the member name.
const IdentifierInfo * getDestroyedTypeIdentifier() const
In a dependent pseudo-destructor expression for which we do not have full type information on the des...
DecomposedForm getDecomposedForm() const LLVM_READONLY
Decompose this operator into its syntactic form.
TypeSourceInfo * getTypeSourceInfo() const
const Expr * getSubExpr() const
CXXCatchStmt * getHandler(unsigned i)
unsigned getNumHandlers() const
CompoundStmt * getTryBlock()
bool isTypeOperand() const
TypeSourceInfo * getTypeOperandSourceInfo() const
Retrieve source information for the type operand.
Expr * getExprOperand() const
bool isListInitialization() const
Determine whether this expression models list-initialization.
QualType getTypeAsWritten() const
Retrieve the type that is being constructed, as specified in the source code.
Expr * getExprOperand() const
bool isTypeOperand() const
TypeSourceInfo * getTypeOperandSourceInfo() const
Retrieve source information for the type operand.
Expr * getArg(unsigned Arg)
getArg - Return the specified argument.
unsigned getNumArgs() const
getNumArgs - Return the number of actual arguments to this call.
Stmt * getBody() const override
getBody - If this Decl represents a declaration for a body of code, such as a function or method defi...
CapturedDecl * getCapturedDecl()
Retrieve the outlined function declaration.
static CharSourceRange getTokenRange(SourceRange R)
static void print(unsigned val, CharacterLiteralKind Kind, raw_ostream &OS)
unsigned getValue() const
CharacterLiteralKind getKind() const
const Expr * getInitializer() const
CompoundStmt - This represents a group of statements like { stmt stmt }.
FPOptionsOverride getStoredFPFeatures() const
Get FPOptionsOverride from trailing storage.
bool hasStoredFPFeatures() const
const ASTTemplateArgumentListInfo * getTemplateArgsAsWritten() const
const NestedNameSpecifierLoc & getNestedNameSpecifierLoc() const
NamedDecl * getFoundDecl() const
SourceLocation getTemplateKWLoc() const
ConceptDecl * getNamedConcept() const
Expr * getCond() const
getCond - Return the expression representing the condition for the ?
Expr * getSrcExpr() const
getSrcExpr - Return the Expr to be converted.
Expr * getOperand() const
Retrieve the operand of the 'co_return' statement.
CompoundStmt * getBody() const
Retrieve the body of the coroutine as written.
Expr * getOperand() const
bool hasExplicitTemplateArgs() const
Determines whether this declaration reference was followed by an explicit template argument list.
NestedNameSpecifier getQualifier() const
If the name was qualified, retrieves the nested-name-specifier that precedes the name.
DeclarationNameInfo getNameInfo() const
ArrayRef< TemplateArgumentLoc > template_arguments() const
bool hadMultipleCandidates() const
Returns true if this expression refers to a function that was resolved from an overloaded set having ...
bool hasTemplateKeyword() const
Determines whether the name in this declaration reference was preceded by the template keyword.
bool isSingleDecl() const
isSingleDecl - This method returns true if this DeclStmt refers to a single Decl.
const Decl * getSingleDecl() const
ASTContext & getASTContext() const LLVM_READONLY
const char * getDeclKindName() const
static void printGroup(Decl **Begin, unsigned NumDecls, raw_ostream &Out, const PrintingPolicy &Policy, unsigned Indentation=0)
void print(raw_ostream &Out, unsigned Indentation=0, bool PrintInstantiation=false) const
IdentifierInfo * getAsIdentifierInfo() const
Retrieve the IdentifierInfo * stored in this declaration name, or null if this declaration name isn't...
NameKind getNameKind() const
Determine what kind of name this is.
Expr * getOperand() const
ArrayRef< TemplateArgumentLoc > template_arguments() const
bool hasExplicitTemplateArgs() const
Determines whether this lookup had explicit template arguments.
NestedNameSpecifier getQualifier() const
Retrieve the nested-name-specifier that qualifies this declaration.
bool hasTemplateKeyword() const
Determines whether the name was preceded by the template keyword.
const DeclarationNameInfo & getNameInfo() const
Retrieve the name that this expression refers to.
Expr * getArrayRangeEnd(const Designator &D) const
Expr * getArrayRangeStart(const Designator &D) const
MutableArrayRef< Designator > designators()
Expr * getArrayIndex(const Designator &D) const
Expr * getInit() const
Retrieve the initializer value.
InitListExpr * getUpdater() const
StringRef getFileName() const
TypeSourceInfo * getTypeInfoAsWritten() const
getTypeInfoAsWritten - Returns the type source info for the type that this expression is casting to.
QualType getTypeAsWritten() const
getTypeAsWritten - Returns the type that this expression is casting to, as written in the source code...
This represents one expression.
Expr * IgnoreImpCasts() LLVM_READONLY
Skip past any implicit casts which might surround this expression until reaching a fixed point.
Expr * getQueriedExpression() const
ExpressionTrait getTrait() const
const Expr * getBase() const
IdentifierInfo & getAccessor() const
bool isAnonymousStructOrUnion() const
Determines whether this field is a representative for an anonymous struct or union.
std::string getValueAsString(unsigned Radix) const
llvm::APFloat getValue() const
DeclStmt * getConditionVariableDeclStmt()
If this ForStmt has a condition variable, return the faux DeclStmt associated with the creation of th...
const Expr * getSubExpr() const
ValueDecl * getParameterPack() const
Get the parameter pack which this expression refers to.
unsigned getNumLabels() const
const Expr * getOutputConstraintExpr(unsigned i) const
StringRef getLabelName(unsigned i) const
StringRef getInputName(unsigned i) const
StringRef getOutputName(unsigned i) const
const Expr * getInputConstraintExpr(unsigned i) const
const Expr * getAsmStringExpr() const
Expr * getOutputExpr(unsigned i)
Expr * getClobberExpr(unsigned i)
Expr * getInputExpr(unsigned i)
AssociationTy< false > Association
TypeSourceInfo * getControllingType()
Return the controlling type of this generic selection expression.
bool isExprPredicate() const
Whether this generic selection uses an expression as its controlling argument.
association_range associations()
Expr * getControllingExpr()
Return the controlling expression of this generic selection expression.
LabelDecl * getLabel() const
const Expr * getArgLValue() const
Return the l-value expression that was written as the argument in source.
StringRef getName() const
Return the actual identifier string.
const Expr * getSubExpr() const
unsigned getNumInits() const
InitListExpr * getSyntacticForm() const
const Expr * getInit(unsigned Init) const
const char * getName() const
bool hasExplicitParameters() const
Determine whether this lambda has an explicit parameter list vs.
bool isMutable() const
Determine whether the lambda is mutable, meaning that any captures values can be modified.
bool isInitCapture(const LambdaCapture *Capture) const
Determine whether one of this lambda's captures is an init-capture.
CXXMethodDecl * getCallOperator() const
Retrieve the function call operator associated with this lambda expression.
const CompoundStmt * getCompoundStmtBody() const
Retrieve the CompoundStmt representing the body of the lambda.
bool hasExplicitResultType() const
Whether this lambda had its result type explicitly specified.
TemplateParameterList * getTemplateParameterList() const
If this is a generic lambda expression, retrieve the template parameter list associated with it,...
ArrayRef< NamedDecl * > getExplicitTemplateParameters() const
Get the template parameters were explicitly specified (as opposed to being invented by use of an auto...
capture_iterator explicit_capture_end() const
Retrieve an iterator pointing past the end of the sequence of explicit lambda captures.
const LambdaCapture * capture_iterator
An iterator that walks over the captures of the lambda, both implicit and explicit.
capture_iterator explicit_capture_begin() const
Retrieve an iterator pointing to the first explicit lambda capture.
LambdaCaptureDefault getCaptureDefault() const
Determine the default capture kind for this lambda.
CXXRecordDecl * getLambdaClass() const
Retrieve the class that corresponds to the lambda.
static StringRef getSourceText(CharSourceRange Range, const SourceManager &SM, const LangOptions &LangOpts, bool *Invalid=nullptr)
Returns a string for the source that the range encompasses.
LabelDecl * getLabelDecl()
bool hasLabelTarget() const
StringRef getAsmString() const
bool isIfExists() const
Determine whether this is an __if_exists statement.
DeclarationNameInfo getNameInfo() const
Retrieve the name of the entity we're testing for, along with location information.
NestedNameSpecifierLoc getQualifierLoc() const
Retrieve the nested-name-specifier that qualifies this name, if any.
CompoundStmt * getSubStmt() const
Retrieve the compound statement that will be included in the program only if the existence of the sym...
NestedNameSpecifierLoc getQualifierLoc() const
MSPropertyDecl * getPropertyDecl() const
Expr * getBaseExpr() const
Expr * getSubExpr() const
Retrieve the temporary-generating subexpression whose value will be materialized into a glvalue.
ArrayRef< TemplateArgumentLoc > template_arguments() const
NestedNameSpecifier getQualifier() const
If the member name was qualified, retrieves the nested-name-specifier that precedes the member name.
ValueDecl * getMemberDecl() const
Retrieve the member declaration to which this expression refers.
bool hasExplicitTemplateArgs() const
Determines whether the member name was followed by an explicit template argument list.
bool hadMultipleCandidates() const
Returns true if this member expression refers to a method that was resolved from an overloaded set ha...
bool hasTemplateKeyword() const
Determines whether the member name was preceded by the template keyword.
DeclarationNameInfo getMemberNameInfo() const
Retrieve the member declaration name info.
IdentifierInfo * getIdentifier() const
Get the identifier that names this declaration, if there is one.
StringRef getName() const
Get the name of identifier for this declaration as a StringRef.
DeclarationName getDeclName() const
Get the actual, stored name of the declaration, which may be a special name.
NestedNameSpecifier getNestedNameSpecifier() const
Retrieve the nested-name-specifier to which this instance refers.
void print(raw_ostream &OS, const PrintingPolicy &Policy, bool ResolveTemplateArguments=false, bool PrintFinalScopeResOp=true) const
Print this nested name specifier to the given output stream.
Expr * getBase()
Fetches base expression of array shaping expression.
ArrayRef< Expr * > getDimensions() const
Fetches the dimensions for array shaping expression.
IteratorRange getIteratorRange(unsigned I)
Gets the iterator range for the given iterator.
unsigned numOfIterators() const
Returns number of iterator definitions.
Decl * getIteratorDecl(unsigned I)
Gets the iterator declaration for the given iterator.
const Expr * getSynchExpr() const
const CompoundStmt * getSynchBody() const
const Expr * getThrowExpr() const
const ObjCAtFinallyStmt * getFinallyStmt() const
Retrieve the @finally statement, if any.
const Stmt * getTryBody() const
Retrieve the @try body.
catch_range catch_stmts()
const Stmt * getSubStmt() const
StringRef getBridgeKindName() const
Retrieve the kind of bridge being performed as a string.
unsigned getNumElements() const
getNumElements - Return number of elements of objective-c dictionary literal.
ObjCDictionaryElement getKeyValueElement(unsigned Index) const
QualType getEncodedType() const
const Expr * getBase() const
Expr * getArg(unsigned Arg)
getArg - Return the specified argument.
Expr * getInstanceReceiver()
Returns the object expression (receiver) for an instance message, or null for a message that is not a...
Selector getSelector() const
@ SuperInstance
The receiver is the instance of the superclass object.
@ Instance
The receiver is an object instance.
@ SuperClass
The receiver is a superclass.
@ Class
The receiver is a class.
QualType getClassReceiver() const
Returns the type of a class message send, or NULL if the message is not a class message.
ReceiverKind getReceiverKind() const
Determine the kind of receiver that this message is being sent to.
unsigned getNumArgs() const
Return the number of actual arguments in this message, not counting the receiver.
Selector getSelector() const
ObjCPropertyDecl * getExplicitProperty() const
ObjCMethodDecl * getImplicitPropertyGetter() const
const Expr * getBase() const
bool isObjectReceiver() const
bool isImplicitProperty() const
ObjCMethodDecl * getImplicitPropertySetter() const
ObjCInterfaceDecl * getClassReceiver() const
bool isClassReceiver() const
bool isSuperReceiver() const
ObjCProtocolDecl * getProtocol() const
Selector getSelector() const
StringLiteral * getString()
Expr * getKeyExpr() const
Expr * getBaseExpr() const
Expr * getIndexExpr(unsigned Idx)
const OffsetOfNode & getComponent(unsigned Idx) const
TypeSourceInfo * getTypeSourceInfo() const
unsigned getNumComponents() const
unsigned getArrayExprIndex() const
For an array element node, returns the index into the array of expressions.
IdentifierInfo * getFieldName() const
For a field or identifier offsetof node, returns the name of the field.
@ Array
An index into an array.
@ Base
An implicit indirection through a C++ base class, when the field found is in a base class.
Kind getKind() const
Determine what kind of offsetof node this is.
Expr * getSourceExpr() const
The source expression of an opaque value expression is the expression which originally generated the ...
OpenACCDirectiveKind getDirectiveKind() const
ArrayRef< const OpenACCClause * > clauses() const
Stmt * getBody() const override
getBody - If this Decl represents a declaration for a body of code, such as a function or method defi...
bool hasExplicitTemplateArgs() const
Determines whether this expression had explicit template arguments.
NestedNameSpecifier getQualifier() const
Fetches the nested-name qualifier, if one was given.
const DeclarationNameInfo & getNameInfo() const
Gets the full name info.
bool hasTemplateKeyword() const
Determines whether the name was preceded by the template keyword.
ArrayRef< TemplateArgumentLoc > template_arguments() const
Expr * getPattern()
Retrieve the pattern of the pack expansion.
Expr * getIndexExpr() const
Expr * getPackIdExpression() const
const Expr * getSubExpr() const
Expr * getExpr(unsigned Init)
unsigned getNumExprs() const
Return the number of expressions in this paren list.
StringRef getIdentKindName() const
PredefinedIdentKind getIdentKind() const
Expr * getSyntacticForm()
Return the syntactic form of this expression, i.e.
void print(raw_ostream &OS, const PrintingPolicy &Policy, const Twine &PlaceHolder=Twine(), unsigned Indentation=0) const
ArrayRef< Expr * > subExpressions()
ArrayRef< concepts::Requirement * > getRequirements() const
ArrayRef< ParmVarDecl * > getLocalParameters() const
CompoundStmt * getBlock() const
Expr * getFilterExpr() const
CompoundStmt * getBlock() const
CompoundStmt * getTryBlock() const
SEHFinallyStmt * getFinallyHandler() const
SEHExceptStmt * getExceptHandler() const
Returns 0 if not defined.
OutlinedFunctionDecl * getOutlinedFunctionDecl()
Retrieve the outlined function declaration.
TypeSourceInfo * getTypeSourceInfo()
static std::string getPropertyNameFromSetterSelector(Selector Sel)
Return the property name for the given setter selector.
StringRef getNameForSlot(unsigned argIndex) const
Retrieve the name at a given position in the selector.
const IdentifierInfo * getIdentifierInfoForSlot(unsigned argIndex) const
Retrieve the identifier at a given position in the selector.
void print(llvm::raw_ostream &OS) const
Prints the full selector name (e.g. "foo:bar:").
bool isUnarySelector() const
unsigned getNumArgs() const
unsigned getNumSubExprs() const
getNumSubExprs - Return the size of the SubExprs array.
Expr * getExpr(unsigned Index)
getExpr - Return the Expr at the specified index.
NamedDecl * getPack() const
Retrieve the parameter pack.
StringRef getBuiltinStr() const
Return a string representing the name of the specific builtin function.
bool isValid() const
Return true if this is a valid SourceLocation object.
CompoundStmt * getSubStmt()
StmtVisitor - This class implements a simple visitor for Stmt subclasses.
void printPretty(raw_ostream &OS, PrinterHelper *Helper, const PrintingPolicy &Policy, unsigned Indentation=0, StringRef NewlineSymbol="\n", const ASTContext *Context=nullptr) const
void printJson(raw_ostream &Out, PrinterHelper *Helper, const PrintingPolicy &Policy, bool AddQuotes) const
Pretty-prints in JSON format.
SourceRange getSourceRange() const LLVM_READONLY
SourceLocation tokens are not useful in isolation - they are low level value objects created/interpre...
void printPrettyControlled(raw_ostream &OS, PrinterHelper *Helper, const PrintingPolicy &Policy, unsigned Indentation=0, StringRef NewlineSymbol="\n", const ASTContext *Context=nullptr) const
Stmt(StmtClass SC, EmptyShell)
Construct an empty statement.
void dumpPretty(const ASTContext &Context) const
dumpPretty/printPretty - These two methods do a "pretty print" of the AST back to its original source...
void outputString(raw_ostream &OS) const
Expr * getReplacement() const
NonTypeTemplateParmDecl * getParameterPack() const
Retrieve the non-type template parameter pack being substituted.
DeclStmt * getConditionVariableDeclStmt()
If this SwitchStmt has a condition variable, return the faux DeclStmt associated with the creation of...
unsigned size() const
Retrieve the number of template arguments in this template argument list.
const TemplateArgument & get(unsigned Idx) const
Retrieve the template argument at a given index.
ArrayRef< TemplateArgument > asArray() const
Produce this as an array ref.
ArrayRef< TemplateArgument > pack_elements() const
Iterator range referencing all of the elements of a template argument pack.
@ Pack
The template argument is actually a parameter pack.
ArgKind getKind() const
Return the kind of stored template argument.
TemplateParameterList * getTemplateParameters() const
Get the list of template parameters.
void print(raw_ostream &Out, const ASTContext &Context, bool OmitTemplateKW=false) const
QualType getType() const
Return the type wrapped by this type source info.
TypeSourceInfo * getArg(unsigned I) const
Retrieve the Ith argument.
unsigned getNumArgs() const
Determine the number of arguments to this type trait.
TypeTrait getTrait() const
Determine which type trait this expression uses.
bool isSignedIntegerType() const
Return true if this is an integer type that is signed, according to C99 6.2.5p4 [char,...
CXXRecordDecl * getAsCXXRecordDecl() const
Retrieves the CXXRecordDecl that this type refers to, either because the type is a RecordType or beca...
const T * castAs() const
Member-template castAs<specific type>.
DeducedType * getContainedDeducedType() const
Get the DeducedType whose type will be deduced for a variable with an initializer of this type.
bool isRecordType() const
QualType getArgumentType() const
bool isArgumentType() const
UnaryExprOrTypeTrait getKind() const
static bool isPostfix(Opcode Op)
isPostfix - Return true if this is a postfix operation, like x++.
Expr * getSubExpr() const
static StringRef getOpcodeStr(Opcode Op)
getOpcodeStr - Turn an Opcode enum value into the punctuation char it corresponds to,...
bool isArrow() const
Determine whether this member expression used the '->' operator; otherwise, it used the '.
Expr * getBase()
Retrieve the base object of this member expressions, e.g., the x in x.m.
bool isImplicitAccess() const
True if this is an implicit access, i.e., one in which the member being accessed was not written in t...
const DeclarationNameInfo & getMemberNameInfo() const
Retrieve the full name info for the member that this expression refers to.
LiteralOperatorKind getLiteralOperatorKind() const
Returns the kind of literal operator invocation which this expression represents.
const IdentifierInfo * getUDSuffix() const
Returns the ud-suffix specified for this literal.
Expr * getCookedLiteral()
If this is not a raw user-defined literal, get the underlying cooked literal (representing the litera...
@ LOK_String
operator "" X (const CharT *, size_t)
@ LOK_Raw
Raw form: operator "" X (const char *)
@ LOK_Floating
operator "" X (long double)
@ LOK_Integer
operator "" X (unsigned long long)
@ LOK_Template
Raw form: operator "" X<cs...> ()
@ LOK_Character
operator "" X (CharT)
const Expr * getSubExpr() const
@ CInit
C-style initialization with assignment.
@ CallInit
Call-style initialization (C++98)
DeclStmt * getConditionVariableDeclStmt()
If this WhileStmt has a condition variable, return the faux DeclStmt associated with the creation of ...
@ OS
Indicates that the tracking object is a descendant of a referenced-counted OSObject,...
The JSON file list parser is used to communicate input to InstallAPI.
OverloadedOperatorKind
Enumeration specifying the different kinds of C++ overloaded operators.
bool isa(CodeGen::Address addr)
@ LCK_ByCopy
Capturing by copy (a.k.a., by value)
@ LCK_ByRef
Capturing by reference.
@ LCK_VLAType
Capturing variable-length array type.
@ LCK_StarThis
Capturing the *this object by copy.
@ LCK_This
Capturing the *this object by reference.
@ If
'if' clause, allowed on all the Compute Constructs, Data Constructs, Executable Constructs,...
nullptr
This class represents a compute construct, representing a 'Kind' of ‘parallel’, 'serial',...
OpenACCComputeConstruct(OpenACCDirectiveKind K, SourceLocation Start, SourceLocation DirectiveLoc, SourceLocation End, ArrayRef< const OpenACCClause * > Clauses, Stmt *StructuredBlock)
raw_ostream & Indent(raw_ostream &Out, const unsigned int Space, bool IsDot)
const FunctionProtoType * T
std::string JsonFormat(StringRef RawSR, bool AddQuotes)
const char * getTraitSpelling(ExpressionTrait T) LLVM_READONLY
Return the spelling of the type trait TT. Never null.
const char * getOperatorSpelling(OverloadedOperatorKind Operator)
Retrieve the spelling of the given overloaded operator, without the preceding "operator" keyword.
U cast(CodeGen::Address addr)
@ ObjCSelf
Parameter for Objective-C 'self' argument.
CXXNewInitializationStyle
ArrayRef< TemplateArgumentLoc > arguments() const
DeclarationName getName() const
getName - Returns the embedded declaration name.
void printName(raw_ostream &OS, PrintingPolicy Policy) const
printName - Print the human-readable name to a stream.
Expr * Value
The value of the dictionary element.
bool isPackExpansion() const
Determines whether this dictionary element is a pack expansion.
Expr * Key
The key for the dictionary element.
Describes how types, statements, expressions, and declarations should be printed.
unsigned Alignof
Whether we can use 'alignof' rather than '__alignof'.
unsigned CleanUglifiedParameters
Whether to strip underscores when printing reserved parameter names.
unsigned ConstantsAsWritten
Whether we should print the constant expressions as written in the sources.
unsigned IncludeNewlines
When true, include newlines after statements like "break", etc.
unsigned TerseOutput
Provide a 'terse' output.
unsigned PrintAsCanonical
Whether to print entities as written or canonically.
unsigned UnderscoreAlignof
Whether we can use '_Alignof' rather than '__alignof'.
unsigned SuppressImplicitBase
When true, don't print the implicit 'self' or 'this' expressions.