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 [[maybe_unused]]
void VisitStmt(Stmt *Node) {
155 Indent() <<
"<<unknown stmt type>>" << NL;
158 [[maybe_unused]]
void VisitExpr(Expr *Node) {
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::VisitDeferStmt(DeferStmt *Node) {
496 PrintControlledStmt(Node->
getBody());
499void StmtPrinter::VisitReturnStmt(ReturnStmt *Node) {
509void StmtPrinter::VisitGCCAsmStmt(GCCAsmStmt *Node) {
526 for (
unsigned i = 0, e = Node->
getNumOutputs(); i != e; ++i) {
547 for (
unsigned i = 0, e = Node->
getNumInputs(); i != e; ++i) {
578 for (
unsigned i = 0, e = Node->
getNumLabels(); i != e; ++i) {
588void StmtPrinter::VisitMSAsmStmt(MSAsmStmt *Node) {
598void StmtPrinter::VisitCapturedStmt(CapturedStmt *Node) {
602void StmtPrinter::VisitSYCLKernelCallStmt(SYCLKernelCallStmt *Node) {
606void StmtPrinter::VisitObjCAtTryStmt(ObjCAtTryStmt *Node) {
608 if (
auto *TS = dyn_cast<CompoundStmt>(Node->
getTryBody())) {
609 PrintRawCompoundStmt(TS);
613 for (ObjCAtCatchStmt *catchStmt : Node->
catch_stmts()) {
615 if (Decl *DS = catchStmt->getCatchParamDecl())
618 if (
auto *CS = dyn_cast<CompoundStmt>(catchStmt->getCatchBody())) {
619 PrintRawCompoundStmt(CS);
626 if (
auto *CS = dyn_cast<CompoundStmt>(FS->getFinallyBody())) {
627 PrintRawCompoundStmt(CS);
633void StmtPrinter::VisitObjCAtFinallyStmt(ObjCAtFinallyStmt *Node) {
636void StmtPrinter::VisitObjCAtCatchStmt (ObjCAtCatchStmt *Node) {
637 Indent() <<
"@catch (...) { /* todo */ } " << NL;
640void StmtPrinter::VisitObjCAtThrowStmt(ObjCAtThrowStmt *Node) {
649void StmtPrinter::VisitObjCAvailabilityCheckExpr(
650 ObjCAvailabilityCheckExpr *Node) {
651 OS <<
"@available(...)";
654void StmtPrinter::VisitObjCAtSynchronizedStmt(ObjCAtSynchronizedStmt *Node) {
655 Indent() <<
"@synchronized (";
662void StmtPrinter::VisitObjCAutoreleasePoolStmt(ObjCAutoreleasePoolStmt *Node) {
663 Indent() <<
"@autoreleasepool";
668void StmtPrinter::PrintRawCXXCatchStmt(CXXCatchStmt *Node) {
671 PrintRawDecl(ExDecl);
678void StmtPrinter::VisitCXXCatchStmt(CXXCatchStmt *Node) {
680 PrintRawCXXCatchStmt(Node);
684void StmtPrinter::VisitCXXTryStmt(CXXTryStmt *Node) {
694void StmtPrinter::VisitSEHTryStmt(SEHTryStmt *Node) {
700 PrintRawSEHExceptHandler(E);
702 assert(F &&
"Must have a finally block...");
703 PrintRawSEHFinallyStmt(F);
708void StmtPrinter::PrintRawSEHFinallyStmt(SEHFinallyStmt *Node) {
710 PrintRawCompoundStmt(Node->
getBlock());
714void StmtPrinter::PrintRawSEHExceptHandler(SEHExceptStmt *Node) {
718 PrintRawCompoundStmt(Node->
getBlock());
722void StmtPrinter::VisitSEHExceptStmt(SEHExceptStmt *Node) {
724 PrintRawSEHExceptHandler(Node);
728void StmtPrinter::VisitSEHFinallyStmt(SEHFinallyStmt *Node) {
730 PrintRawSEHFinallyStmt(Node);
734void StmtPrinter::VisitSEHLeaveStmt(SEHLeaveStmt *Node) {
743void StmtPrinter::VisitOMPCanonicalLoop(OMPCanonicalLoop *Node) {
744 PrintStmt(Node->getLoopStmt());
747void StmtPrinter::PrintOMPExecutableDirective(OMPExecutableDirective *S,
749 unsigned OpenMPVersion =
750 Context ? Context->
getLangOpts().OpenMP : llvm::omp::FallbackVersion;
751 OMPClausePrinter Printer(OS, Policy, OpenMPVersion);
752 ArrayRef<OMPClause *> Clauses = S->clauses();
753 for (
auto *Clause : Clauses)
754 if (Clause && !Clause->isImplicit()) {
756 Printer.Visit(Clause);
759 if (!ForceNoStmt && S->hasAssociatedStmt())
760 PrintStmt(S->getRawStmt());
763void StmtPrinter::VisitOMPMetaDirective(OMPMetaDirective *Node) {
764 Indent() <<
"#pragma omp metadirective";
765 PrintOMPExecutableDirective(Node);
768void StmtPrinter::VisitOMPParallelDirective(OMPParallelDirective *Node) {
769 Indent() <<
"#pragma omp parallel";
770 PrintOMPExecutableDirective(Node);
773void StmtPrinter::VisitOMPSimdDirective(OMPSimdDirective *Node) {
774 Indent() <<
"#pragma omp simd";
775 PrintOMPExecutableDirective(Node);
778void StmtPrinter::VisitOMPTileDirective(OMPTileDirective *Node) {
779 Indent() <<
"#pragma omp tile";
780 PrintOMPExecutableDirective(Node);
783void StmtPrinter::VisitOMPStripeDirective(OMPStripeDirective *Node) {
784 Indent() <<
"#pragma omp stripe";
785 PrintOMPExecutableDirective(Node);
788void StmtPrinter::VisitOMPUnrollDirective(OMPUnrollDirective *Node) {
789 Indent() <<
"#pragma omp unroll";
790 PrintOMPExecutableDirective(Node);
793void StmtPrinter::VisitOMPReverseDirective(OMPReverseDirective *Node) {
794 Indent() <<
"#pragma omp reverse";
795 PrintOMPExecutableDirective(Node);
798void StmtPrinter::VisitOMPInterchangeDirective(OMPInterchangeDirective *Node) {
799 Indent() <<
"#pragma omp interchange";
800 PrintOMPExecutableDirective(Node);
803void StmtPrinter::VisitOMPSplitDirective(OMPSplitDirective *Node) {
804 Indent() <<
"#pragma omp split";
805 PrintOMPExecutableDirective(Node);
808void StmtPrinter::VisitOMPFuseDirective(OMPFuseDirective *Node) {
809 Indent() <<
"#pragma omp fuse";
810 PrintOMPExecutableDirective(Node);
813void StmtPrinter::VisitOMPForDirective(OMPForDirective *Node) {
814 Indent() <<
"#pragma omp for";
815 PrintOMPExecutableDirective(Node);
818void StmtPrinter::VisitOMPForSimdDirective(OMPForSimdDirective *Node) {
819 Indent() <<
"#pragma omp for simd";
820 PrintOMPExecutableDirective(Node);
823void StmtPrinter::VisitOMPSectionsDirective(OMPSectionsDirective *Node) {
824 Indent() <<
"#pragma omp sections";
825 PrintOMPExecutableDirective(Node);
828void StmtPrinter::VisitOMPSectionDirective(OMPSectionDirective *Node) {
829 Indent() <<
"#pragma omp section";
830 PrintOMPExecutableDirective(Node);
833void StmtPrinter::VisitOMPScopeDirective(OMPScopeDirective *Node) {
834 Indent() <<
"#pragma omp scope";
835 PrintOMPExecutableDirective(Node);
838void StmtPrinter::VisitOMPSingleDirective(OMPSingleDirective *Node) {
839 Indent() <<
"#pragma omp single";
840 PrintOMPExecutableDirective(Node);
843void StmtPrinter::VisitOMPMasterDirective(OMPMasterDirective *Node) {
844 Indent() <<
"#pragma omp master";
845 PrintOMPExecutableDirective(Node);
848void StmtPrinter::VisitOMPCriticalDirective(OMPCriticalDirective *Node) {
849 Indent() <<
"#pragma omp critical";
850 if (Node->getDirectiveName().getName()) {
852 Node->getDirectiveName().printName(OS, Policy);
855 PrintOMPExecutableDirective(Node);
858void StmtPrinter::VisitOMPParallelForDirective(OMPParallelForDirective *Node) {
859 Indent() <<
"#pragma omp parallel for";
860 PrintOMPExecutableDirective(Node);
863void StmtPrinter::VisitOMPParallelForSimdDirective(
864 OMPParallelForSimdDirective *Node) {
865 Indent() <<
"#pragma omp parallel for simd";
866 PrintOMPExecutableDirective(Node);
869void StmtPrinter::VisitOMPParallelMasterDirective(
870 OMPParallelMasterDirective *Node) {
871 Indent() <<
"#pragma omp parallel master";
872 PrintOMPExecutableDirective(Node);
875void StmtPrinter::VisitOMPParallelMaskedDirective(
876 OMPParallelMaskedDirective *Node) {
877 Indent() <<
"#pragma omp parallel masked";
878 PrintOMPExecutableDirective(Node);
881void StmtPrinter::VisitOMPParallelSectionsDirective(
882 OMPParallelSectionsDirective *Node) {
883 Indent() <<
"#pragma omp parallel sections";
884 PrintOMPExecutableDirective(Node);
887void StmtPrinter::VisitOMPTaskDirective(OMPTaskDirective *Node) {
888 Indent() <<
"#pragma omp task";
889 PrintOMPExecutableDirective(Node);
892void StmtPrinter::VisitOMPTaskyieldDirective(OMPTaskyieldDirective *Node) {
893 Indent() <<
"#pragma omp taskyield";
894 PrintOMPExecutableDirective(Node);
897void StmtPrinter::VisitOMPBarrierDirective(OMPBarrierDirective *Node) {
898 Indent() <<
"#pragma omp barrier";
899 PrintOMPExecutableDirective(Node);
902void StmtPrinter::VisitOMPTaskwaitDirective(OMPTaskwaitDirective *Node) {
903 Indent() <<
"#pragma omp taskwait";
904 PrintOMPExecutableDirective(Node);
907void StmtPrinter::VisitOMPAssumeDirective(OMPAssumeDirective *Node) {
908 Indent() <<
"#pragma omp assume";
909 PrintOMPExecutableDirective(Node);
912void StmtPrinter::VisitOMPErrorDirective(OMPErrorDirective *Node) {
913 Indent() <<
"#pragma omp error";
914 PrintOMPExecutableDirective(Node);
917void StmtPrinter::VisitOMPTaskgroupDirective(OMPTaskgroupDirective *Node) {
918 Indent() <<
"#pragma omp taskgroup";
919 PrintOMPExecutableDirective(Node);
922void StmtPrinter::VisitOMPFlushDirective(OMPFlushDirective *Node) {
923 Indent() <<
"#pragma omp flush";
924 PrintOMPExecutableDirective(Node);
927void StmtPrinter::VisitOMPDepobjDirective(OMPDepobjDirective *Node) {
928 Indent() <<
"#pragma omp depobj";
929 PrintOMPExecutableDirective(Node);
932void StmtPrinter::VisitOMPScanDirective(OMPScanDirective *Node) {
933 Indent() <<
"#pragma omp scan";
934 PrintOMPExecutableDirective(Node);
937void StmtPrinter::VisitOMPOrderedDirective(OMPOrderedDirective *Node) {
938 Indent() <<
"#pragma omp ordered";
939 PrintOMPExecutableDirective(Node, Node->hasClausesOfKind<OMPDependClause>());
942void StmtPrinter::VisitOMPAtomicDirective(OMPAtomicDirective *Node) {
943 Indent() <<
"#pragma omp atomic";
944 PrintOMPExecutableDirective(Node);
947void StmtPrinter::VisitOMPTargetDirective(OMPTargetDirective *Node) {
948 Indent() <<
"#pragma omp target";
949 PrintOMPExecutableDirective(Node);
952void StmtPrinter::VisitOMPTargetDataDirective(OMPTargetDataDirective *Node) {
953 Indent() <<
"#pragma omp target data";
954 PrintOMPExecutableDirective(Node);
957void StmtPrinter::VisitOMPTargetEnterDataDirective(
958 OMPTargetEnterDataDirective *Node) {
959 Indent() <<
"#pragma omp target enter data";
960 PrintOMPExecutableDirective(Node,
true);
963void StmtPrinter::VisitOMPTargetExitDataDirective(
964 OMPTargetExitDataDirective *Node) {
965 Indent() <<
"#pragma omp target exit data";
966 PrintOMPExecutableDirective(Node,
true);
969void StmtPrinter::VisitOMPTargetParallelDirective(
970 OMPTargetParallelDirective *Node) {
971 Indent() <<
"#pragma omp target parallel";
972 PrintOMPExecutableDirective(Node);
975void StmtPrinter::VisitOMPTargetParallelForDirective(
976 OMPTargetParallelForDirective *Node) {
977 Indent() <<
"#pragma omp target parallel for";
978 PrintOMPExecutableDirective(Node);
981void StmtPrinter::VisitOMPTeamsDirective(OMPTeamsDirective *Node) {
982 Indent() <<
"#pragma omp teams";
983 PrintOMPExecutableDirective(Node);
986void StmtPrinter::VisitOMPCancellationPointDirective(
987 OMPCancellationPointDirective *Node) {
988 unsigned OpenMPVersion =
989 Context ? Context->
getLangOpts().OpenMP : llvm::omp::FallbackVersion;
990 Indent() <<
"#pragma omp cancellation point "
992 PrintOMPExecutableDirective(Node);
995void StmtPrinter::VisitOMPCancelDirective(OMPCancelDirective *Node) {
996 unsigned OpenMPVersion =
997 Context ? Context->
getLangOpts().OpenMP : llvm::omp::FallbackVersion;
998 Indent() <<
"#pragma omp cancel "
1000 PrintOMPExecutableDirective(Node);
1003void StmtPrinter::VisitOMPTaskLoopDirective(OMPTaskLoopDirective *Node) {
1004 Indent() <<
"#pragma omp taskloop";
1005 PrintOMPExecutableDirective(Node);
1008void StmtPrinter::VisitOMPTaskLoopSimdDirective(
1009 OMPTaskLoopSimdDirective *Node) {
1010 Indent() <<
"#pragma omp taskloop simd";
1011 PrintOMPExecutableDirective(Node);
1014void StmtPrinter::VisitOMPMasterTaskLoopDirective(
1015 OMPMasterTaskLoopDirective *Node) {
1016 Indent() <<
"#pragma omp master taskloop";
1017 PrintOMPExecutableDirective(Node);
1020void StmtPrinter::VisitOMPMaskedTaskLoopDirective(
1021 OMPMaskedTaskLoopDirective *Node) {
1022 Indent() <<
"#pragma omp masked taskloop";
1023 PrintOMPExecutableDirective(Node);
1026void StmtPrinter::VisitOMPMasterTaskLoopSimdDirective(
1027 OMPMasterTaskLoopSimdDirective *Node) {
1028 Indent() <<
"#pragma omp master taskloop simd";
1029 PrintOMPExecutableDirective(Node);
1032void StmtPrinter::VisitOMPMaskedTaskLoopSimdDirective(
1033 OMPMaskedTaskLoopSimdDirective *Node) {
1034 Indent() <<
"#pragma omp masked taskloop simd";
1035 PrintOMPExecutableDirective(Node);
1038void StmtPrinter::VisitOMPParallelMasterTaskLoopDirective(
1039 OMPParallelMasterTaskLoopDirective *Node) {
1040 Indent() <<
"#pragma omp parallel master taskloop";
1041 PrintOMPExecutableDirective(Node);
1044void StmtPrinter::VisitOMPParallelMaskedTaskLoopDirective(
1045 OMPParallelMaskedTaskLoopDirective *Node) {
1046 Indent() <<
"#pragma omp parallel masked taskloop";
1047 PrintOMPExecutableDirective(Node);
1050void StmtPrinter::VisitOMPParallelMasterTaskLoopSimdDirective(
1051 OMPParallelMasterTaskLoopSimdDirective *Node) {
1052 Indent() <<
"#pragma omp parallel master taskloop simd";
1053 PrintOMPExecutableDirective(Node);
1056void StmtPrinter::VisitOMPParallelMaskedTaskLoopSimdDirective(
1057 OMPParallelMaskedTaskLoopSimdDirective *Node) {
1058 Indent() <<
"#pragma omp parallel masked taskloop simd";
1059 PrintOMPExecutableDirective(Node);
1062void StmtPrinter::VisitOMPDistributeDirective(OMPDistributeDirective *Node) {
1063 Indent() <<
"#pragma omp distribute";
1064 PrintOMPExecutableDirective(Node);
1067void StmtPrinter::VisitOMPTargetUpdateDirective(
1068 OMPTargetUpdateDirective *Node) {
1069 Indent() <<
"#pragma omp target update";
1070 PrintOMPExecutableDirective(Node,
true);
1073void StmtPrinter::VisitOMPDistributeParallelForDirective(
1074 OMPDistributeParallelForDirective *Node) {
1075 Indent() <<
"#pragma omp distribute parallel for";
1076 PrintOMPExecutableDirective(Node);
1079void StmtPrinter::VisitOMPDistributeParallelForSimdDirective(
1080 OMPDistributeParallelForSimdDirective *Node) {
1081 Indent() <<
"#pragma omp distribute parallel for simd";
1082 PrintOMPExecutableDirective(Node);
1085void StmtPrinter::VisitOMPDistributeSimdDirective(
1086 OMPDistributeSimdDirective *Node) {
1087 Indent() <<
"#pragma omp distribute simd";
1088 PrintOMPExecutableDirective(Node);
1091void StmtPrinter::VisitOMPTargetParallelForSimdDirective(
1092 OMPTargetParallelForSimdDirective *Node) {
1093 Indent() <<
"#pragma omp target parallel for simd";
1094 PrintOMPExecutableDirective(Node);
1097void StmtPrinter::VisitOMPTargetSimdDirective(OMPTargetSimdDirective *Node) {
1098 Indent() <<
"#pragma omp target simd";
1099 PrintOMPExecutableDirective(Node);
1102void StmtPrinter::VisitOMPTeamsDistributeDirective(
1103 OMPTeamsDistributeDirective *Node) {
1104 Indent() <<
"#pragma omp teams distribute";
1105 PrintOMPExecutableDirective(Node);
1108void StmtPrinter::VisitOMPTeamsDistributeSimdDirective(
1109 OMPTeamsDistributeSimdDirective *Node) {
1110 Indent() <<
"#pragma omp teams distribute simd";
1111 PrintOMPExecutableDirective(Node);
1114void StmtPrinter::VisitOMPTeamsDistributeParallelForSimdDirective(
1115 OMPTeamsDistributeParallelForSimdDirective *Node) {
1116 Indent() <<
"#pragma omp teams distribute parallel for simd";
1117 PrintOMPExecutableDirective(Node);
1120void StmtPrinter::VisitOMPTeamsDistributeParallelForDirective(
1121 OMPTeamsDistributeParallelForDirective *Node) {
1122 Indent() <<
"#pragma omp teams distribute parallel for";
1123 PrintOMPExecutableDirective(Node);
1126void StmtPrinter::VisitOMPTargetTeamsDirective(OMPTargetTeamsDirective *Node) {
1127 Indent() <<
"#pragma omp target teams";
1128 PrintOMPExecutableDirective(Node);
1131void StmtPrinter::VisitOMPTargetTeamsDistributeDirective(
1132 OMPTargetTeamsDistributeDirective *Node) {
1133 Indent() <<
"#pragma omp target teams distribute";
1134 PrintOMPExecutableDirective(Node);
1137void StmtPrinter::VisitOMPTargetTeamsDistributeParallelForDirective(
1138 OMPTargetTeamsDistributeParallelForDirective *Node) {
1139 Indent() <<
"#pragma omp target teams distribute parallel for";
1140 PrintOMPExecutableDirective(Node);
1143void StmtPrinter::VisitOMPTargetTeamsDistributeParallelForSimdDirective(
1144 OMPTargetTeamsDistributeParallelForSimdDirective *Node) {
1145 Indent() <<
"#pragma omp target teams distribute parallel for simd";
1146 PrintOMPExecutableDirective(Node);
1149void StmtPrinter::VisitOMPTargetTeamsDistributeSimdDirective(
1150 OMPTargetTeamsDistributeSimdDirective *Node) {
1151 Indent() <<
"#pragma omp target teams distribute simd";
1152 PrintOMPExecutableDirective(Node);
1155void StmtPrinter::VisitOMPInteropDirective(OMPInteropDirective *Node) {
1156 Indent() <<
"#pragma omp interop";
1157 PrintOMPExecutableDirective(Node);
1160void StmtPrinter::VisitOMPDispatchDirective(OMPDispatchDirective *Node) {
1161 Indent() <<
"#pragma omp dispatch";
1162 PrintOMPExecutableDirective(Node);
1165void StmtPrinter::VisitOMPMaskedDirective(OMPMaskedDirective *Node) {
1166 Indent() <<
"#pragma omp masked";
1167 PrintOMPExecutableDirective(Node);
1170void StmtPrinter::VisitOMPGenericLoopDirective(OMPGenericLoopDirective *Node) {
1171 Indent() <<
"#pragma omp loop";
1172 PrintOMPExecutableDirective(Node);
1175void StmtPrinter::VisitOMPTeamsGenericLoopDirective(
1176 OMPTeamsGenericLoopDirective *Node) {
1177 Indent() <<
"#pragma omp teams loop";
1178 PrintOMPExecutableDirective(Node);
1181void StmtPrinter::VisitOMPTargetTeamsGenericLoopDirective(
1182 OMPTargetTeamsGenericLoopDirective *Node) {
1183 Indent() <<
"#pragma omp target teams loop";
1184 PrintOMPExecutableDirective(Node);
1187void StmtPrinter::VisitOMPParallelGenericLoopDirective(
1188 OMPParallelGenericLoopDirective *Node) {
1189 Indent() <<
"#pragma omp parallel loop";
1190 PrintOMPExecutableDirective(Node);
1193void StmtPrinter::VisitOMPTargetParallelGenericLoopDirective(
1194 OMPTargetParallelGenericLoopDirective *Node) {
1195 Indent() <<
"#pragma omp target parallel loop";
1196 PrintOMPExecutableDirective(Node);
1202void StmtPrinter::PrintOpenACCClauseList(OpenACCConstructStmt *S) {
1205 OpenACCClausePrinter Printer(OS, Policy);
1206 Printer.VisitClauseList(S->
clauses());
1209void StmtPrinter::PrintOpenACCConstruct(OpenACCConstructStmt *S) {
1211 PrintOpenACCClauseList(S);
1215 PrintOpenACCConstruct(S);
1216 PrintStmt(S->getStructuredBlock());
1219void StmtPrinter::VisitOpenACCLoopConstruct(OpenACCLoopConstruct *S) {
1220 PrintOpenACCConstruct(S);
1224void StmtPrinter::VisitOpenACCCombinedConstruct(OpenACCCombinedConstruct *S) {
1225 PrintOpenACCConstruct(S);
1229void StmtPrinter::VisitOpenACCDataConstruct(OpenACCDataConstruct *S) {
1230 PrintOpenACCConstruct(S);
1233void StmtPrinter::VisitOpenACCHostDataConstruct(OpenACCHostDataConstruct *S) {
1234 PrintOpenACCConstruct(S);
1237void StmtPrinter::VisitOpenACCEnterDataConstruct(OpenACCEnterDataConstruct *S) {
1238 PrintOpenACCConstruct(S);
1240void StmtPrinter::VisitOpenACCExitDataConstruct(OpenACCExitDataConstruct *S) {
1241 PrintOpenACCConstruct(S);
1243void StmtPrinter::VisitOpenACCInitConstruct(OpenACCInitConstruct *S) {
1244 PrintOpenACCConstruct(S);
1246void StmtPrinter::VisitOpenACCShutdownConstruct(OpenACCShutdownConstruct *S) {
1247 PrintOpenACCConstruct(S);
1249void StmtPrinter::VisitOpenACCSetConstruct(OpenACCSetConstruct *S) {
1250 PrintOpenACCConstruct(S);
1252void StmtPrinter::VisitOpenACCUpdateConstruct(OpenACCUpdateConstruct *S) {
1253 PrintOpenACCConstruct(S);
1256void StmtPrinter::VisitOpenACCWaitConstruct(OpenACCWaitConstruct *S) {
1257 Indent() <<
"#pragma acc wait";
1270 E->printPretty(OS, nullptr, Policy);
1276 PrintOpenACCClauseList(S);
1280void StmtPrinter::VisitOpenACCAtomicConstruct(OpenACCAtomicConstruct *S) {
1281 Indent() <<
"#pragma acc atomic";
1286 PrintOpenACCClauseList(S);
1291void StmtPrinter::VisitOpenACCCacheConstruct(OpenACCCacheConstruct *S) {
1292 Indent() <<
"#pragma acc cache(";
1296 llvm::interleaveComma(S->
getVarList(), OS, [&](
const Expr *E) {
1297 E->printPretty(OS, nullptr, Policy);
1307void StmtPrinter::VisitSourceLocExpr(SourceLocExpr *Node) {
1311void StmtPrinter::VisitEmbedExpr(EmbedExpr *Node) {
1319void StmtPrinter::VisitConstantExpr(ConstantExpr *Node) {
1323void StmtPrinter::VisitDeclRefExpr(DeclRefExpr *Node) {
1324 ValueDecl *VD = Node->
getDecl();
1325 if (
const auto *OCED = dyn_cast<OMPCapturedExprDecl>(VD)) {
1326 OCED->getInit()->IgnoreImpCasts()->printPretty(OS,
nullptr, Policy);
1329 if (
const auto *TPOD = dyn_cast<TemplateParamObjectDecl>(VD)) {
1330 TPOD->printAsExpr(OS, Policy);
1337 bool ForceAnonymous =
1339 DeclarationNameInfo NameInfo = Node->
getNameInfo();
1345 OS <<
ID->deuglifiedName();
1350 case Decl::NonTypeTemplateParm: {
1352 OS <<
"value-parameter-" << TD->getDepth() <<
'-' << TD->getIndex() <<
"";
1355 case Decl::ParmVar: {
1357 OS <<
"function-parameter-" << PD->getFunctionScopeDepth() <<
'-'
1358 << PD->getFunctionScopeIndex();
1361 case Decl::Decomposition:
1362 OS <<
"decomposition";
1364 OS <<
'-' << I->getName();
1372 const TemplateParameterList *TPL =
nullptr;
1374 if (
auto *TD = dyn_cast<TemplateDecl>(VD))
1375 TPL = TD->getTemplateParameters();
1380void StmtPrinter::VisitDependentScopeDeclRefExpr(
1381 DependentScopeDeclRefExpr *Node) {
1390void StmtPrinter::VisitUnresolvedLookupExpr(UnresolvedLookupExpr *Node) {
1400 if (
const auto *DRE = dyn_cast<DeclRefExpr>(E)) {
1401 if (
const auto *PD = dyn_cast<ImplicitParamDecl>(DRE->getDecl())) {
1403 DRE->getBeginLoc().isInvalid())
1410void StmtPrinter::VisitObjCIvarRefExpr(ObjCIvarRefExpr *Node) {
1421void StmtPrinter::VisitObjCPropertyRefExpr(ObjCPropertyRefExpr *Node) {
1433 Getter->getSelector().print(OS);
1441void StmtPrinter::VisitObjCSubscriptRefExpr(ObjCSubscriptRefExpr *Node) {
1448void StmtPrinter::VisitSYCLUniqueStableNameExpr(
1449 SYCLUniqueStableNameExpr *Node) {
1450 OS <<
"__builtin_sycl_unique_stable_name(";
1455void StmtPrinter::VisitUnresolvedSYCLKernelCallStmt(
1456 UnresolvedSYCLKernelCallStmt *Node) {
1460void StmtPrinter::VisitPredefinedExpr(PredefinedExpr *Node) {
1464void StmtPrinter::VisitOpenACCAsteriskSizeExpr(OpenACCAsteriskSizeExpr *Node) {
1468void StmtPrinter::VisitCharacterLiteral(CharacterLiteral *Node) {
1481 Context->getSourceManager(), Context->getLangOpts(), &
Invalid);
1489void StmtPrinter::VisitIntegerLiteral(IntegerLiteral *Node) {
1496 OS << (isSigned ?
"wb" :
"uwb");
1501 switch (Node->
getType()->
castAs<BuiltinType>()->getKind()) {
1502 default: llvm_unreachable(
"Unexpected type for integer literal!");
1503 case BuiltinType::Char_S:
1504 case BuiltinType::Char_U:
OS <<
"i8";
break;
1505 case BuiltinType::UChar:
OS <<
"Ui8";
break;
1506 case BuiltinType::SChar:
OS <<
"i8";
break;
1507 case BuiltinType::Short:
OS <<
"i16";
break;
1508 case BuiltinType::UShort:
OS <<
"Ui16";
break;
1509 case BuiltinType::Int:
break;
1510 case BuiltinType::UInt:
OS <<
'U';
break;
1511 case BuiltinType::Long:
OS <<
'L';
break;
1512 case BuiltinType::ULong:
OS <<
"UL";
break;
1513 case BuiltinType::LongLong:
OS <<
"LL";
break;
1514 case BuiltinType::ULongLong:
OS <<
"ULL";
break;
1515 case BuiltinType::Int128:
1517 case BuiltinType::UInt128:
1519 case BuiltinType::WChar_S:
1520 case BuiltinType::WChar_U:
1525void StmtPrinter::VisitFixedPointLiteral(FixedPointLiteral *Node) {
1530 switch (Node->
getType()->
castAs<BuiltinType>()->getKind()) {
1531 default: llvm_unreachable(
"Unexpected type for fixed point literal!");
1532 case BuiltinType::ShortFract:
OS <<
"hr";
break;
1533 case BuiltinType::ShortAccum:
OS <<
"hk";
break;
1534 case BuiltinType::UShortFract:
OS <<
"uhr";
break;
1535 case BuiltinType::UShortAccum:
OS <<
"uhk";
break;
1536 case BuiltinType::Fract:
OS <<
"r";
break;
1537 case BuiltinType::Accum:
OS <<
"k";
break;
1538 case BuiltinType::UFract:
OS <<
"ur";
break;
1539 case BuiltinType::UAccum:
OS <<
"uk";
break;
1540 case BuiltinType::LongFract:
OS <<
"lr";
break;
1541 case BuiltinType::LongAccum:
OS <<
"lk";
break;
1542 case BuiltinType::ULongFract:
OS <<
"ulr";
break;
1543 case BuiltinType::ULongAccum:
OS <<
"ulk";
break;
1552 if (Str.find_first_not_of(
"-0123456789") == StringRef::npos)
1560 default: llvm_unreachable(
"Unexpected type for float literal!");
1561 case BuiltinType::Half:
break;
1562 case BuiltinType::Ibm128:
break;
1563 case BuiltinType::Double:
break;
1564 case BuiltinType::Float16: OS <<
"F16";
break;
1565 case BuiltinType::Float: OS <<
'F';
break;
1566 case BuiltinType::LongDouble: OS <<
'L';
break;
1567 case BuiltinType::Float128: OS <<
'Q';
break;
1571void StmtPrinter::VisitFloatingLiteral(FloatingLiteral *Node) {
1577void StmtPrinter::VisitImaginaryLiteral(ImaginaryLiteral *Node) {
1582void StmtPrinter::VisitStringLiteral(StringLiteral *Str) {
1586void StmtPrinter::VisitParenExpr(ParenExpr *Node) {
1592void StmtPrinter::VisitUnaryOperator(UnaryOperator *Node) {
1618void StmtPrinter::VisitOffsetOfExpr(OffsetOfExpr *Node) {
1619 OS <<
"__builtin_offsetof(";
1622 bool PrintedSomething =
false;
1630 PrintedSomething =
true;
1643 if (PrintedSomething)
1646 PrintedSomething =
true;
1652void StmtPrinter::VisitUnaryExprOrTypeTraitExpr(
1653 UnaryExprOrTypeTraitExpr *Node) {
1655 if (Node->
getKind() == UETT_AlignOf) {
1657 Spelling =
"alignof";
1659 Spelling =
"_Alignof";
1661 Spelling =
"__alignof";
1676void StmtPrinter::VisitGenericSelectionExpr(GenericSelectionExpr *Node) {
1685 QualType T = Assoc.getType();
1689 T.
print(OS, Policy);
1691 PrintExpr(Assoc.getAssociationExpr());
1696void StmtPrinter::VisitArraySubscriptExpr(ArraySubscriptExpr *Node) {
1697 PrintExpr(Node->
getLHS());
1699 PrintExpr(Node->
getRHS());
1703void StmtPrinter::VisitMatrixSingleSubscriptExpr(
1704 MatrixSingleSubscriptExpr *Node) {
1711void StmtPrinter::VisitMatrixSubscriptExpr(MatrixSubscriptExpr *Node) {
1721void StmtPrinter::VisitArraySectionExpr(ArraySectionExpr *Node) {
1739void StmtPrinter::VisitOMPArrayShapingExpr(OMPArrayShapingExpr *Node) {
1750void StmtPrinter::VisitOMPIteratorExpr(OMPIteratorExpr *Node) {
1757 PrintExpr(
Range.Begin);
1759 PrintExpr(
Range.End);
1762 PrintExpr(
Range.Step);
1770void StmtPrinter::PrintCallArgs(CallExpr *
Call) {
1771 for (
unsigned i = 0, e =
Call->getNumArgs(); i != e; ++i) {
1778 PrintExpr(
Call->getArg(i));
1782void StmtPrinter::VisitCallExpr(CallExpr *
Call) {
1783 PrintExpr(
Call->getCallee());
1785 PrintCallArgs(
Call);
1790 if (
const auto *TE = dyn_cast<CXXThisExpr>(E))
1791 return TE->isImplicit();
1795void StmtPrinter::VisitMemberExpr(MemberExpr *Node) {
1799 auto *ParentMember = dyn_cast<MemberExpr>(Node->
getBase());
1800 FieldDecl *ParentDecl =
1801 ParentMember ? dyn_cast<FieldDecl>(ParentMember->getMemberDecl())
1809 if (FD->isAnonymousStructOrUnion())
1816 const TemplateParameterList *TPL =
nullptr;
1817 if (
auto *FD = dyn_cast<FunctionDecl>(Node->
getMemberDecl())) {
1819 if (
auto *FTD = FD->getPrimaryTemplate())
1820 TPL = FTD->getTemplateParameters();
1821 }
else if (
auto *VTSD =
1822 dyn_cast<VarTemplateSpecializationDecl>(Node->
getMemberDecl()))
1823 TPL = VTSD->getSpecializedTemplate()->getTemplateParameters();
1828void StmtPrinter::VisitObjCIsaExpr(ObjCIsaExpr *Node) {
1830 OS << (Node->
isArrow() ?
"->isa" :
".isa");
1833void StmtPrinter::VisitExtVectorElementExpr(ExtVectorElementExpr *Node) {
1839void StmtPrinter::VisitMatrixElementExpr(MatrixElementExpr *Node) {
1845void StmtPrinter::VisitCStyleCastExpr(CStyleCastExpr *Node) {
1852void StmtPrinter::VisitCompoundLiteralExpr(CompoundLiteralExpr *Node) {
1859void StmtPrinter::VisitImplicitCastExpr(ImplicitCastExpr *Node) {
1864void StmtPrinter::VisitBinaryOperator(BinaryOperator *Node) {
1865 PrintExpr(Node->
getLHS());
1867 PrintExpr(Node->
getRHS());
1870void StmtPrinter::VisitCompoundAssignOperator(CompoundAssignOperator *Node) {
1871 PrintExpr(Node->
getLHS());
1873 PrintExpr(Node->
getRHS());
1876void StmtPrinter::VisitConditionalOperator(ConditionalOperator *Node) {
1879 PrintExpr(Node->
getLHS());
1881 PrintExpr(Node->
getRHS());
1887StmtPrinter::VisitBinaryConditionalOperator(BinaryConditionalOperator *Node) {
1893void StmtPrinter::VisitAddrLabelExpr(AddrLabelExpr *Node) {
1897void StmtPrinter::VisitStmtExpr(StmtExpr *E) {
1903void StmtPrinter::VisitChooseExpr(ChooseExpr *Node) {
1904 OS <<
"__builtin_choose_expr(";
1907 PrintExpr(Node->
getLHS());
1909 PrintExpr(Node->
getRHS());
1913void StmtPrinter::VisitGNUNullExpr(GNUNullExpr *) {
1917void StmtPrinter::VisitShuffleVectorExpr(ShuffleVectorExpr *Node) {
1918 OS <<
"__builtin_shufflevector(";
1926void StmtPrinter::VisitConvertVectorExpr(ConvertVectorExpr *Node) {
1927 OS <<
"__builtin_convertvector(";
1934void StmtPrinter::VisitInitListExpr(InitListExpr* Node) {
1941 for (
unsigned i = 0, e = Node->
getNumInits(); i != e; ++i) {
1951void StmtPrinter::VisitArrayInitLoopExpr(ArrayInitLoopExpr *Node) {
1959void StmtPrinter::VisitArrayInitIndexExpr(ArrayInitIndexExpr *Node) {
1963void StmtPrinter::VisitParenListExpr(ParenListExpr* Node) {
1965 for (
unsigned i = 0, e = Node->
getNumExprs(); i != e; ++i) {
1972void StmtPrinter::VisitDesignatedInitExpr(DesignatedInitExpr *Node) {
1973 bool NeedsEquals =
true;
1974 for (
const DesignatedInitExpr::Designator &D : Node->
designators()) {
1975 if (D.isFieldDesignator()) {
1976 if (D.getDotLoc().isInvalid()) {
1977 if (
const IdentifierInfo *II = D.getFieldName()) {
1978 OS << II->getName() <<
":";
1979 NeedsEquals =
false;
1982 OS <<
"." << D.getFieldName()->getName();
1986 if (D.isArrayDesignator()) {
2004void StmtPrinter::VisitDesignatedInitUpdateExpr(
2005 DesignatedInitUpdateExpr *Node) {
2011 OS <<
"/*updater*/";
2016void StmtPrinter::VisitNoInitExpr(NoInitExpr *Node) {
2017 OS <<
"/*no init*/";
2020void StmtPrinter::VisitImplicitValueInitExpr(ImplicitValueInitExpr *Node) {
2022 OS <<
"/*implicit*/";
2026 OS <<
"/*implicit*/(";
2036void StmtPrinter::VisitVAArgExpr(VAArgExpr *Node) {
2037 OS <<
"__builtin_va_arg(";
2044void StmtPrinter::VisitPseudoObjectExpr(PseudoObjectExpr *Node) {
2048void StmtPrinter::VisitAtomicExpr(AtomicExpr *Node) {
2049 const char *Name =
nullptr;
2050 switch (Node->
getOp()) {
2051#define ATOMIC_BUILTIN(ID, TYPE, ATTRS) \
2052 case AtomicExpr::AO ## ID: \
2055#include "clang/Basic/Builtins.inc"
2060 PrintExpr(Node->
getPtr());
2065 if (Node->
getOp() == AtomicExpr::AO__atomic_exchange ||
2070 if (Node->
getOp() == AtomicExpr::AO__atomic_compare_exchange ||
2071 Node->
getOp() == AtomicExpr::AO__atomic_compare_exchange_n) {
2075 if (Node->
getOp() != AtomicExpr::AO__c11_atomic_init &&
2076 Node->
getOp() != AtomicExpr::AO__opencl_atomic_init) {
2088void StmtPrinter::VisitCXXOperatorCallExpr(CXXOperatorCallExpr *Node) {
2090 if (Kind == OO_PlusPlus || Kind == OO_MinusMinus) {
2093 PrintExpr(Node->
getArg(0));
2095 PrintExpr(Node->
getArg(0));
2098 }
else if (Kind == OO_Arrow) {
2099 PrintExpr(Node->
getArg(0));
2100 }
else if (Kind == OO_Call || Kind == OO_Subscript) {
2101 PrintExpr(Node->
getArg(0));
2102 OS << (
Kind == OO_Call ?
'(' :
'[');
2103 for (
unsigned ArgIdx = 1; ArgIdx < Node->
getNumArgs(); ++ArgIdx) {
2107 PrintExpr(Node->
getArg(ArgIdx));
2109 OS << (
Kind == OO_Call ?
')' :
']');
2112 PrintExpr(Node->
getArg(0));
2114 PrintExpr(Node->
getArg(0));
2116 PrintExpr(Node->
getArg(1));
2118 llvm_unreachable(
"unknown overloaded operator");
2122void StmtPrinter::VisitCXXMemberCallExpr(CXXMemberCallExpr *Node) {
2125 if (isa_and_nonnull<CXXConversionDecl>(MD)) {
2132void StmtPrinter::VisitCUDAKernelCallExpr(CUDAKernelCallExpr *Node) {
2137 PrintCallArgs(Node);
2141void StmtPrinter::VisitCXXRewrittenBinaryOperator(
2142 CXXRewrittenBinaryOperator *Node) {
2143 CXXRewrittenBinaryOperator::DecomposedForm Decomposed =
2145 PrintExpr(
const_cast<Expr*
>(Decomposed.
LHS));
2147 PrintExpr(
const_cast<Expr*
>(Decomposed.
RHS));
2150void StmtPrinter::VisitCXXNamedCastExpr(CXXNamedCastExpr *Node) {
2158void StmtPrinter::VisitCXXStaticCastExpr(CXXStaticCastExpr *Node) {
2159 VisitCXXNamedCastExpr(Node);
2162void StmtPrinter::VisitCXXDynamicCastExpr(CXXDynamicCastExpr *Node) {
2163 VisitCXXNamedCastExpr(Node);
2166void StmtPrinter::VisitCXXReinterpretCastExpr(CXXReinterpretCastExpr *Node) {
2167 VisitCXXNamedCastExpr(Node);
2170void StmtPrinter::VisitCXXConstCastExpr(CXXConstCastExpr *Node) {
2171 VisitCXXNamedCastExpr(Node);
2174void StmtPrinter::VisitBuiltinBitCastExpr(BuiltinBitCastExpr *Node) {
2175 OS <<
"__builtin_bit_cast(";
2182void StmtPrinter::VisitCXXAddrspaceCastExpr(CXXAddrspaceCastExpr *Node) {
2183 VisitCXXNamedCastExpr(Node);
2186void StmtPrinter::VisitCXXTypeidExpr(CXXTypeidExpr *Node) {
2196void StmtPrinter::VisitCXXUuidofExpr(CXXUuidofExpr *Node) {
2206void StmtPrinter::VisitMSPropertyRefExpr(MSPropertyRefExpr *Node) {
2216void StmtPrinter::VisitMSPropertySubscriptExpr(MSPropertySubscriptExpr *Node) {
2219 PrintExpr(Node->
getIdx());
2223void StmtPrinter::VisitUserDefinedLiteral(UserDefinedLiteral *Node) {
2230 const TemplateArgumentList *Args =
2235 const TemplateParameterList *TPL =
nullptr;
2236 if (!DRE->hadMultipleCandidates())
2237 if (
const auto *TD = dyn_cast<TemplateDecl>(DRE->getDecl()))
2238 TPL = TD->getTemplateParameters();
2240 printTemplateArgumentList(OS, Args->
asArray(), Policy, TPL);
2245 const TemplateArgument &Pack = Args->
get(0);
2247 char C = (char)P.getAsIntegral().getZExtValue();
2272void StmtPrinter::VisitCXXBoolLiteralExpr(CXXBoolLiteralExpr *Node) {
2276void StmtPrinter::VisitCXXNullPtrLiteralExpr(CXXNullPtrLiteralExpr *Node) {
2280void StmtPrinter::VisitCXXThisExpr(CXXThisExpr *Node) {
2284void StmtPrinter::VisitCXXThrowExpr(CXXThrowExpr *Node) {
2293void StmtPrinter::VisitCXXDefaultArgExpr(CXXDefaultArgExpr *Node) {
2297void StmtPrinter::VisitCXXDefaultInitExpr(CXXDefaultInitExpr *Node) {
2301void StmtPrinter::VisitCXXFunctionalCastExpr(CXXFunctionalCastExpr *Node) {
2302 auto TargetType = Node->
getType();
2304 bool Bare =
Auto &&
Auto->isDeduced();
2309 TargetType.print(OS, Policy);
2321void StmtPrinter::VisitCXXBindTemporaryExpr(CXXBindTemporaryExpr *Node) {
2325void StmtPrinter::VisitCXXTemporaryObjectExpr(CXXTemporaryObjectExpr *Node) {
2333 for (CXXTemporaryObjectExpr::arg_iterator Arg = Node->
arg_begin(),
2335 Arg != ArgEnd; ++Arg) {
2336 if ((*Arg)->isDefaultArgument())
2350void StmtPrinter::VisitLambdaExpr(
LambdaExpr *Node) {
2352 bool NeedComma =
false;
2371 if (
C->capturesVLAType())
2378 switch (
C->getCaptureKind()) {
2390 OS <<
C->getCapturedVar()->getName();
2394 OS <<
C->getCapturedVar()->getName();
2398 llvm_unreachable(
"VLA type in explicit captures.");
2401 if (
C->isPackExpansion())
2408 llvm::StringRef
Pre;
2409 llvm::StringRef
Post;
2419 PrintExpr(D->getInit());
2435 for (
const auto *P :
Method->parameters()) {
2441 std::string ParamStr =
2443 ? P->getIdentifier()->deuglifiedName().str()
2444 : P->getNameAsString();
2445 P->getOriginalType().print(OS, Policy, ParamStr);
2447 if (
Method->isVariadic()) {
2457 auto *Proto =
Method->getType()->castAs<FunctionProtoType>();
2458 Proto->printExceptionSpecification(OS, Policy);
2465 Proto->getReturnType().print(OS, Policy);
2477void StmtPrinter::VisitCXXScalarValueInitExpr(CXXScalarValueInitExpr *Node) {
2479 TSInfo->getType().print(OS, Policy);
2485void StmtPrinter::VisitCXXNewExpr(CXXNewExpr *E) {
2493 for (
unsigned i = 1; i < NumPlace; ++i) {
2505 llvm::raw_string_ostream
s(TypeS);
2508 (*Size)->printPretty(
s, Helper, Policy);
2516 if (InitStyle != CXXNewInitializationStyle::None) {
2517 bool Bare = InitStyle == CXXNewInitializationStyle::Parens &&
2527void StmtPrinter::VisitCXXDeleteExpr(CXXDeleteExpr *E) {
2536void StmtPrinter::VisitCXXPseudoDestructorExpr(CXXPseudoDestructorExpr *E) {
2546 OS << II->getName();
2551void StmtPrinter::VisitCXXConstructExpr(CXXConstructExpr *E) {
2555 for (
unsigned i = 0, e = E->
getNumArgs(); i != e; ++i) {
2569void StmtPrinter::VisitCXXInheritedCtorInitExpr(CXXInheritedCtorInitExpr *E) {
2571 OS <<
"<forwarded>";
2574void StmtPrinter::VisitCXXStdInitializerListExpr(CXXStdInitializerListExpr *E) {
2578void StmtPrinter::VisitExprWithCleanups(ExprWithCleanups *E) {
2583void StmtPrinter::VisitCXXUnresolvedConstructExpr(
2584 CXXUnresolvedConstructExpr *Node) {
2588 for (
auto Arg = Node->
arg_begin(), ArgEnd = Node->
arg_end(); Arg != ArgEnd;
2598void StmtPrinter::VisitCXXReflectExpr(CXXReflectExpr *S) {
2600 assert(
false &&
"not implemented yet");
2603void StmtPrinter::VisitCXXDependentScopeMemberExpr(
2604 CXXDependentScopeMemberExpr *Node) {
2617void StmtPrinter::VisitUnresolvedMemberExpr(UnresolvedMemberExpr *Node) {
2630void StmtPrinter::VisitTypeTraitExpr(TypeTraitExpr *E) {
2632 for (
unsigned I = 0, N = E->
getNumArgs(); I != N; ++I) {
2640void StmtPrinter::VisitArrayTypeTraitExpr(ArrayTypeTraitExpr *E) {
2646void StmtPrinter::VisitExpressionTraitExpr(ExpressionTraitExpr *E) {
2652void StmtPrinter::VisitCXXNoexceptExpr(CXXNoexceptExpr *E) {
2658void StmtPrinter::VisitPackExpansionExpr(PackExpansionExpr *E) {
2663void StmtPrinter::VisitSizeOfPackExpr(SizeOfPackExpr *E) {
2664 OS <<
"sizeof...(" << *E->
getPack() <<
")";
2667void StmtPrinter::VisitPackIndexingExpr(PackIndexingExpr *E) {
2674void StmtPrinter::VisitSubstNonTypeTemplateParmPackExpr(
2675 SubstNonTypeTemplateParmPackExpr *Node) {
2679void StmtPrinter::VisitSubstNonTypeTemplateParmExpr(
2680 SubstNonTypeTemplateParmExpr *Node) {
2684void StmtPrinter::VisitFunctionParmPackExpr(FunctionParmPackExpr *E) {
2688void StmtPrinter::VisitMaterializeTemporaryExpr(MaterializeTemporaryExpr *Node){
2692void StmtPrinter::VisitCXXFoldExpr(CXXFoldExpr *E) {
2706void StmtPrinter::VisitCXXParenListInitExpr(CXXParenListInitExpr *Node) {
2708 [&](Expr *E) { PrintExpr(E); });
2711void StmtPrinter::VisitConceptSpecializationExpr(ConceptSpecializationExpr *E) {
2725 if (!LocalParameters.empty()) {
2727 for (ParmVarDecl *LocalParam : LocalParameters) {
2728 PrintRawDecl(LocalParam);
2729 if (LocalParam != LocalParameters.back())
2737 for (concepts::Requirement *Req : Requirements) {
2738 if (
auto *TypeReq = dyn_cast<concepts::TypeRequirement>(Req)) {
2739 if (TypeReq->isSubstitutionFailure())
2740 OS <<
"<<error-type>>";
2742 TypeReq->getType()->getType().print(OS, Policy);
2743 }
else if (
auto *ExprReq = dyn_cast<concepts::ExprRequirement>(Req)) {
2744 if (ExprReq->isCompound())
2746 if (ExprReq->isExprSubstitutionFailure())
2747 OS <<
"<<error-expression>>";
2749 PrintExpr(ExprReq->getExpr());
2750 if (ExprReq->isCompound()) {
2752 if (ExprReq->getNoexceptLoc().isValid())
2754 const auto &RetReq = ExprReq->getReturnTypeRequirement();
2755 if (!RetReq.isEmpty()) {
2757 if (RetReq.isSubstitutionFailure())
2758 OS <<
"<<error-type>>";
2759 else if (RetReq.isTypeConstraint())
2760 RetReq.getTypeConstraint()->print(OS, Policy);
2766 if (NestedReq->hasInvalidConstraint())
2767 OS <<
"<<error-expression>>";
2769 PrintExpr(NestedReq->getConstraintExpr());
2778void StmtPrinter::VisitCoroutineBodyStmt(CoroutineBodyStmt *S) {
2782void StmtPrinter::VisitCoreturnStmt(CoreturnStmt *S) {
2791void StmtPrinter::VisitCoawaitExpr(CoawaitExpr *S) {
2796void StmtPrinter::VisitDependentCoawaitExpr(DependentCoawaitExpr *S) {
2801void StmtPrinter::VisitCoyieldExpr(CoyieldExpr *S) {
2808void StmtPrinter::VisitObjCStringLiteral(ObjCStringLiteral *Node) {
2813void StmtPrinter::VisitObjCBoxedExpr(ObjCBoxedExpr *E) {
2818void StmtPrinter::VisitObjCArrayLiteral(ObjCArrayLiteral *E) {
2820 ObjCArrayLiteral::child_range Ch = E->
children();
2821 for (
auto I = Ch.begin(), E = Ch.end(); I != E; ++I) {
2822 if (I != Ch.begin())
2829void StmtPrinter::VisitObjCDictionaryLiteral(ObjCDictionaryLiteral *E) {
2838 Visit(Element.
Value);
2845void StmtPrinter::VisitObjCEncodeExpr(ObjCEncodeExpr *Node) {
2851void StmtPrinter::VisitObjCSelectorExpr(ObjCSelectorExpr *Node) {
2857void StmtPrinter::VisitObjCProtocolExpr(ObjCProtocolExpr *Node) {
2861void StmtPrinter::VisitObjCMessageExpr(ObjCMessageExpr *Mess) {
2883 for (
unsigned i = 0, e = Mess->
getNumArgs(); i != e; ++i) {
2885 if (i > 0)
OS <<
' ';
2893 PrintExpr(Mess->
getArg(i));
2899void StmtPrinter::VisitObjCBoolLiteralExpr(ObjCBoolLiteralExpr *Node) {
2900 OS << (Node->
getValue() ?
"__objc_yes" :
"__objc_no");
2904StmtPrinter::VisitObjCIndirectCopyRestoreExpr(ObjCIndirectCopyRestoreExpr *E) {
2909StmtPrinter::VisitObjCBridgedCastExpr(ObjCBridgedCastExpr *E) {
2916void StmtPrinter::VisitBlockExpr(BlockExpr *Node) {
2929 std::string ParamStr = (*AI)->getNameAsString();
2930 (*AI)->getType().print(OS, Policy, ParamStr);
2934 if (FT->isVariadic()) {
2943void StmtPrinter::VisitOpaqueValueExpr(OpaqueValueExpr *Node) {
2947void StmtPrinter::VisitRecoveryExpr(RecoveryExpr *Node) {
2948 OS <<
"<recovery-expr>(";
2949 const char *Sep =
"";
2958void StmtPrinter::VisitAsTypeExpr(AsTypeExpr *Node) {
2959 OS <<
"__builtin_astype(";
2966void StmtPrinter::VisitHLSLOutArgExpr(HLSLOutArgExpr *Node) {
2980 StringRef NL,
const ASTContext *Context)
const {
2981 StmtPrinter P(Out, Helper, Policy, Indentation, NL, Context);
2982 P.Visit(
const_cast<Stmt *
>(
this));
2987 unsigned Indentation, StringRef NL,
2989 StmtPrinter P(Out, Helper, Policy, Indentation, NL, Context);
2990 P.PrintControlledStmt(
const_cast<Stmt *
>(
this));
2996 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
bool hasVal1Operand() 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
IdentifierInfo & getAccessor() const
const Expr * getBase() 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
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
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.
bool isNull() const
Return true if this QualType doesn't point to a type yet.
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.
CompoundStmt * getOriginalStmt()
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.
CompoundStmt * getOriginalStmt()
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)
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 SuppressLambdaBody
Whether to suppress printing the body of a lambda.
unsigned UnderscoreAlignof
Whether we can use '_Alignof' rather than '__alignof'.
unsigned SuppressImplicitBase
When true, don't print the implicit 'self' or 'this' expressions.