clang: clang::ObjCAtTryStmt Class Reference (original) (raw)
Represents Objective-C's @try ... @catch ... @finally statement. More...
#include "[clang/AST/StmtObjC.h](StmtObjC%5F8h%5Fsource.html)"
Public Types | |
---|---|
using | catch_stmt_iterator = CastIterator< ObjCAtCatchStmt > |
using | const_catch_stmt_iterator = ConstCastIterator< ObjCAtCatchStmt > |
using | catch_range = llvm::iterator_range< catch_stmt_iterator > |
using | catch_const_range = llvm::iterator_range< const_catch_stmt_iterator > |
![]() |
|
enum | StmtClass { NoStmtClass = 0 } |
enum | Likelihood { LH_Unlikely = -1 , LH_None, LH_Likely } |
The likelihood of a branch being taken. More... | |
using | child_iterator = StmtIterator |
Child Iterators: All subclasses must implement 'children' to permit easy iteration over the substatements/subexpressions of an AST node. | |
using | const_child_iterator = ConstStmtIterator |
using | child_range = llvm::iterator_range< child_iterator > |
using | const_child_range = llvm::iterator_range< const_child_iterator > |
Public Member Functions | |
---|---|
SourceLocation | getAtTryLoc () const |
Retrieve the location of the @ in the @try. | |
void | setAtTryLoc (SourceLocation Loc) |
const Stmt * | getTryBody () const |
Retrieve the @try body. | |
Stmt * | getTryBody () |
void | setTryBody (Stmt *S) |
unsigned | getNumCatchStmts () const |
Retrieve the number of @catch statements in this try-catch-finally block. | |
const ObjCAtCatchStmt * | getCatchStmt (unsigned I) const |
Retrieve a @catch statement. | |
ObjCAtCatchStmt * | getCatchStmt (unsigned I) |
Retrieve a @catch statement. | |
void | setCatchStmt (unsigned I, ObjCAtCatchStmt *S) |
Set a particular catch statement. | |
const ObjCAtFinallyStmt * | getFinallyStmt () const |
Retrieve the @finally statement, if any. | |
ObjCAtFinallyStmt * | getFinallyStmt () |
void | setFinallyStmt (Stmt *S) |
SourceLocation | getBeginLoc () const LLVM_READONLY |
SourceLocation | getEndLoc () const LLVM_READONLY |
child_range | children () |
const_child_range | children () const |
catch_stmt_iterator | catch_stmts_begin () |
catch_stmt_iterator | catch_stmts_end () |
catch_range | catch_stmts () |
const_catch_stmt_iterator | catch_stmts_begin () const |
const_catch_stmt_iterator | catch_stmts_end () const |
catch_const_range | catch_stmts () const |
![]() |
|
void * | operator new (size_t bytes, const ASTContext &C, unsigned alignment=8) |
void * | operator new (size_t bytes, const ASTContext *C, unsigned alignment=8) |
void * | operator new (size_t bytes, void *mem) noexcept |
void | operator delete (void *, const ASTContext &, unsigned) noexcept |
void | operator delete (void *, const ASTContext *, unsigned) noexcept |
void | operator delete (void *, size_t) noexcept |
void | operator delete (void *, void *) noexcept |
Stmt ()=delete | |
Stmt (const Stmt &)=delete | |
Stmt (Stmt &&)=delete | |
Stmt & | operator= (const Stmt &)=delete |
Stmt & | operator= (Stmt &&)=delete |
Stmt (StmtClass SC) | |
StmtClass | getStmtClass () const |
const char * | getStmtClassName () const |
SourceRange | getSourceRange () const LLVM_READONLY |
SourceLocation tokens are not useful in isolation - they are low level value objects created/interpreted by SourceManager. | |
SourceLocation | getBeginLoc () const LLVM_READONLY |
SourceLocation | getEndLoc () const LLVM_READONLY |
void | dump () const |
Dumps the specified AST fragment and all subtrees to llvm::errs(). | |
void | dump (raw_ostream &OS, const ASTContext &Context) const |
int64_t | getID (const ASTContext &Context) const |
void | dumpColor () const |
dumpColor - same as dump(), but forces color highlighting. | |
void | dumpPretty (const ASTContext &Context) const |
dumpPretty/printPretty - These two methods do a "pretty print" of the AST back to its original source language syntax. | |
void | printPretty (raw_ostream &OS, PrinterHelper *Helper, const PrintingPolicy &Policy, unsigned Indentation=0, StringRef NewlineSymbol="\n", const ASTContext *Context=nullptr) const |
void | printPrettyControlled (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. | |
void | viewAST () const |
viewAST - Visualize an AST rooted at this Stmt* using GraphViz. | |
Stmt * | IgnoreContainers (bool IgnoreCaptured=false) |
Skip no-op (attributed, compound) container stmts and skip captured stmt at the top, if IgnoreCaptured is true. | |
const Stmt * | IgnoreContainers (bool IgnoreCaptured=false) const |
const Stmt * | stripLabelLikeStatements () const |
Strip off all label-like statements. | |
Stmt * | stripLabelLikeStatements () |
child_range | children () |
const_child_range | children () const |
child_iterator | child_begin () |
child_iterator | child_end () |
const_child_iterator | child_begin () const |
const_child_iterator | child_end () const |
void | Profile (llvm::FoldingSetNodeID &ID, const ASTContext &Context, bool Canonical, bool ProfileLambdaExpr=false) const |
Produce a unique representation of the given statement. | |
void | ProcessODRHash (llvm::FoldingSetNodeID &ID, ODRHash &Hash) const |
Calculate a unique representation for a statement that is stable across compiler invocations. | |
Static Public Member Functions | |
---|---|
static ObjCAtTryStmt * | Create (const ASTContext &Context, SourceLocation atTryLoc, Stmt *atTryStmt, Stmt **CatchStmts, unsigned NumCatchStmts, Stmt *atFinallyStmt) |
static ObjCAtTryStmt * | CreateEmpty (const ASTContext &Context, unsigned NumCatchStmts, bool HasFinally) |
static bool | classof (const Stmt *T) |
![]() |
|
static void | addStmtClass (const StmtClass s) |
static void | EnableStatistics () |
static void | PrintStats () |
static Likelihood | getLikelihood (ArrayRef< const Attr * > Attrs) |
static Likelihood | getLikelihood (const Stmt *S) |
static const Attr * | getLikelihoodAttr (const Stmt *S) |
static Likelihood | getLikelihood (const Stmt *Then, const Stmt *Else) |
static std::tuple< bool, const Attr *, const Attr * > | determineLikelihoodConflict (const Stmt *Then, const Stmt *Else) |
Represents Objective-C's @try ... @catch ... @finally statement.
Definition at line 165 of file StmtObjC.h.
◆ catch_const_range
◆ catch_range
◆ catch_stmt_iterator
◆ const_catch_stmt_iterator
◆ catch_stmts() [1/2]
catch_range clang::ObjCAtTryStmt::catch_stmts ( ) | inline |
---|
◆ catch_stmts() [2/2]
◆ catch_stmts_begin() [1/2]
◆ catch_stmts_begin() [2/2]
◆ catch_stmts_end() [1/2]
◆ catch_stmts_end() [2/2]
◆ children() [1/2]
◆ children() [2/2]
◆ classof()
static bool clang::ObjCAtTryStmt::classof ( const Stmt * T) | inlinestatic |
---|
◆ Create()
◆ CreateEmpty()
◆ getAtTryLoc()
Retrieve the location of the @ in the @try.
Definition at line 209 of file StmtObjC.h.
◆ getBeginLoc()
◆ getCatchStmt() [1/2]
Retrieve a @catch statement.
Definition at line 228 of file StmtObjC.h.
◆ getCatchStmt() [2/2]
◆ getEndLoc()
◆ getFinallyStmt() [1/2]
◆ getFinallyStmt() [2/2]
◆ getNumCatchStmts()
unsigned clang::ObjCAtTryStmt::getNumCatchStmts ( ) const | inline |
---|
Retrieve the number of @catch statements in this try-catch-finally block.
Definition at line 219 of file StmtObjC.h.
◆ getTryBody() [1/2]
Stmt * clang::ObjCAtTryStmt::getTryBody ( ) | inline |
---|
◆ getTryBody() [2/2]
const Stmt * clang::ObjCAtTryStmt::getTryBody ( ) const | inline |
---|
◆ setAtTryLoc()
◆ setCatchStmt()
Set a particular catch statement.
Definition at line 234 of file StmtObjC.h.
◆ setFinallyStmt()
void clang::ObjCAtTryStmt::setFinallyStmt ( Stmt * S) | inline |
---|
◆ setTryBody()
void clang::ObjCAtTryStmt::setTryBody ( Stmt * S) | inline |
---|
The documentation for this class was generated from the following files:
- include/clang/AST/StmtObjC.h
- lib/AST/StmtObjC.cpp